#![allow(non_snake_case)]
use std::convert::TryInto;
use crate::Context;
use crate::Local;
use crate::Message;
use crate::Object;
use crate::StackFrame;
use crate::StackTrace;
use crate::String;
use crate::Value;
use crate::isolate::RealIsolate;
use crate::scope::PinScope;
use crate::support::MaybeBool;
use crate::support::int;
unsafe extern "C" {
fn v8__Message__Get(this: *const Message) -> *const String;
fn v8__Message__GetSourceLine(
this: *const Message,
context: *const Context,
) -> *const String;
fn v8__Message__GetScriptResourceName(this: *const Message) -> *const Value;
fn v8__Message__GetLineNumber(
this: *const Message,
context: *const Context,
) -> int;
fn v8__Message__GetStartPosition(this: *const Message) -> int;
fn v8__Message__GetEndPosition(this: *const Message) -> int;
fn v8__Message__GetWasmFunctionIndex(this: *const Message) -> int;
fn v8__Message__ErrorLevel(this: *const Message) -> int;
fn v8__Message__GetStartColumn(this: *const Message) -> int;
fn v8__Message__GetEndColumn(this: *const Message) -> int;
fn v8__Message__IsSharedCrossOrigin(this: *const Message) -> bool;
fn v8__Message__IsOpaque(this: *const Message) -> bool;
fn v8__Message__GetStackTrace(this: *const Message) -> *const StackTrace;
fn v8__StackTrace__CurrentStackTrace(
isolate: *mut RealIsolate,
frame_limit: int,
) -> *const StackTrace;
fn v8__StackTrace__CurrentScriptNameOrSourceURL(
isolate: *mut RealIsolate,
) -> *const String;
fn v8__StackTrace__GetFrameCount(this: *const StackTrace) -> int;
fn v8__StackTrace__GetFrame(
this: *const StackTrace,
isolate: *mut RealIsolate,
index: u32,
) -> *const StackFrame;
fn v8__StackFrame__GetLineNumber(this: *const StackFrame) -> int;
fn v8__StackFrame__GetColumn(this: *const StackFrame) -> int;
fn v8__StackFrame__GetScriptId(this: *const StackFrame) -> int;
fn v8__StackFrame__GetScriptName(this: *const StackFrame) -> *const String;
fn v8__StackFrame__GetScriptNameOrSourceURL(
this: *const StackFrame,
) -> *const String;
fn v8__StackFrame__GetScriptSource(this: *const StackFrame) -> *const String;
fn v8__StackFrame__GetScriptSourceMappingURL(
this: *const StackFrame,
) -> *const String;
fn v8__StackFrame__GetFunctionName(this: *const StackFrame) -> *const String;
fn v8__StackFrame__IsEval(this: *const StackFrame) -> bool;
fn v8__StackFrame__IsConstructor(this: *const StackFrame) -> bool;
fn v8__StackFrame__IsWasm(this: *const StackFrame) -> bool;
fn v8__StackFrame__IsUserJavaScript(this: *const StackFrame) -> bool;
fn v8__Exception__Error(message: *const String) -> *const Value;
fn v8__Exception__RangeError(message: *const String) -> *const Value;
fn v8__Exception__ReferenceError(message: *const String) -> *const Value;
fn v8__Exception__SyntaxError(message: *const String) -> *const Value;
fn v8__Exception__TypeError(message: *const String) -> *const Value;
fn v8__Exception__CreateMessage(
isolate: *mut RealIsolate,
exception: *const Value,
) -> *const Message;
fn v8__Exception__GetStackTrace(exception: *const Value)
-> *const StackTrace;
fn v8__Exception__CaptureStackTrace(
context: *const Context,
object: *const Object,
) -> MaybeBool;
}
impl StackTrace {
#[inline(always)]
pub fn current_stack_trace<'s>(
scope: &PinScope<'s, '_>,
frame_limit: usize,
) -> Option<Local<'s, StackTrace>> {
let frame_limit = frame_limit.try_into().ok()?;
unsafe {
scope.cast_local(|sd| {
v8__StackTrace__CurrentStackTrace(sd.get_isolate_ptr(), frame_limit)
})
}
}
#[inline(always)]
pub fn current_script_name_or_source_url<'s>(
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, String>> {
unsafe {
scope.cast_local(|sd| {
v8__StackTrace__CurrentScriptNameOrSourceURL(sd.get_isolate_ptr())
})
}
}
#[inline(always)]
pub fn get_frame_count(&self) -> usize {
unsafe { v8__StackTrace__GetFrameCount(self) as usize }
}
#[inline(always)]
pub fn get_frame<'s>(
&self,
scope: &PinScope<'s, '_>,
index: usize,
) -> Option<Local<'s, StackFrame>> {
unsafe {
scope.cast_local(|sd| {
v8__StackTrace__GetFrame(self, sd.get_isolate_ptr(), index as u32)
})
}
}
}
impl StackFrame {
#[inline(always)]
pub fn get_line_number(&self) -> usize {
unsafe { v8__StackFrame__GetLineNumber(self) as usize }
}
#[inline(always)]
pub fn get_column(&self) -> usize {
unsafe { v8__StackFrame__GetColumn(self) as usize }
}
#[inline(always)]
pub fn get_script_id(&self) -> usize {
unsafe { v8__StackFrame__GetScriptId(self) as usize }
}
#[inline(always)]
pub fn get_script_name<'s>(
&self,
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, String>> {
unsafe { scope.cast_local(|_| v8__StackFrame__GetScriptName(self)) }
}
#[inline(always)]
pub fn get_script_name_or_source_url<'s>(
&self,
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, String>> {
unsafe {
scope.cast_local(|_| v8__StackFrame__GetScriptNameOrSourceURL(self))
}
}
#[inline(always)]
pub fn get_script_source<'s>(
&self,
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, String>> {
unsafe { scope.cast_local(|_| v8__StackFrame__GetScriptSource(self)) }
}
#[inline(always)]
pub fn get_script_source_mapping_url<'s>(
&self,
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, String>> {
unsafe {
scope.cast_local(|_| v8__StackFrame__GetScriptSourceMappingURL(self))
}
}
#[inline(always)]
pub fn get_function_name<'s>(
&self,
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, String>> {
unsafe { scope.cast_local(|_| v8__StackFrame__GetFunctionName(self)) }
}
#[inline(always)]
pub fn is_eval(&self) -> bool {
unsafe { v8__StackFrame__IsEval(self) }
}
#[inline(always)]
pub fn is_constructor(&self) -> bool {
unsafe { v8__StackFrame__IsConstructor(self) }
}
#[inline(always)]
pub fn is_wasm(&self) -> bool {
unsafe { v8__StackFrame__IsWasm(self) }
}
#[inline(always)]
pub fn is_user_javascript(&self) -> bool {
unsafe { v8__StackFrame__IsUserJavaScript(self) }
}
}
impl Message {
#[inline(always)]
pub fn get<'s>(&self, scope: &PinScope<'s, '_>) -> Local<'s, String> {
unsafe { scope.cast_local(|_| v8__Message__Get(self)) }.unwrap()
}
#[inline(always)]
pub fn get_stack_trace<'s>(
&self,
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, StackTrace>> {
unsafe { scope.cast_local(|_| v8__Message__GetStackTrace(self)) }
}
#[inline(always)]
pub fn get_source_line<'s>(
&self,
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, String>> {
unsafe {
scope.cast_local(|sd| {
v8__Message__GetSourceLine(self, sd.get_current_context())
})
}
}
#[inline(always)]
pub fn get_script_resource_name<'s>(
&self,
scope: &PinScope<'s, '_>,
) -> Option<Local<'s, Value>> {
unsafe { scope.cast_local(|_| v8__Message__GetScriptResourceName(self)) }
}
#[inline(always)]
pub fn get_line_number(&self, scope: &PinScope<'_, '_>) -> Option<usize> {
let i = unsafe {
v8__Message__GetLineNumber(self, &*scope.get_current_context())
};
if i < 0 { None } else { Some(i as usize) }
}
#[inline(always)]
pub fn get_start_position(&self) -> int {
unsafe { v8__Message__GetStartPosition(self) }
}
#[inline(always)]
pub fn get_end_position(&self) -> int {
unsafe { v8__Message__GetEndPosition(self) }
}
#[inline(always)]
pub fn get_wasm_function_index(&self) -> int {
unsafe { v8__Message__GetWasmFunctionIndex(self) }
}
#[inline(always)]
pub fn error_level(&self) -> int {
unsafe { v8__Message__ErrorLevel(self) }
}
#[inline(always)]
pub fn get_start_column(&self) -> usize {
unsafe { v8__Message__GetStartColumn(self) as usize }
}
#[inline(always)]
pub fn get_end_column(&self) -> usize {
unsafe { v8__Message__GetEndColumn(self) as usize }
}
#[inline(always)]
pub fn is_shared_cross_origin(&self) -> bool {
unsafe { v8__Message__IsSharedCrossOrigin(self) }
}
#[inline(always)]
pub fn is_opaque(&self) -> bool {
unsafe { v8__Message__IsOpaque(self) }
}
}
#[derive(Debug)]
pub struct Exception;
impl Exception {
#[inline(always)]
pub fn error<'s>(
scope: &PinScope<'s, '_>,
message: Local<String>,
) -> Local<'s, Value> {
Self::new_error_with(scope, message, v8__Exception__Error)
}
#[inline(always)]
pub fn range_error<'s>(
scope: &PinScope<'s, '_>,
message: Local<String>,
) -> Local<'s, Value> {
Self::new_error_with(scope, message, v8__Exception__RangeError)
}
#[inline(always)]
pub fn reference_error<'s>(
scope: &PinScope<'s, '_>,
message: Local<String>,
) -> Local<'s, Value> {
Self::new_error_with(scope, message, v8__Exception__ReferenceError)
}
#[inline(always)]
pub fn syntax_error<'s>(
scope: &PinScope<'s, '_>,
message: Local<String>,
) -> Local<'s, Value> {
Self::new_error_with(scope, message, v8__Exception__SyntaxError)
}
#[inline(always)]
pub fn type_error<'s>(
scope: &PinScope<'s, '_>,
message: Local<String>,
) -> Local<'s, Value> {
Self::new_error_with(scope, message, v8__Exception__TypeError)
}
#[inline(always)]
fn new_error_with<'s>(
scope: &PinScope<'s, '_>,
message: Local<String>,
contructor: unsafe extern "C" fn(*const String) -> *const Value,
) -> Local<'s, Value> {
unsafe {
scope.enter();
let error = scope.cast_local(|_| (contructor)(&*message)).unwrap();
scope.exit();
error
}
}
#[inline(always)]
pub fn create_message<'s>(
scope: &PinScope<'s, '_>,
exception: Local<Value>,
) -> Local<'s, Message> {
unsafe {
scope.cast_local(|sd| {
v8__Exception__CreateMessage(sd.get_isolate_ptr(), &*exception)
})
}
.unwrap()
}
#[inline(always)]
pub fn get_stack_trace<'s>(
scope: &PinScope<'s, '_>,
exception: Local<Value>,
) -> Option<Local<'s, StackTrace>> {
unsafe { scope.cast_local(|_| v8__Exception__GetStackTrace(&*exception)) }
}
#[inline(always)]
pub fn capture_stack_trace(
context: Local<Context>,
object: Local<Object>,
) -> Option<bool> {
unsafe { v8__Exception__CaptureStackTrace(&*context, &*object).into() }
}
}