diff --git a/packager/debugger.html b/packager/debugger.html index 3b905efe3..a69424ea9 100644 --- a/packager/debugger.html +++ b/packager/debugger.html @@ -42,32 +42,28 @@ function setStatus(status) { document.getElementById('status').innerHTML = status; } +// This worker will run the application javascript code, +// making sure that it's run in an environment without a global +// document, to make it consistent with the JSC executor environment. +var worker = new Worker('debuggerWorker.js'); + var messageHandlers = { // This method is a bit hacky. Catalyst asks for a new clean JS runtime. // The easiest way to do this is to reload this page. That also means that // web socket connection will be lost. To send reply back we need to remember - // message id + // message id. + // This message also needs to be handled outside of the worker, since the worker + // doesn't have access to local storage. 'prepareJSRuntime': function(message) { window.onbeforeunload = undefined; window.localStorage.setItem('sessionID', message.id); window.location.reload(); }, - 'executeApplicationScript': function(message, sendReply) { - for (var key in message.inject) { - window[key] = JSON.parse(message.inject[key]); - } - loadScript(message.url, sendReply.bind(null, null)); + 'executeApplicationScript': function(message) { + worker.postMessage(message); }, - 'executeJSCall': function(message, sendReply) { - var returnValue = null; - try { - if (window && window.require) { - var module = window.require(message.moduleName); - returnValue = module[message.moduleMethod].apply(module, message.arguments); - } - } finally { - sendReply(JSON.stringify(returnValue)); - } + 'executeJSCall': function(message) { + worker.postMessage(message); } }; @@ -89,12 +85,9 @@ function connectToDebuggerProxy() { return; } - var sendReply = function(result) { - ws.send(JSON.stringify({replyID: object.id, result: result})); - }; var handler = messageHandlers[object.method]; if (handler) { - handler(object, sendReply); + handler(object); } else { console.warn('Unknown method: ' + object.method); } @@ -107,18 +100,14 @@ function connectToDebuggerProxy() { window.localStorage.removeItem('sessionID'); debuggerSetTimeout(connectToDebuggerProxy, 100); }; + + worker.onmessage = function(message) { + ws.send(JSON.stringify(message.data)); + } } connectToDebuggerProxy(); -function loadScript(src, callback) { - var script = document.createElement('script'); - script.type = 'text/javascript'; - script.src = src; - script.onload = callback; - document.head.appendChild(script); -} - })();