Fix "Assertion failure: srcArgs.callee().toFunction()->native() == native || srcArgs.callee().toFunction()->native() == js_generic_native_method_dispatcher, at jswrapper.cpp:788." Bug 743101, r=djvj.

This commit is contained in:
Jason Orendorff 2012-04-06 16:58:43 -05:00
Родитель 92afd1de3d
Коммит a3b1edc427
2 изменённых файлов: 7 добавлений и 2 удалений

Просмотреть файл

@ -286,7 +286,7 @@ MapObject::construct(JSContext *cx, unsigned argc, Value *vp)
JSBool JSBool
MapObject::size(JSContext *cx, unsigned argc, Value *vp) MapObject::size(JSContext *cx, unsigned argc, Value *vp)
{ {
THIS_MAP(get, cx, argc, vp, args, map); THIS_MAP(size, cx, argc, vp, args, map);
JS_STATIC_ASSERT(sizeof map.count() <= sizeof(uint32_t)); JS_STATIC_ASSERT(sizeof map.count() <= sizeof(uint32_t));
args.rval().setNumber(map.count()); args.rval().setNumber(map.count());
return true; return true;
@ -455,7 +455,7 @@ SetObject::construct(JSContext *cx, unsigned argc, Value *vp)
JSBool JSBool
SetObject::size(JSContext *cx, unsigned argc, Value *vp) SetObject::size(JSContext *cx, unsigned argc, Value *vp)
{ {
THIS_SET(has, cx, argc, vp, args, set); THIS_SET(size, cx, argc, vp, args, set);
JS_STATIC_ASSERT(sizeof set.count() <= sizeof(uint32_t)); JS_STATIC_ASSERT(sizeof set.count() <= sizeof(uint32_t));
args.rval().setNumber(set.count()); args.rval().setNumber(set.count());
return true; return true;

Просмотреть файл

@ -0,0 +1,5 @@
load(libdir + "asserts.js");
var g = newGlobal('new-compartment');
assertThrowsInstanceOf(function () { Map.prototype.size.apply(g, []); }, g.TypeError);
assertThrowsInstanceOf(function () { Set.prototype.size.apply(g, []); }, g.TypeError);