mirror of
https://github.com/servo/servo.git
synced 2025-08-06 14:10:11 +01:00
Implement a WebSocket server for debugging.
This commit is contained in:
parent
77651959e2
commit
8856671f2e
7 changed files with 100 additions and 0 deletions
15
components/debugger/Cargo.toml
Normal file
15
components/debugger/Cargo.toml
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
[package]
|
||||||
|
name = "debugger"
|
||||||
|
version = "0.0.1"
|
||||||
|
authors = ["The Servo Project Developers"]
|
||||||
|
license = "MPL-2.0"
|
||||||
|
publish = false
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "debugger"
|
||||||
|
path = "lib.rs"
|
||||||
|
crate_type = ["rlib"]
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
util = { path = "../util" }
|
||||||
|
websocket = "0.17.1"
|
50
components/debugger/lib.rs
Normal file
50
components/debugger/lib.rs
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
|
extern crate util;
|
||||||
|
extern crate websocket;
|
||||||
|
|
||||||
|
use util::thread::spawn_named;
|
||||||
|
use websocket::{Message, Receiver, Sender, Server};
|
||||||
|
use websocket::message::Type;
|
||||||
|
|
||||||
|
pub fn start_server(port: u16) {
|
||||||
|
println!("Starting debugger server.");
|
||||||
|
spawn_named("debugger-server".to_owned(), move || {
|
||||||
|
run_server(port)
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
fn run_server(port: u16) {
|
||||||
|
let server = Server::bind(("127.0.0.1", port)).unwrap();
|
||||||
|
for connection in server {
|
||||||
|
spawn_named("debugger-connection".to_owned(), move || {
|
||||||
|
let connection = connection.unwrap();
|
||||||
|
let request = connection.read_request().unwrap();
|
||||||
|
let response = request.accept();
|
||||||
|
let client = response.send().unwrap();
|
||||||
|
let (mut sender, mut receiver) = client.split();
|
||||||
|
for message in receiver.incoming_messages() {
|
||||||
|
let message: Message = message.unwrap();
|
||||||
|
match message.opcode {
|
||||||
|
Type::Close => {
|
||||||
|
let message = Message::close();
|
||||||
|
sender.send_message(&message).unwrap();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
Type::Ping => {
|
||||||
|
let message = Message::pong(message.payload);
|
||||||
|
sender.send_message(&message).unwrap();
|
||||||
|
}
|
||||||
|
Type::Text => {
|
||||||
|
sender.send_message(&message).unwrap();
|
||||||
|
}
|
||||||
|
_ => {
|
||||||
|
panic!("Unexpected message type.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
9
components/servo/Cargo.lock
generated
9
components/servo/Cargo.lock
generated
|
@ -10,6 +10,7 @@ dependencies = [
|
||||||
"compiletest_helper 0.0.1",
|
"compiletest_helper 0.0.1",
|
||||||
"compositing 0.0.1",
|
"compositing 0.0.1",
|
||||||
"constellation 0.0.1",
|
"constellation 0.0.1",
|
||||||
|
"debugger 0.0.1",
|
||||||
"devtools 0.0.1",
|
"devtools 0.0.1",
|
||||||
"devtools_traits 0.0.1",
|
"devtools_traits 0.0.1",
|
||||||
"env_logger 0.3.4 (registry+https://github.com/rust-lang/crates.io-index)",
|
"env_logger 0.3.4 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
@ -481,6 +482,14 @@ dependencies = [
|
||||||
"unreachable 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"unreachable 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "debugger"
|
||||||
|
version = "0.0.1"
|
||||||
|
dependencies = [
|
||||||
|
"util 0.0.1",
|
||||||
|
"websocket 0.17.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "deque"
|
name = "deque"
|
||||||
version = "0.3.1"
|
version = "0.3.1"
|
||||||
|
|
|
@ -49,6 +49,7 @@ canvas = {path = "../canvas"}
|
||||||
canvas_traits = {path = "../canvas_traits"}
|
canvas_traits = {path = "../canvas_traits"}
|
||||||
compositing = {path = "../compositing"}
|
compositing = {path = "../compositing"}
|
||||||
constellation = {path = "../constellation"}
|
constellation = {path = "../constellation"}
|
||||||
|
debugger = {path = "../debugger"}
|
||||||
devtools = {path = "../devtools"}
|
devtools = {path = "../devtools"}
|
||||||
devtools_traits = {path = "../devtools_traits"}
|
devtools_traits = {path = "../devtools_traits"}
|
||||||
env_logger = "0.3"
|
env_logger = "0.3"
|
||||||
|
|
|
@ -28,6 +28,7 @@ pub extern crate canvas;
|
||||||
pub extern crate canvas_traits;
|
pub extern crate canvas_traits;
|
||||||
pub extern crate compositing;
|
pub extern crate compositing;
|
||||||
pub extern crate constellation;
|
pub extern crate constellation;
|
||||||
|
pub extern crate debugger;
|
||||||
pub extern crate devtools;
|
pub extern crate devtools;
|
||||||
pub extern crate devtools_traits;
|
pub extern crate devtools_traits;
|
||||||
pub extern crate euclid;
|
pub extern crate euclid;
|
||||||
|
@ -125,6 +126,9 @@ impl<Window> Browser<Window> where Window: WindowMethods + 'static {
|
||||||
let time_profiler_chan = profile_time::Profiler::create(&opts.time_profiling,
|
let time_profiler_chan = profile_time::Profiler::create(&opts.time_profiling,
|
||||||
opts.time_profiler_trace_path.clone());
|
opts.time_profiler_trace_path.clone());
|
||||||
let mem_profiler_chan = profile_mem::Profiler::create(opts.mem_profiler_period);
|
let mem_profiler_chan = profile_mem::Profiler::create(opts.mem_profiler_period);
|
||||||
|
if let Some(port) = opts.debugger_port {
|
||||||
|
debugger::start_server(port)
|
||||||
|
}
|
||||||
let devtools_chan = opts.devtools_port.map(|port| {
|
let devtools_chan = opts.devtools_port.map(|port| {
|
||||||
devtools::start_server(port)
|
devtools::start_server(port)
|
||||||
});
|
});
|
||||||
|
|
|
@ -123,6 +123,10 @@ pub struct Opts {
|
||||||
/// Enable all heartbeats for profiling.
|
/// Enable all heartbeats for profiling.
|
||||||
pub profile_heartbeats: bool,
|
pub profile_heartbeats: bool,
|
||||||
|
|
||||||
|
/// `None` to disable debugger or `Some` with a port number to start a server to listen to
|
||||||
|
/// remote Firefox debugger connections.
|
||||||
|
pub debugger_port: Option<u16>,
|
||||||
|
|
||||||
/// `None` to disable devtools or `Some` with a port number to start a server to listen to
|
/// `None` to disable devtools or `Some` with a port number to start a server to listen to
|
||||||
/// remote Firefox devtools connections.
|
/// remote Firefox devtools connections.
|
||||||
pub devtools_port: Option<u16>,
|
pub devtools_port: Option<u16>,
|
||||||
|
@ -502,6 +506,7 @@ pub fn default_opts() -> Opts {
|
||||||
enable_text_antialiasing: false,
|
enable_text_antialiasing: false,
|
||||||
enable_canvas_antialiasing: false,
|
enable_canvas_antialiasing: false,
|
||||||
trace_layout: false,
|
trace_layout: false,
|
||||||
|
debugger_port: None,
|
||||||
devtools_port: None,
|
devtools_port: None,
|
||||||
webdriver_port: None,
|
webdriver_port: None,
|
||||||
initial_window_size: TypedSize2D::new(1024, 740),
|
initial_window_size: TypedSize2D::new(1024, 740),
|
||||||
|
@ -562,6 +567,7 @@ pub fn from_cmdline_args(args: &[String]) -> ArgumentParsingResult {
|
||||||
opts.optflag("z", "headless", "Headless mode");
|
opts.optflag("z", "headless", "Headless mode");
|
||||||
opts.optflag("f", "hard-fail", "Exit on thread failure instead of displaying about:failure");
|
opts.optflag("f", "hard-fail", "Exit on thread failure instead of displaying about:failure");
|
||||||
opts.optflag("F", "soft-fail", "Display about:failure on thread failure instead of exiting");
|
opts.optflag("F", "soft-fail", "Display about:failure on thread failure instead of exiting");
|
||||||
|
opts.optflagopt("", "remote-debugging-port", "Start remote debugger server on port", "2794");
|
||||||
opts.optflagopt("", "devtools", "Start remote devtools server on port", "6000");
|
opts.optflagopt("", "devtools", "Start remote devtools server on port", "6000");
|
||||||
opts.optflagopt("", "webdriver", "Start remote WebDriver server on port", "7000");
|
opts.optflagopt("", "webdriver", "Start remote WebDriver server on port", "7000");
|
||||||
opts.optopt("", "resolution", "Set window resolution.", "1024x740");
|
opts.optopt("", "resolution", "Set window resolution.", "1024x740");
|
||||||
|
@ -721,6 +727,11 @@ pub fn from_cmdline_args(args: &[String]) -> ArgumentParsingResult {
|
||||||
bubble_inline_sizes_separately = true;
|
bubble_inline_sizes_separately = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let debugger_port = opt_match.opt_default("remote-debugging-port", "2794").map(|port| {
|
||||||
|
port.parse()
|
||||||
|
.unwrap_or_else(|err| args_fail(&format!("Error parsing option: --remote-debugging-port ({})", err)))
|
||||||
|
});
|
||||||
|
|
||||||
let devtools_port = opt_match.opt_default("devtools", "6000").map(|port| {
|
let devtools_port = opt_match.opt_default("devtools", "6000").map(|port| {
|
||||||
port.parse().unwrap_or_else(|err| args_fail(&format!("Error parsing option: --devtools ({})", err)))
|
port.parse().unwrap_or_else(|err| args_fail(&format!("Error parsing option: --devtools ({})", err)))
|
||||||
});
|
});
|
||||||
|
@ -802,6 +813,7 @@ pub fn from_cmdline_args(args: &[String]) -> ArgumentParsingResult {
|
||||||
profile_script_events: debug_options.profile_script_events,
|
profile_script_events: debug_options.profile_script_events,
|
||||||
profile_heartbeats: debug_options.profile_heartbeats,
|
profile_heartbeats: debug_options.profile_heartbeats,
|
||||||
trace_layout: debug_options.trace_layout,
|
trace_layout: debug_options.trace_layout,
|
||||||
|
debugger_port: debugger_port,
|
||||||
devtools_port: devtools_port,
|
devtools_port: devtools_port,
|
||||||
webdriver_port: webdriver_port,
|
webdriver_port: webdriver_port,
|
||||||
initial_window_size: initial_window_size,
|
initial_window_size: initial_window_size,
|
||||||
|
|
9
ports/cef/Cargo.lock
generated
9
ports/cef/Cargo.lock
generated
|
@ -439,6 +439,14 @@ dependencies = [
|
||||||
"unreachable 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"unreachable 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "debugger"
|
||||||
|
version = "0.0.1"
|
||||||
|
dependencies = [
|
||||||
|
"util 0.0.1",
|
||||||
|
"websocket 0.17.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "deque"
|
name = "deque"
|
||||||
version = "0.3.1"
|
version = "0.3.1"
|
||||||
|
@ -1972,6 +1980,7 @@ dependencies = [
|
||||||
"canvas_traits 0.0.1",
|
"canvas_traits 0.0.1",
|
||||||
"compositing 0.0.1",
|
"compositing 0.0.1",
|
||||||
"constellation 0.0.1",
|
"constellation 0.0.1",
|
||||||
|
"debugger 0.0.1",
|
||||||
"devtools 0.0.1",
|
"devtools 0.0.1",
|
||||||
"devtools_traits 0.0.1",
|
"devtools_traits 0.0.1",
|
||||||
"env_logger 0.3.4 (registry+https://github.com/rust-lang/crates.io-index)",
|
"env_logger 0.3.4 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue