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)
This commit is contained in:
commit
bba072d95d
2 changed files with 21 additions and 15 deletions
|
|
@ -1,18 +1,24 @@
|
|||
var integers = require("integers");
|
||||
|
||||
var val = 3902408827
|
||||
ret = integers.signed_long_identity(val)
|
||||
if (ret != val)
|
||||
throw "Incorrect value: " + ret
|
||||
function checkOne(val, signed, typeName) {
|
||||
typeName = (signed ? 'signed_' : 'unsigned_') + typeName
|
||||
|
||||
ret = integers.unsigned_long_identity(val)
|
||||
if (ret != val)
|
||||
throw "Incorrect value: " + ret
|
||||
var size = integers[typeName + '_size']()
|
||||
if ((!signed && val < 0) || (size < 8))
|
||||
return // out of range, skip test
|
||||
|
||||
ret = integers.signed_long_long_identity(val)
|
||||
if (ret != val)
|
||||
throw "Incorrect value: " + ret
|
||||
ret = integers[typeName + '_identity'](val)
|
||||
if (ret !== val)
|
||||
throw "Incorrect value: expected " + val + ", got " + ret
|
||||
}
|
||||
|
||||
ret = integers.unsigned_long_long_identity(val)
|
||||
if (ret != val)
|
||||
throw "Incorrect value: " + ret
|
||||
function checkAll(val) {
|
||||
checkOne(val, true, 'long')
|
||||
checkOne(val, false, 'long')
|
||||
checkOne(val, true, 'long_long')
|
||||
checkOne(val, false, 'long_long')
|
||||
}
|
||||
|
||||
checkAll(3902408827)
|
||||
checkAll(Number.MAX_SAFE_INTEGER)
|
||||
checkAll(Number.MIN_SAFE_INTEGER)
|
||||
|
|
|
|||
|
|
@ -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
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue