diff options
author | Adam Chelminski <adam.chelminski@mongodb.com> | 2016-08-05 11:49:17 -0400 |
---|---|---|
committer | Adam Chelminski <adam.chelminski@mongodb.com> | 2016-08-15 10:52:24 -0400 |
commit | df4248d69bd6643925d0e9cc62c6be3adf7750d7 (patch) | |
tree | 1f6b84bc55c83a7c981f74ed7483dc087b7b23f6 /src/mongo/scripting/mozjs/numberlong.cpp | |
parent | 9175ab505d970a6e97733a28e16496426d10f3ee (diff) | |
download | mongo-df4248d69bd6643925d0e9cc62c6be3adf7750d7.tar.gz |
SERVER-24146 Fix JSON.stringify regression, and add new "tostrictjson" shell util function for printing strict JSON
Diffstat (limited to 'src/mongo/scripting/mozjs/numberlong.cpp')
-rw-r--r-- | src/mongo/scripting/mozjs/numberlong.cpp | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/src/mongo/scripting/mozjs/numberlong.cpp b/src/mongo/scripting/mozjs/numberlong.cpp index 7bc9ebe10ff..1f763e47c20 100644 --- a/src/mongo/scripting/mozjs/numberlong.cpp +++ b/src/mongo/scripting/mozjs/numberlong.cpp @@ -43,9 +43,10 @@ namespace mongo { namespace mozjs { -const JSFunctionSpec NumberLongInfo::methods[5] = { +const JSFunctionSpec NumberLongInfo::methods[6] = { MONGO_ATTACH_JS_CONSTRAINED_METHOD(toNumber, NumberLongInfo), MONGO_ATTACH_JS_CONSTRAINED_METHOD(toString, NumberLongInfo), + MONGO_ATTACH_JS_CONSTRAINED_METHOD(toJSON, NumberLongInfo), MONGO_ATTACH_JS_CONSTRAINED_METHOD(valueOf, NumberLongInfo), MONGO_ATTACH_JS_CONSTRAINED_METHOD(compare, NumberLongInfo), JS_FS_END}; @@ -53,7 +54,7 @@ const JSFunctionSpec NumberLongInfo::methods[5] = { const char* const NumberLongInfo::className = "NumberLong"; void NumberLongInfo::finalize(JSFreeOp* fop, JSObject* obj) { - auto numLong = static_cast<int*>(JS_GetPrivate(obj)); + auto numLong = static_cast<int64_t*>(JS_GetPrivate(obj)); if (numLong) delete numLong; @@ -94,6 +95,13 @@ void NumberLongInfo::Functions::toString::call(JSContext* cx, JS::CallArgs args) ValueReader(cx, args.rval()).fromStringData(ss.operator std::string()); } +void NumberLongInfo::Functions::toJSON::call(JSContext* cx, JS::CallArgs args) { + int64_t val = NumberLongInfo::ToNumberLong(cx, args.thisv()); + + ValueReader(cx, args.rval()) + .fromBSON(BSON("$numberLong" << std::to_string(val)), nullptr, false); +} + void NumberLongInfo::Functions::compare::call(JSContext* cx, JS::CallArgs args) { uassert(ErrorCodes::BadValue, "NumberLong.compare() needs 1 argument", args.length() == 1); uassert(ErrorCodes::BadValue, |