From 2bbdb0cd396d785a9587bc776d699283c1902ff7 Mon Sep 17 00:00:00 2001 From: Chad Austin Date: Mon, 31 Mar 2014 22:43:28 -0700 Subject: embind doesn't always need the full std::type_info record. if EMSCRIPTEN_HAS_UNBOUND_TYPE_NAMES=0, then use a lighter type identifier. This shaves 175 KB off of our engine's minified JavaScript. --- system/lib/embind/bind.cpp | 38 ++++++++++++++++++++++---------------- 1 file changed, 22 insertions(+), 16 deletions(-) (limited to 'system/lib/embind/bind.cpp') diff --git a/system/lib/embind/bind.cpp b/system/lib/embind/bind.cpp index f43d1ea1..37918050 100644 --- a/system/lib/embind/bind.cpp +++ b/system/lib/embind/bind.cpp @@ -14,26 +14,32 @@ using namespace emscripten; extern "C" { const char* __attribute__((used)) __getTypeName(const std::type_info* ti) { + if (has_unbound_type_names) { #ifdef USE_CXA_DEMANGLE - int stat; - char* demangled = abi::__cxa_demangle(ti->name(), NULL, NULL, &stat); - if (stat == 0 && demangled) { - return demangled; - } + int stat; + char* demangled = abi::__cxa_demangle(ti->name(), NULL, NULL, &stat); + if (stat == 0 && demangled) { + return demangled; + } - switch (stat) { - case -1: - return strdup(""); - case -2: - return strdup(""); - case -3: - return strdup(""); - default: - return strdup(""); - } + switch (stat) { + case -1: + return strdup(""); + case -2: + return strdup(""); + case -3: + return strdup(""); + default: + return strdup(""); + } #else - return strdup(ti->name()); + return strdup(ti->name()); #endif + } else { + char str[80]; + sprintf(str, "%p", ti); + return strdup(str); + } } } -- cgit v1.2.3-70-g09d2