Support debugger reconnection when the packager goes down.

Summary:
This should resolve the issue highlighted in #1709
Closes https://github.com/facebook/react-native/pull/1992
Github Author: Sean Powell <sean@longdivision.co.uk>
This commit is contained in:
Sean Powell 2015-07-16 14:16:50 -07:00
parent f7d51c750f
commit 0cc159ff66

View File

@ -27,6 +27,11 @@ window.onbeforeunload = function() {
} }
}; };
// Alias native implementations needed by the debugger before platform-specific
// implementations are loaded into the global namespace
var debuggerSetTimeout = window.setTimeout;
var DebuggerWebSocket = window.WebSocket;
function setStatus(status) { function setStatus(status) {
document.getElementById('status').innerHTML = status; document.getElementById('status').innerHTML = status;
} }
@ -58,35 +63,43 @@ var messageHandlers = {
sendReply(JSON.stringify(returnValue)); sendReply(JSON.stringify(returnValue));
} }
} }
} };
var ws = new WebSocket('ws://' + window.location.host + '/debugger-proxy'); function connectToDebuggerProxy() {
var ws = new DebuggerWebSocket('ws://' + window.location.host + '/debugger-proxy');
ws.onopen = function() { ws.onopen = function() {
if (sessionID) { if (sessionID) {
setStatus('Debugger session #' + sessionID + ' active'); setStatus('Debugger session #' + sessionID + ' active');
ws.send(JSON.stringify({replyID: parseInt(sessionID, 10)})); ws.send(JSON.stringify({replyID: parseInt(sessionID, 10)}));
} else { } else {
setStatus('Waiting, press ⌘R in simulator to reload and connect'); setStatus('Waiting, press ⌘R in simulator to reload and connect');
} }
} };
ws.onmessage = function(message) { ws.onmessage = function(message) {
var object = JSON.parse(message.data); var object = JSON.parse(message.data);
var sendReply = function(result) { var sendReply = function(result) {
ws.send(JSON.stringify({replyID: object.id, result: result})); ws.send(JSON.stringify({replyID: object.id, result: result}));
} };
var handler = messageHandlers[object.method]; var handler = messageHandlers[object.method];
if (handler) { if (handler) {
handler(object, sendReply); handler(object, sendReply);
} else { } else {
console.warn('Unknown method: ' + object.method); console.warn('Unknown method: ' + object.method);
} }
};
ws.onclose = function() {
setStatus('Disconnected from proxy. Attempting reconnection. Is node server running?');
sessionID = null;
window.localStorage.removeItem('sessionID');
debuggerSetTimeout(connectToDebuggerProxy, 100);
};
} }
ws.onclose = function() { connectToDebuggerProxy();
setStatus('Disconnected from proxy. Is node server running?');
}
function loadScript(src, callback) { function loadScript(src, callback) {
var script = document.createElement('script'); var script = document.createElement('script');