js/src/tests/js1_8_5/extensions/reflect-parse-proxy.js

Thu, 22 Jan 2015 13:21:57 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Thu, 22 Jan 2015 13:21:57 +0100
branch
TOR_BUG_9701
changeset 15
b8a032363ba2
permissions
-rw-r--r--

Incorporate requested changes from Mozilla in review:
https://bugzilla.mozilla.org/show_bug.cgi?id=1123480#c6

michael@0 1 // |reftest| skip-if(!xulRuntime.shell)
michael@0 2 // bug 905774
michael@0 3
michael@0 4 // Proxy options
michael@0 5 var opts = new Proxy({loc: false}, {});
michael@0 6 assertEq(Reflect.parse("0;", opts).loc === null, true);
michael@0 7 opts.loc = true;
michael@0 8 assertEq(Reflect.parse("0;", opts).loc !== null, true);
michael@0 9 delete opts.loc;
michael@0 10 assertEq(Reflect.parse("0;", opts).loc !== null, true); // default is true
michael@0 11
michael@0 12 // Proxy builder
michael@0 13 var builder = {
michael@0 14 program: function (body) { return body.join(); },
michael@0 15 expressionStatement: function (expr) { return expr + ";" },
michael@0 16 literal: function (val) { return "" + val; }
michael@0 17 };
michael@0 18 opts = {builder: new Proxy(builder, {})};
michael@0 19 assertEq(Reflect.parse("0xff;", opts), "255;");
michael@0 20
michael@0 21 reportCompare(0, 0, 'ok');

mercurial