diff options
author | Alon Zakai <alonzakai@gmail.com> | 2014-04-30 13:40:27 -0700 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2014-04-30 13:40:27 -0700 |
commit | 9dd3a7059749d4051202687817bf6b68ab2ce54c (patch) | |
tree | 6f98400f4bb90aedd7ea419163febb1d70c488fd /src/embind | |
parent | 63f913cc533e20cea584d2407de78c933d063b67 (diff) | |
parent | 7da733906454466f4ae22d1a1541ea152f5025db (diff) |
Merge pull request #2327 from chadaustin/embind-asmjs-precise-f32
Fix embind/asm.js in PRECISE_F32 mode
Diffstat (limited to 'src/embind')
-rw-r--r-- | src/embind/embind.js | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/src/embind/embind.js b/src/embind/embind.js index bb979365..3eadb85f 100644 --- a/src/embind/embind.js +++ b/src/embind/embind.js @@ -723,9 +723,16 @@ function requireFunction(signature, rawFunction) { // possibly allocate. var dc = asm['dynCall_' + signature]; if (dc === undefined) { - throwBindingError("No dynCall invoker for signature: " + signature); + // We will always enter this branch if the signature + // contains 'f' and PRECISE_F32 is not enabled. + // + // Try again, replacing 'f' with 'd'. + dc = asm['dynCall_' + signature.replace(/f/g, 'd')]; + if (dc === undefined) { + throwBindingError("No dynCall invoker for signature: " + signature); + } } - fp = asm['dynCall_' + signature].bind(undefined, rawFunction); + fp = dc.bind(undefined, rawFunction); } else { fp = FUNCTION_TABLE[rawFunction]; } |