0
0
Fork 0
mirror of https://github.com/denoland/rusty_v8.git synced 2025-01-11 16:42:32 -05:00

Add V8InspectorClientImpl::console_api_message() (#252)

This makes it possible to intercept console.log() messages through
the V8 inspector API.
This commit is contained in:
Ben Noordhuis 2020-01-24 15:33:54 +01:00 committed by Ryan Dahl
parent 6303158de0
commit 683aa2b2a9
5 changed files with 182 additions and 0 deletions

View file

@ -1378,6 +1378,13 @@ void v8_inspector__V8InspectorClient__BASE__quitMessageLoopOnPause(
v8_inspector::V8InspectorClient& self); v8_inspector::V8InspectorClient& self);
void v8_inspector__V8InspectorClient__BASE__runIfWaitingForDebugger( void v8_inspector__V8InspectorClient__BASE__runIfWaitingForDebugger(
v8_inspector::V8InspectorClient& self, int contextGroupId); v8_inspector::V8InspectorClient& self, int contextGroupId);
void v8_inspector__V8InspectorClient__BASE__consoleAPIMessage(
v8_inspector::V8InspectorClient& self, int contextGroupId,
v8::Isolate::MessageErrorLevel level,
const v8_inspector::StringView& message,
const v8_inspector::StringView& url,
unsigned lineNumber, unsigned columnNumber,
v8_inspector::V8StackTrace* stackTrace);
} // extern "C" } // extern "C"
struct v8_inspector__V8InspectorClient__BASE struct v8_inspector__V8InspectorClient__BASE
@ -1395,6 +1402,17 @@ struct v8_inspector__V8InspectorClient__BASE
v8_inspector__V8InspectorClient__BASE__runIfWaitingForDebugger( v8_inspector__V8InspectorClient__BASE__runIfWaitingForDebugger(
*this, contextGroupId); *this, contextGroupId);
} }
void consoleAPIMessage(
int contextGroupId,
v8::Isolate::MessageErrorLevel level,
const v8_inspector::StringView& message,
const v8_inspector::StringView& url,
unsigned lineNumber, unsigned columnNumber,
v8_inspector::V8StackTrace* stackTrace) override {
v8_inspector__V8InspectorClient__BASE__consoleAPIMessage(
*this, contextGroupId, level, message, url,
lineNumber, columnNumber, stackTrace);
}
}; };
extern "C" { extern "C" {
@ -1416,6 +1434,17 @@ void v8_inspector__V8InspectorClient__runIfWaitingForDebugger(
self.runIfWaitingForDebugger(contextGroupId); self.runIfWaitingForDebugger(contextGroupId);
} }
void v8_inspector__V8InspectorClient__consoleAPIMessage(
v8_inspector::V8InspectorClient& self, int contextGroupId,
v8::Isolate::MessageErrorLevel level,
const v8_inspector::StringView& message,
const v8_inspector::StringView& url,
unsigned lineNumber, unsigned columnNumber,
v8_inspector::V8StackTrace* stackTrace) {
self.consoleAPIMessage(contextGroupId, level, message, url,
lineNumber, columnNumber, stackTrace);
}
void v8_inspector__StringBuffer__DELETE(v8_inspector::StringBuffer& self) { void v8_inspector__StringBuffer__DELETE(v8_inspector::StringBuffer& self) {
delete &self; delete &self;
} }

View file

@ -1,3 +1,4 @@
use super::{StringView, V8StackTrace};
use crate::support::int; use crate::support::int;
use crate::support::CxxVTable; use crate::support::CxxVTable;
use crate::support::FieldOffset; use crate::support::FieldOffset;
@ -20,6 +21,16 @@ extern "C" {
this: &mut V8InspectorClient, this: &mut V8InspectorClient,
context_group_id: int, context_group_id: int,
) -> (); ) -> ();
fn v8_inspector__V8InspectorClient__consoleAPIMessage(
this: &mut V8InspectorClient,
context_group_id: int,
level: int,
message: &StringView,
url: &StringView,
line_number: u32,
column_number: u32,
stack_trace: &mut V8StackTrace,
) -> ();
} }
#[no_mangle] #[no_mangle]
@ -47,6 +58,28 @@ pub unsafe extern "C" fn v8_inspector__V8InspectorClient__BASE__runIfWaitingForD
.run_if_waiting_for_debugger(context_group_id) .run_if_waiting_for_debugger(context_group_id)
} }
#[no_mangle]
pub unsafe extern "C" fn v8_inspector__V8InspectorClient__BASE__consoleAPIMessage(
this: &mut V8InspectorClient,
context_group_id: int,
level: int,
message: &StringView,
url: &StringView,
line_number: u32,
column_number: u32,
stack_trace: &mut V8StackTrace,
) {
V8InspectorClientBase::dispatch_mut(this).console_api_message(
context_group_id,
level,
message,
url,
line_number,
column_number,
stack_trace,
)
}
#[repr(C)] #[repr(C)]
pub struct V8InspectorClient { pub struct V8InspectorClient {
_cxx_vtable: CxxVTable, _cxx_vtable: CxxVTable,
@ -61,9 +94,11 @@ impl V8InspectorClient {
) )
} }
} }
pub fn quit_message_loop_on_pause(&mut self) { pub fn quit_message_loop_on_pause(&mut self) {
unsafe { v8_inspector__V8InspectorClient__quitMessageLoopOnPause(self) } unsafe { v8_inspector__V8InspectorClient__quitMessageLoopOnPause(self) }
} }
pub fn run_if_waiting_for_debugger(&mut self, context_group_id: int) { pub fn run_if_waiting_for_debugger(&mut self, context_group_id: int) {
unsafe { unsafe {
v8_inspector__V8InspectorClient__runIfWaitingForDebugger( v8_inspector__V8InspectorClient__runIfWaitingForDebugger(
@ -72,6 +107,31 @@ impl V8InspectorClient {
) )
} }
} }
#[allow(clippy::too_many_arguments)]
pub fn console_api_message(
&mut self,
context_group_id: int,
level: int,
message: &StringView,
url: &StringView,
line_number: u32,
column_number: u32,
stack_trace: &mut V8StackTrace,
) {
unsafe {
v8_inspector__V8InspectorClient__consoleAPIMessage(
self,
context_group_id,
level,
message,
url,
line_number,
column_number,
stack_trace,
)
}
}
} }
pub trait AsV8InspectorClient { pub trait AsV8InspectorClient {
@ -108,6 +168,19 @@ pub trait V8InspectorClientImpl: AsV8InspectorClient {
fn run_message_loop_on_pause(&mut self, context_group_id: int) {} fn run_message_loop_on_pause(&mut self, context_group_id: int) {}
fn quit_message_loop_on_pause(&mut self) {} fn quit_message_loop_on_pause(&mut self) {}
fn run_if_waiting_for_debugger(&mut self, context_group_id: int) {} fn run_if_waiting_for_debugger(&mut self, context_group_id: int) {}
#[allow(clippy::too_many_arguments)]
fn console_api_message(
&mut self,
context_group_id: int,
level: int,
message: &StringView,
url: &StringView,
line_number: u32,
column_number: u32,
stack_trace: &mut V8StackTrace,
) {
}
} }
pub struct V8InspectorClientBase { pub struct V8InspectorClientBase {

View file

@ -4,6 +4,7 @@ mod session;
mod string_buffer; mod string_buffer;
mod string_view; mod string_view;
mod v8_inspector; mod v8_inspector;
mod v8_stack_trace;
pub use channel::{AsChannel, Channel, ChannelBase, ChannelImpl}; pub use channel::{AsChannel, Channel, ChannelBase, ChannelImpl};
pub use client::AsV8InspectorClient; pub use client::AsV8InspectorClient;
@ -14,3 +15,4 @@ pub use session::V8InspectorSession;
pub use string_buffer::StringBuffer; pub use string_buffer::StringBuffer;
pub use string_view::StringView; pub use string_view::StringView;
pub use v8_inspector::V8Inspector; pub use v8_inspector::V8Inspector;
pub use v8_stack_trace::V8StackTrace;

View file

@ -0,0 +1,9 @@
use crate::support::CxxVTable;
#[repr(C)]
pub struct V8StackTrace {
_cxx_vtable: CxxVTable,
}
// TODO(bnoordhuis) This needs to be fleshed out more but that can wait
// until it's actually needed.

View file

@ -2350,6 +2350,75 @@ fn inspector_dispatch_protocol_message() {
assert_eq!(channel.flush_protocol_notifications_count, 0); assert_eq!(channel.flush_protocol_notifications_count, 0);
} }
#[test]
fn inspector_console_api_message() {
let _setup_guard = setup();
let mut params = v8::Isolate::create_params();
params.set_array_buffer_allocator(v8::new_default_allocator());
let mut isolate = v8::Isolate::new(params);
let mut locker = v8::Locker::new(&isolate);
let scope = locker.enter();
use v8::inspector::*;
struct Client {
base: V8InspectorClientBase,
messages: Vec<String>,
}
impl Client {
fn new() -> Self {
Self {
base: V8InspectorClientBase::new::<Self>(),
messages: Vec::new(),
}
}
}
impl V8InspectorClientImpl for Client {
fn base(&self) -> &V8InspectorClientBase {
&self.base
}
fn base_mut(&mut self) -> &mut V8InspectorClientBase {
&mut self.base
}
fn console_api_message(
&mut self,
_context_group_id: i32,
_level: i32,
message: &StringView,
_url: &StringView,
_line_number: u32,
_column_number: u32,
_stack_trace: &mut V8StackTrace,
) {
self.messages.push(message.to_string());
}
}
let mut hs = v8::HandleScope::new(scope);
let scope = hs.enter();
let context = v8::Context::new(scope);
let mut cs = v8::ContextScope::new(scope, context);
let scope = cs.enter();
let mut client = Client::new();
let mut inspector = V8Inspector::create(&mut isolate, &mut client);
let name = b"";
let name_view = StringView::from(&name[..]);
inspector.context_created(context, 1, &name_view);
let source = r#"
console.log("one");
console.error("two");
console.trace("three");
"#;
let _ = eval(scope, context, source).unwrap();
assert_eq!(client.messages, vec!["one", "two", "three"]);
}
#[test] #[test]
fn context_from_object_template() { fn context_from_object_template() {
let _setup_guard = setup(); let _setup_guard = setup();