Skip to content

Commit

Permalink
Merge 74e2830 into b1f4e0d
Browse files Browse the repository at this point in the history
  • Loading branch information
HalidOdat authored Apr 16, 2023
2 parents b1f4e0d + 74e2830 commit b07dddb
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 1 deletion.
2 changes: 2 additions & 0 deletions boa_engine/src/object/internal_methods/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ pub(super) mod integer_indexed;
pub(super) mod proxy;
pub(super) mod string;

pub(crate) use array::ARRAY_EXOTIC_INTERNAL_METHODS;

impl JsObject {
/// Internal method `[[GetPrototypeOf]]`
///
Expand Down
9 changes: 9 additions & 0 deletions boa_engine/src/object/property_map.rs
Original file line number Diff line number Diff line change
Expand Up @@ -287,6 +287,15 @@ impl PropertyMap {
}
}

/// Returns the vec of dense indexed properties if they exist.
pub(crate) fn dense_indexed_properties_mut(&mut self) -> Option<&mut ThinVec<JsValue>> {
if let IndexedProperties::Dense(properties) = &mut self.indexed_properties {
Some(properties)
} else {
None
}
}

/// An iterator visiting all key-value pairs in arbitrary order. The iterator element type is `(PropertyKey, &'a Property)`.
///
/// This iterator does not recurse down the prototype chain.
Expand Down
37 changes: 37 additions & 0 deletions boa_engine/src/vm/opcode/get/property.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use crate::{
js_string,
object::internal_methods::ARRAY_EXOTIC_INTERNAL_METHODS,
property::PropertyKey,
vm::{opcode::Operation, CompletionType},
Context, JsResult, JsValue,
Expand Down Expand Up @@ -56,6 +57,23 @@ impl Operation for GetPropertyByValue {
};

let key = key.to_property_key(context)?;

// Fast Path
if std::ptr::eq(object.vtable(), &ARRAY_EXOTIC_INTERNAL_METHODS) {
if let PropertyKey::Index(index) = &key {
let object_borrowed = object.borrow();
if let Some(dense_elements) =
object_borrowed.properties().dense_indexed_properties()
{
let index = *index as usize;
context
.vm
.push(dense_elements.get(index).cloned().unwrap_or_default());
return Ok(CompletionType::Normal);
}
}
}

let result = object.__get__(&key, value, context)?;

context.vm.push(result);
Expand Down Expand Up @@ -110,6 +128,25 @@ impl Operation for GetPropertyByValuePush {
};

let key = key.to_property_key(context)?;

// Fast path:
if std::ptr::eq(object.vtable(), &ARRAY_EXOTIC_INTERNAL_METHODS) {
if let PropertyKey::Index(index) = &key {
let object_borrowed = object.borrow();
if let Some(dense_elements) =
object_borrowed.properties().dense_indexed_properties()
{
let index = *index as usize;
context.vm.push(key);
context
.vm
.push(dense_elements.get(index).cloned().unwrap_or_default());
return Ok(CompletionType::Normal);
}
}
}

// Slow path:
let result = object.__get__(&key, value, context)?;

context.vm.push(key);
Expand Down
20 changes: 19 additions & 1 deletion boa_engine/src/vm/opcode/set/property.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use crate::{
builtins::function::set_function_name,
object::internal_methods::ARRAY_EXOTIC_INTERNAL_METHODS,
property::{PropertyDescriptor, PropertyKey},
vm::{opcode::Operation, CompletionType},
Context, JsNativeError, JsResult, JsString, JsValue,
Expand Down Expand Up @@ -31,7 +32,6 @@ impl Operation for SetPropertyByName {
let name = context.vm.frame().code_block.names[index as usize];
let name: PropertyKey = context.interner().resolve_expect(name.sym()).utf16().into();

//object.set(name, value.clone(), context.vm.frame().code.strict, context)?;
let succeeded = object.__set__(name.clone(), value.clone(), receiver, context)?;
if !succeeded && context.vm.frame().code_block.strict {
return Err(JsNativeError::typ()
Expand Down Expand Up @@ -65,6 +65,24 @@ impl Operation for SetPropertyByValue {
};

let key = key.to_property_key(context)?;

// Fast Path:
if std::ptr::eq(object.vtable(), &ARRAY_EXOTIC_INTERNAL_METHODS) {
if let PropertyKey::Index(index) = &key {
let mut object_borrowed = object.borrow_mut();
if let Some(element) = object_borrowed
.properties_mut()
.dense_indexed_properties_mut()
.and_then(|vec| vec.get_mut(*index as usize))
{
*element = value;
context.vm.push(element.clone());
return Ok(CompletionType::Normal);
}
}
}

// Slow path:
object.set(
key,
value.clone(),
Expand Down

0 comments on commit b07dddb

Please sign in to comment.