mirror of
https://github.com/denoland/rusty_v8.git
synced 2025-01-11 16:42:32 -05:00
Add Value::{ToString, ToNumber, ToObject} (#162)
This commit is contained in:
parent
8f9aafe764
commit
e501f6d854
4 changed files with 57 additions and 12 deletions
|
@ -306,6 +306,18 @@ bool v8__Value__SameValue(const v8::Value& self, v8::Value* that) {
|
||||||
return self.SameValue(ptr_to_local(that));
|
return self.SameValue(ptr_to_local(that));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
v8::String* v8__Value__ToString(const v8::Value& self, v8::Context* context) {
|
||||||
|
return maybe_local_to_ptr(self.ToString(ptr_to_local(context)));
|
||||||
|
}
|
||||||
|
|
||||||
|
v8::Number* v8__Value__ToNumber(const v8::Value& self, v8::Context* context) {
|
||||||
|
return maybe_local_to_ptr(self.ToNumber(ptr_to_local(context)));
|
||||||
|
}
|
||||||
|
|
||||||
|
v8::Object* v8__Value__ToObject(const v8::Value& self, v8::Context* context) {
|
||||||
|
return maybe_local_to_ptr(self.ToObject(ptr_to_local(context)));
|
||||||
|
}
|
||||||
|
|
||||||
v8::Primitive* v8__Null(v8::Isolate* isolate) {
|
v8::Primitive* v8__Null(v8::Isolate* isolate) {
|
||||||
return local_to_ptr(v8::Null(isolate));
|
return local_to_ptr(v8::Null(isolate));
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
//! code.to_rust_string_lossy(scope);
|
//! code.to_rust_string_lossy(scope);
|
||||||
//! let mut script = v8::Script::compile(scope, context, code, None).unwrap();
|
//! let mut script = v8::Script::compile(scope, context, code, None).unwrap();
|
||||||
//! let result = script.run(scope, context).unwrap();
|
//! let result = script.run(scope, context).unwrap();
|
||||||
//! let result = unsafe { v8::Local::<v8::String>::cast(result) };
|
//! let result = result.to_string(scope).unwrap();
|
||||||
//! let str = result.to_rust_string_lossy(scope);
|
//! let str = result.to_rust_string_lossy(scope);
|
||||||
//! println!("{}", str);
|
//! println!("{}", str);
|
||||||
//!
|
//!
|
||||||
|
|
35
src/value.rs
35
src/value.rs
|
@ -1,4 +1,9 @@
|
||||||
|
use crate::Context;
|
||||||
use crate::Local;
|
use crate::Local;
|
||||||
|
use crate::Number;
|
||||||
|
use crate::Object;
|
||||||
|
use crate::String;
|
||||||
|
use crate::ToLocal;
|
||||||
use crate::Value;
|
use crate::Value;
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
@ -12,6 +17,9 @@ extern "C" {
|
||||||
fn v8__Value__IsObject(this: &Value) -> bool;
|
fn v8__Value__IsObject(this: &Value) -> bool;
|
||||||
fn v8__Value__StrictEquals(this: &Value, that: &Value) -> bool;
|
fn v8__Value__StrictEquals(this: &Value, that: &Value) -> bool;
|
||||||
fn v8__Value__SameValue(this: &Value, that: &Value) -> bool;
|
fn v8__Value__SameValue(this: &Value, that: &Value) -> bool;
|
||||||
|
fn v8__Value__ToString(this: &Value, context: *mut Context) -> *mut String;
|
||||||
|
fn v8__Value__ToNumber(this: &Value, context: *mut Context) -> *mut Number;
|
||||||
|
fn v8__Value__ToObject(this: &Value, context: *mut Context) -> *mut Object;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Value {
|
impl Value {
|
||||||
|
@ -65,4 +73,31 @@ impl Value {
|
||||||
pub fn same_value<'sc>(&self, that: Local<'sc, Value>) -> bool {
|
pub fn same_value<'sc>(&self, that: Local<'sc, Value>) -> bool {
|
||||||
unsafe { v8__Value__SameValue(self, &that) }
|
unsafe { v8__Value__SameValue(self, &that) }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn to_string<'sc>(
|
||||||
|
&self,
|
||||||
|
scope: &mut impl ToLocal<'sc>,
|
||||||
|
) -> Option<Local<'sc, String>> {
|
||||||
|
let isolate = scope.isolate();
|
||||||
|
let mut context = isolate.get_current_context();
|
||||||
|
unsafe { Local::from_raw(v8__Value__ToString(self, &mut *context)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn to_number<'sc>(
|
||||||
|
&self,
|
||||||
|
scope: &mut impl ToLocal<'sc>,
|
||||||
|
) -> Option<Local<'sc, Number>> {
|
||||||
|
let isolate = scope.isolate();
|
||||||
|
let mut context = isolate.get_current_context();
|
||||||
|
unsafe { Local::from_raw(v8__Value__ToNumber(self, &mut *context)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn to_object<'sc>(
|
||||||
|
&self,
|
||||||
|
scope: &mut impl ToLocal<'sc>,
|
||||||
|
) -> Option<Local<'sc, Object>> {
|
||||||
|
let isolate = scope.isolate();
|
||||||
|
let mut context = isolate.get_current_context();
|
||||||
|
unsafe { Local::from_raw(v8__Value__ToObject(self, &mut *context)) }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -548,7 +548,7 @@ fn set_host_initialize_import_meta_object_callback() {
|
||||||
assert!(result.is_some());
|
assert!(result.is_some());
|
||||||
let meta = module.evaluate(s, context).unwrap();
|
let meta = module.evaluate(s, context).unwrap();
|
||||||
assert!(meta.is_object());
|
assert!(meta.is_object());
|
||||||
let meta = unsafe { Local::<v8::Object>::cast(meta) };
|
let meta = meta.to_object(s).unwrap();
|
||||||
let key = v8::String::new(s, "foo").unwrap();
|
let key = v8::String::new(s, "foo").unwrap();
|
||||||
let expected = v8::String::new(s, "bar").unwrap();
|
let expected = v8::String::new(s, "bar").unwrap();
|
||||||
let actual = meta.get(s, context, key.into()).unwrap();
|
let actual = meta.get(s, context, key.into()).unwrap();
|
||||||
|
@ -577,9 +577,7 @@ fn script_compile_and_run() {
|
||||||
let mut script = v8::Script::compile(s, context, source, None).unwrap();
|
let mut script = v8::Script::compile(s, context, source, None).unwrap();
|
||||||
source.to_rust_string_lossy(s);
|
source.to_rust_string_lossy(s);
|
||||||
let result = script.run(s, context).unwrap();
|
let result = script.run(s, context).unwrap();
|
||||||
// TODO: safer casts.
|
let result = result.to_string(s).unwrap();
|
||||||
let result: v8::Local<v8::String> =
|
|
||||||
unsafe { std::mem::transmute_copy(&result) };
|
|
||||||
assert_eq!(result.to_rust_string_lossy(s), "Hello 13th planet");
|
assert_eq!(result.to_rust_string_lossy(s), "Hello 13th planet");
|
||||||
context.exit();
|
context.exit();
|
||||||
}
|
}
|
||||||
|
@ -824,7 +822,7 @@ fn create_data_property() {
|
||||||
.get(scope, context, key.into())
|
.get(scope, context, key.into())
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(obj.is_object());
|
assert!(obj.is_object());
|
||||||
let obj = unsafe { Local::<v8::Object>::cast(obj) };
|
let obj = obj.to_object(scope).unwrap();
|
||||||
let key = v8_str(scope, "foo");
|
let key = v8_str(scope, "foo");
|
||||||
let value = v8_str(scope, "bar");
|
let value = v8_str(scope, "bar");
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
|
@ -869,14 +867,14 @@ fn promise_resolved() {
|
||||||
resolver.resolve(context, value.into());
|
resolver.resolve(context, value.into());
|
||||||
assert_eq!(promise.state(), v8::PromiseState::Fulfilled);
|
assert_eq!(promise.state(), v8::PromiseState::Fulfilled);
|
||||||
let result = promise.result(scope);
|
let result = promise.result(scope);
|
||||||
let result_str = unsafe { Local::<v8::String>::cast(result) };
|
let result_str = result.to_string(scope).unwrap();
|
||||||
assert_eq!(result_str.to_rust_string_lossy(scope), "test".to_string());
|
assert_eq!(result_str.to_rust_string_lossy(scope), "test".to_string());
|
||||||
// Resolve again with different value, since promise is already in `Fulfilled` state
|
// Resolve again with different value, since promise is already in `Fulfilled` state
|
||||||
// it should be ignored.
|
// it should be ignored.
|
||||||
let value = v8::String::new(scope, "test2").unwrap();
|
let value = v8::String::new(scope, "test2").unwrap();
|
||||||
resolver.resolve(context, value.into());
|
resolver.resolve(context, value.into());
|
||||||
let result = promise.result(scope);
|
let result = promise.result(scope);
|
||||||
let result_str = unsafe { Local::<v8::String>::cast(result) };
|
let result_str = result.to_string(scope).unwrap();
|
||||||
assert_eq!(result_str.to_rust_string_lossy(scope), "test".to_string());
|
assert_eq!(result_str.to_rust_string_lossy(scope), "test".to_string());
|
||||||
context.exit();
|
context.exit();
|
||||||
}
|
}
|
||||||
|
@ -906,14 +904,14 @@ fn promise_rejected() {
|
||||||
assert!(rejected.unwrap());
|
assert!(rejected.unwrap());
|
||||||
assert_eq!(promise.state(), v8::PromiseState::Rejected);
|
assert_eq!(promise.state(), v8::PromiseState::Rejected);
|
||||||
let result = promise.result(scope);
|
let result = promise.result(scope);
|
||||||
let result_str = unsafe { Local::<v8::String>::cast(result) };
|
let result_str = result.to_string(scope).unwrap();
|
||||||
assert_eq!(result_str.to_rust_string_lossy(scope), "test".to_string());
|
assert_eq!(result_str.to_rust_string_lossy(scope), "test".to_string());
|
||||||
// Reject again with different value, since promise is already in `Rejected` state
|
// Reject again with different value, since promise is already in `Rejected` state
|
||||||
// it should be ignored.
|
// it should be ignored.
|
||||||
let value = v8::String::new(scope, "test2").unwrap();
|
let value = v8::String::new(scope, "test2").unwrap();
|
||||||
resolver.reject(context, value.into());
|
resolver.reject(context, value.into());
|
||||||
let result = promise.result(scope);
|
let result = promise.result(scope);
|
||||||
let result_str = unsafe { Local::<v8::String>::cast(result) };
|
let result_str = result.to_string(scope).unwrap();
|
||||||
assert_eq!(result_str.to_rust_string_lossy(scope), "test".to_string());
|
assert_eq!(result_str.to_rust_string_lossy(scope), "test".to_string());
|
||||||
context.exit();
|
context.exit();
|
||||||
}
|
}
|
||||||
|
@ -1008,7 +1006,7 @@ fn function() {
|
||||||
vec![arg1.into(), arg2.into()],
|
vec![arg1.into(), arg2.into()],
|
||||||
);
|
);
|
||||||
let value = maybe_value.unwrap();
|
let value = maybe_value.unwrap();
|
||||||
let value_str = unsafe { Local::<v8::String>::cast(value) };
|
let value_str = value.to_string(scope).unwrap();
|
||||||
let rust_str = value_str.to_rust_string_lossy(scope);
|
let rust_str = value_str.to_rust_string_lossy(scope);
|
||||||
assert_eq!(rust_str, "Hello callback!".to_string());
|
assert_eq!(rust_str, "Hello callback!".to_string());
|
||||||
context.exit();
|
context.exit();
|
||||||
|
@ -1028,7 +1026,7 @@ extern "C" fn promise_reject_callback(msg: v8::PromiseRejectMessage) {
|
||||||
{
|
{
|
||||||
let mut hs = v8::HandleScope::new(&mut locker);
|
let mut hs = v8::HandleScope::new(&mut locker);
|
||||||
let scope = hs.enter();
|
let scope = hs.enter();
|
||||||
let value_str = unsafe { Local::<v8::String>::cast(value) };
|
let value_str = value.to_string(scope).unwrap();
|
||||||
let rust_str = value_str.to_rust_string_lossy(scope);
|
let rust_str = value_str.to_rust_string_lossy(scope);
|
||||||
assert_eq!(rust_str, "promise rejected".to_string());
|
assert_eq!(rust_str, "promise rejected".to_string());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue