integrating code from John Fairhurst <mjf35@cam.ac.uk> to deal with platforms without long long support

This commit is contained in:
jband%netscape.com 1999-03-27 00:30:19 +00:00
parent ebc7d5465e
commit 57df53d8d9
2 changed files with 41 additions and 4 deletions

View File

@ -93,11 +93,42 @@ XPCConvert::IsMethodReflectable(const nsXPTMethodInfo& info)
/***************************************************************************/
/*
* Support for 64 bit conversions were 'long long' not supported.
* (from John Fairhurst <mjf35@cam.ac.uk>)
*/
#ifdef JS_HAVE_LONG_LONG
#define JAM_DOUBLE(cx,v,d) (d=JS_NewDouble(cx,(jsdouble)v),DOUBLE_TO_JSVAL(d))
#define FIT_32(cx,i,d) (INT_FITS_IN_JSVAL(i)?INT_TO_JSVAL(i):JAM_DOUBLE(cx,i,d))
// Win32 can't handle uint64 to double conversion
#define JAM_DOUBLE_U64(cx,v,d) JAM_DOUBLE(cx,((int64)v),d)
#else
inline jsval
JAM_DOUBLE(JSContext *cx, const int64 &v, jsdouble *dbl)
{
jsdouble d;
LL_L2D(d, v);
dbl = JS_NewDouble(cx, d);
return DOUBLE_TO_JSVAL(dbl);
}
inline jsval
JAM_DOUBLE(JSContext *cx, double v, jsdouble *dbl)
{
dbl = JS_NewDouble(cx, (jsdouble)v);
return DOUBLE_TO_JSVAL(dbl);
}
// if !HAVE_LONG_LONG, then uint64 is a typedef of int64
#define JAM_DOUBLE_U64(cx,v,d) JAM_DOUBLE(cx,v,d)
#endif
#define FIT_32(cx,i,d) (INT_FITS_IN_JSVAL(i)?INT_TO_JSVAL(i):JAM_DOUBLE(cx,i,d))
// static
JSBool
XPCConvert::NativeData2JS(JSContext* cx, jsval* d, const void* s,
@ -293,13 +324,14 @@ XPCConvert::JSData2Native(JSContext* cx, void* d, jsval s,
{
if(!JS_ValueToECMAInt32(cx, s, &ti))
return JS_FALSE;
*((int64*)d) = (int64) ti;
LL_I2L(*((int64*)d),ti);
}
else
{
if(!JS_ValueToNumber(cx, s, &td))
return JS_FALSE;
*((int64*)d) = (int64) td;
LL_D2L(*((int64*)d),td);
}
break;
case nsXPTType::T_U8 :
@ -321,14 +353,18 @@ XPCConvert::JSData2Native(JSContext* cx, void* d, jsval s,
{
if(!JS_ValueToECMAUint32(cx, s, &tu))
return JS_FALSE;
*((uint64*)d) = (uint64) tu;
LL_UI2L(*((int64*)d),tu);
}
else
{
if(!JS_ValueToNumber(cx, s, &td))
return JS_FALSE;
#ifdef XP_WIN
// XXX Win32 can't handle double to uint64 directly
*((uint64*)d) = (uint64)((int64) td);
#else
LL_D2L(*((uint64*)d),td);
#endif
}
break;
case nsXPTType::T_FLOAT :

View File

@ -42,6 +42,7 @@
#include "xpclog.h"
#include "xpccomponents.h"
#include "xpcjsid.h"
#include "prlong.h"
extern const char* XPC_VAL_STR; // 'value' property name for out params