aboutsummaryrefslogtreecommitdiff
path: root/src/embind/embind.js
diff options
context:
space:
mode:
authorJukka Jylanki <jjylanki@imvu.com>2013-03-26 12:18:13 +0200
committerJukka Jylänki <jujjyl@gmail.com>2013-04-12 14:26:48 +0300
commit113721e6c6ca4cbde2bb39c4460269424ef3d81d (patch)
tree550b1420982c863ab6816fae6ba309038d7b5e77 /src/embind/embind.js
parent08881f98fdf4688afab03f4b0632f4d1385de969 (diff)
Raise a TypeError if user tries to push an integer from JS side to C/C++ function exported with embind and the integer (char/short/int/long) is out of bounds of the data type expected by the C++ function.
Diffstat (limited to 'src/embind/embind.js')
-rwxr-xr-xsrc/embind/embind.js9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/embind/embind.js b/src/embind/embind.js
index c7b1633a..ccce9f19 100755
--- a/src/embind/embind.js
+++ b/src/embind/embind.js
@@ -221,10 +221,14 @@ function __embind_register_bool(rawType, name, trueValue, falseValue) {
});
}
-function __embind_register_integer(rawType, name) {
+// When converting a number from JS to C++ side, the valid range of the number is
+// [minRange, maxRange], inclusive.
+function __embind_register_integer(primitiveType, name, minRange, maxRange) {
name = Pointer_stringify(name);
registerType(rawType, {
name: name,
+ minRange: minRange,
+ maxRange: maxRange,
fromWireType: function(value) {
return value;
},
@@ -232,6 +236,9 @@ function __embind_register_integer(rawType, name) {
if (typeof value !== "number") {
throw new TypeError('Cannot convert "' + _embind_repr(value) + '" to ' + this.name);
}
+ if (value < minRange || value > maxRange) {
+ throw new TypeError('Passing a number "' + _embind_repr(value) + '" from JS side to C/C++ side to an argument of type "' + name + '", which is outside the valid range [' + minRange + ', ' + maxRange + ']!');
+ }
return value | 0;
},
});