Thu, 15 Jan 2015 21:03:48 +0100
Integrate friendly tips from Tor colleagues to make (or not) 4.5 alpha 3;
This includes removal of overloaded (but unused) methods, and addition of
a overlooked call to DataStruct::SetData(nsISupports, uint32_t, bool.)
michael@0 | 1 | // Eval-in-frame with different type on baseline frame with let-scoping |
michael@0 | 2 | |
michael@0 | 3 | load(libdir + "jitopts.js"); |
michael@0 | 4 | |
michael@0 | 5 | if (!jitTogglesMatch(Opts_BaselineEager)) |
michael@0 | 6 | quit(0); |
michael@0 | 7 | |
michael@0 | 8 | withJitOptions(Opts_BaselineEager, function () { |
michael@0 | 9 | var g = newGlobal(); |
michael@0 | 10 | var dbg = new Debugger; |
michael@0 | 11 | |
michael@0 | 12 | g.h = function h(d) { |
michael@0 | 13 | if (d) { |
michael@0 | 14 | dbg.addDebuggee(g); |
michael@0 | 15 | var f = dbg.getNewestFrame().older; |
michael@0 | 16 | assertEq(f.implementation, "baseline"); |
michael@0 | 17 | assertEq(f.environment.getVariable("foo"), 42); |
michael@0 | 18 | f.eval("foo = 'string of 42'"); |
michael@0 | 19 | } |
michael@0 | 20 | } |
michael@0 | 21 | |
michael@0 | 22 | g.eval("" + function f(d) { |
michael@0 | 23 | if (d) { |
michael@0 | 24 | let foo = 42; |
michael@0 | 25 | g(d); |
michael@0 | 26 | return foo; |
michael@0 | 27 | } |
michael@0 | 28 | }); |
michael@0 | 29 | |
michael@0 | 30 | g.eval("" + function g(d) { h(d); }); |
michael@0 | 31 | |
michael@0 | 32 | g.eval("(" + function () { assertEq(f(true), "string of 42"); } + ")();"); |
michael@0 | 33 | }); |