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

Add Object::create_data_property, Object::get, Value::is_array, Value::is_object, Value::is_function (#129)

This commit is contained in:
Ry Dahl 2019-12-24 16:10:40 -05:00 committed by GitHub
parent b00ef1ea3c
commit d65c604f3a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 119 additions and 1 deletions

View file

@ -216,6 +216,12 @@ bool v8__Value__IsString(const v8::Value& self) { return self.IsString(); }
bool v8__Value__IsNumber(const v8::Value& self) { return self.IsNumber(); }
bool v8__Value__IsObject(const v8::Value& self) { return self.IsObject(); }
bool v8__Value__IsArray(const v8::Value& self) { return self.IsArray(); }
bool v8__Value__IsFunction(const v8::Value& self) { return self.IsFunction(); }
bool v8__Value__StrictEquals(const v8::Value& self, v8::Value* that) {
return self.StrictEquals(ptr_to_local(that));
}
@ -301,6 +307,18 @@ v8::Object* v8__Object__New(v8::Isolate* isolate,
v8::Object::New(isolate, prototype_or_null, names, values, length));
}
v8::Value* v8__Object__Get(v8::Object& self, v8::Local<v8::Context> context,
v8::Local<v8::Value> key) {
return maybe_local_to_ptr(self.Get(context, key));
}
MaybeBool v8__Object__CreateDataProperty(v8::Object& self,
v8::Local<v8::Context> context,
v8::Local<v8::Name> key,
v8::Local<v8::Value> value) {
return maybe_to_maybe_bool(self.CreateDataProperty(context, key, value));
}
v8::Isolate* v8__Object__GetIsolate(v8::Object& self) {
return self.GetIsolate();
}

View file

@ -72,5 +72,7 @@ pub use script_or_module::ScriptOrModule;
pub use snapshot::{FunctionCodeHandling, SnapshotCreator, StartupData};
pub use string::NewStringType;
pub use string::String;
pub use support::MaybeBool;
pub use support::UniqueRef;
pub use try_catch::{TryCatch, TryCatchScope};
pub use value::Value;

View file

@ -1,7 +1,9 @@
use std::ops::Deref;
use crate::isolate::Isolate;
use crate::support::MaybeBool;
use crate::support::Opaque;
use crate::Context;
use crate::HandleScope;
use crate::Local;
use crate::Name;
@ -20,6 +22,19 @@ extern "C" {
length: usize,
) -> *mut Object;
fn v8__Object__GetIsolate(object: &Object) -> &mut Isolate;
fn v8__Object__Get(
object: &Object,
context: *const Context,
key: *const Value,
) -> *mut Value;
fn v8__Object__CreateDataProperty(
object: &Object,
context: *const Context,
key: *const Name,
value: *const Value,
) -> MaybeBool;
}
impl Object {
@ -59,6 +74,37 @@ impl Object {
}
}
/// Implements CreateDataProperty (ECMA-262, 7.3.4).
///
/// Defines a configurable, writable, enumerable property with the given value
/// on the object unless the property already exists and is not configurable
/// or the object is not extensible.
///
/// Returns true on success.
pub fn create_data_property(
&self,
context: Local<Context>,
key: Local<Name>,
value: Local<Value>,
) -> MaybeBool {
unsafe { v8__Object__CreateDataProperty(self, &*context, &*key, &*value) }
}
pub fn get<'a>(
&self,
context: Local<Context>,
key: Local<Value>,
) -> Option<Local<'a, Value>> {
unsafe {
let ptr = v8__Object__Get(self, &*context, &*key);
if ptr.is_null() {
None
} else {
Some(Local::from_raw(ptr).unwrap())
}
}
}
/// Return the isolate to which the Object belongs to.
pub fn get_isolate(&self) -> &Isolate {
unsafe { v8__Object__GetIsolate(self) }

View file

@ -138,7 +138,7 @@ where
}
#[repr(C)]
#[derive(Debug)]
#[derive(Debug, PartialEq)]
pub enum MaybeBool {
JustFalse = 0,
JustTrue = 1,

View file

@ -7,6 +7,9 @@ extern "C" {
fn v8__Value__IsNullOrUndefined(this: &Value) -> bool;
fn v8__Value__IsString(this: &Value) -> bool;
fn v8__Value__IsNumber(this: &Value) -> bool;
fn v8__Value__IsArray(this: &Value) -> bool;
fn v8__Value__IsFunction(this: &Value) -> bool;
fn v8__Value__IsObject(this: &Value) -> bool;
fn v8__Value__StrictEquals(this: &Value, that: &Value) -> bool;
fn v8__Value__SameValue(this: &Value, that: &Value) -> bool;
}
@ -38,6 +41,22 @@ impl Value {
unsafe { v8__Value__IsString(self) }
}
/// Returns true if this value is an array. Note that it will return false for
/// an Proxy for an array.
pub fn is_array(&self) -> bool {
unsafe { v8__Value__IsArray(self) }
}
/// Returns true if this value is a function.
pub fn is_function(&self) -> bool {
unsafe { v8__Value__IsFunction(self) }
}
/// Returns true if this value is an object.
pub fn is_object(&self) -> bool {
unsafe { v8__Value__IsObject(self) }
}
/// Returns true if this value is a number.
pub fn is_number(&self) -> bool {
unsafe { v8__Value__IsNumber(self) }

View file

@ -577,6 +577,39 @@ fn object() {
drop(locker);
}
#[test]
fn create_data_property() {
setup();
let mut params = v8::Isolate::create_params();
params.set_array_buffer_allocator(v8::Allocator::new_default_allocator());
let isolate = v8::Isolate::new(params);
let mut locker = v8::Locker::new(&isolate);
v8::HandleScope::enter(&mut locker, |scope| {
let mut context = v8::Context::new(scope);
context.enter();
eval(scope, context, "var a = {};");
let obj = context
.global()
.get(context, v8_str(scope, "a").into())
.unwrap();
assert!(obj.is_object());
let obj: Local<v8::Object> = cast(obj);
let key = v8_str(scope, "foo");
let value = v8_str(scope, "bar");
assert_eq!(
obj.create_data_property(context, cast(key), cast(value)),
v8::MaybeBool::JustTrue
);
let actual = obj.get(context, cast(key)).unwrap();
assert!(value.strict_equals(actual));
context.exit();
});
drop(locker);
}
#[test]
fn promise_resolved() {
setup();