diff options
author | William S Fulton <wsf@fultondesigns.co.uk> | 2022-10-14 19:19:13 +0100 |
---|---|---|
committer | William S Fulton <wsf@fultondesigns.co.uk> | 2022-10-14 19:19:13 +0100 |
commit | bba072d95d9a020b03f60026d5a3fae788a03b0b (patch) | |
tree | 36436c01992a500f6003ea9df00a2c63fe13ba29 /Lib | |
parent | 54497fce49485f138211f6188009dc103b7e05cc (diff) | |
parent | cdb0e498a1453be2c77ddd3a11ba658f97ce0500 (diff) | |
download | swig-bba072d95d9a020b03f60026d5a3fae788a03b0b.tar.gz |
Merge branch 'fix-cast'
* fix-cast:
add tests for new casting behavior
skip tests when value is out of range
refactor integers JS testcase to avoid repeating code
Return uint64_t as double if is bigger than uint32_t
Use SWIG_TypeCast in SWIG_V8_ConvertInstancePtr if types don't match (#3)
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/javascript/v8/javascriptprimtypes.swg | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/Lib/javascript/v8/javascriptprimtypes.swg b/Lib/javascript/v8/javascriptprimtypes.swg index 0af406b90..8ed571df1 100644 --- a/Lib/javascript/v8/javascriptprimtypes.swg +++ b/Lib/javascript/v8/javascriptprimtypes.swg @@ -81,7 +81,7 @@ int SWIG_AsVal_dec(long)(SWIGV8_VALUE obj, long* val) SWIGINTERNINLINE SWIGV8_VALUE SWIG_From_dec(unsigned long)(unsigned long value) { - return SWIGV8_INTEGER_NEW_UNS(value); + return value <= UINT32_MAX ? (SWIGV8_VALUE)SWIGV8_INTEGER_NEW_UNS(value) : (SWIGV8_VALUE)SWIGV8_NUMBER_NEW(static_cast<double>(value)); } } @@ -149,7 +149,7 @@ int SWIG_AsVal_dec(long long)(SWIGV8_VALUE obj, long long* val) SWIGINTERNINLINE SWIGV8_VALUE SWIG_From_dec(unsigned long long)(unsigned long long value) { - return SWIGV8_INTEGER_NEW_UNS(value); + return value <= UINT32_MAX ? (SWIGV8_VALUE)SWIGV8_INTEGER_NEW_UNS(value) : (SWIGV8_VALUE)SWIGV8_NUMBER_NEW(static_cast<double>(value)); } %#endif } |