Wed, 31 Dec 2014 06:09:35 +0100
Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.
michael@0 | 1 | // Creating a global within an onNewGlobalObject handler causes a recursive handler invocation. |
michael@0 | 2 | // |
michael@0 | 3 | // This isn't really desirable behavior, as presumably a global created while a |
michael@0 | 4 | // handler is running is one the debugger is creating for its own purposes and |
michael@0 | 5 | // should not be observed, but if this behavior changes, we sure want to know. |
michael@0 | 6 | |
michael@0 | 7 | var dbg = new Debugger; |
michael@0 | 8 | var log; |
michael@0 | 9 | var depth; |
michael@0 | 10 | |
michael@0 | 11 | dbg.onNewGlobalObject = function (global) { |
michael@0 | 12 | log += '('; depth++; |
michael@0 | 13 | |
michael@0 | 14 | assertEq(global.seen, undefined); |
michael@0 | 15 | global.seen = true; |
michael@0 | 16 | |
michael@0 | 17 | if (depth < 3) |
michael@0 | 18 | newGlobal(); |
michael@0 | 19 | |
michael@0 | 20 | log += ')'; depth--; |
michael@0 | 21 | }; |
michael@0 | 22 | |
michael@0 | 23 | log = ''; |
michael@0 | 24 | depth = 0; |
michael@0 | 25 | newGlobal(); |
michael@0 | 26 | assertEq(log, '((()))'); |