mirror of
https://github.com/status-im/metro.git
synced 2025-01-22 00:50:52 +00:00
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:
parent
f7d51c750f
commit
0cc159ff66
@ -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');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user