pub struct JsMap { /* private fields */ }
Expand description

JsMap provides a wrapper for Boa’s implementation of the ECMAScript Map object.

§Examples

Create a JsMap and set a new entry

// Create default `Context`
let context = &mut Context::default();

// Create a new empty `JsMap`.
let map = JsMap::new(context);

// Set key-value pairs for the `JsMap`.
map.set(js_string!("Key-1"), js_string!("Value-1"), context)?;
map.set(js_string!("Key-2"), 10, context)?;

assert_eq!(map.get_size(context)?, 2.into());

Create a JsMap from a JsArray

// Create a default `Context`
let context = &mut Context::default();

// Create an array of two `[key, value]` pairs
let js_array = JsArray::new(context);

// Create a `[key, value]` pair of JsValues
let vec_one: Vec<JsValue> = vec![
    js_string!("first-key").into(),
    js_string!("first-value").into()
];

// We create an push our `[key, value]` pair onto our array as a `JsArray`
js_array.push(JsArray::from_iter(vec_one, context), context)?;

// Create a `JsMap` from the `JsArray` using it's iterable property.
let js_iterable_map = JsMap::from_js_iterable(&js_array.into(), context)?;

assert_eq!(
    js_iterable_map.get(js_string!("first-key"), context)?,
    js_string!("first-value").into()
);

}

Implementations§

source§

impl JsMap

source

pub fn new(context: &mut Context) -> Self

Creates a new empty JsMap object.

§Example
// Create a new empty `JsMap`.
let map = JsMap::new(context);
source

pub fn from_js_iterable( iterable: &JsValue, context: &mut Context ) -> JsResult<Self>

Create a new JsMap object from a JsObject that has an @@Iterator field.

§Examples
// Create an array of two `[key, value]` pairs
let js_array = JsArray::new(context);

// Create a `[key, value]` pair of JsValues and add it to the `JsArray` as a `JsArray`
let vec_one: Vec<JsValue> = vec![
    js_string!("first-key").into(),
    js_string!("first-value").into()
];
js_array.push(JsArray::from_iter(vec_one, context), context)?;

// Create a `JsMap` from the `JsArray` using it's iterable property.
let js_iterable_map = JsMap::from_js_iterable(&js_array.into(), context)?;
source

pub fn from_object(object: JsObject) -> JsResult<Self>

Creates a JsMap from a valid JsObject, or returns a TypeError if the provided object is not a JsMap

§Examples
§Valid Example - returns a JsMap object
// `some_object` can be any JavaScript `Map` object.
let some_object = JsObject::from_proto_and_data(
    context.intrinsics().constructors().map().prototype(),
    OrderedMap::<JsValue>::new(),
);

// Create `JsMap` object with incoming object.
let js_map = JsMap::from_object(some_object)?;
§Invalid Example - returns a TypeError with the message “object is not a Map”
let some_object = JsArray::new(context);

// `some_object` is an Array object, not a map object
assert!(JsMap::from_object(some_object.into()).is_err());
source

pub fn entries(&self, context: &mut Context) -> JsResult<JsMapIterator>

Returns a new JsMapIterator object that yields the [key, value] pairs within the JsMap in insertion order.

source

pub fn keys(&self, context: &mut Context) -> JsResult<JsMapIterator>

Returns a new JsMapIterator object that yields the key for each element within the JsMap in insertion order.

source

pub fn set<K, V>( &self, key: K, value: V, context: &mut Context ) -> JsResult<JsValue>
where K: Into<JsValue>, V: Into<JsValue>,

Inserts a new entry into the JsMap object

§Example
let js_map = JsMap::new(context);

js_map.set(js_string!("foo"), js_string!("bar"), context)?;
js_map.set(2, 4, context)?;

assert_eq!(
    js_map.get(js_string!("foo"), context)?,
    js_string!("bar").into()
);
assert_eq!(js_map.get(2, context)?, 4.into());
source

pub fn get_size(&self, context: &mut Context) -> JsResult<JsValue>

Gets the size of the JsMap object.

§Example
let js_map = JsMap::new(context);

js_map.set(js_string!("foo"), js_string!("bar"), context)?;

let map_size = js_map.get_size(context)?;

assert_eq!(map_size, 1.into());
source

pub fn delete<T>(&self, key: T, context: &mut Context) -> JsResult<JsValue>
where T: Into<JsValue>,

Removes element from JsMap with a matching key value.

§Example
let js_map = JsMap::new(context);
js_map.set(js_string!("foo"), js_string!("bar"), context)?;
js_map.set(js_string!("hello"), js_string!("world"), context)?;

js_map.delete(js_string!("foo"), context)?;

assert_eq!(js_map.get_size(context)?, 1.into());
assert_eq!(
    js_map.get(js_string!("foo"), context)?,
    JsValue::undefined()
);
source

pub fn get<T>(&self, key: T, context: &mut Context) -> JsResult<JsValue>
where T: Into<JsValue>,

Gets the value associated with the specified key within the JsMap, or undefined if the key does not exist.

§Example
let js_map = JsMap::new(context);
js_map.set(js_string!("foo"), js_string!("bar"), context)?;

let retrieved_value = js_map.get(js_string!("foo"), context)?;

assert_eq!(retrieved_value, js_string!("bar").into());
source

pub fn clear(&self, context: &mut Context) -> JsResult<JsValue>

Removes all entries from the JsMap.

§Example
let js_map = JsMap::new(context);
js_map.set(js_string!("foo"), js_string!("bar"), context)?;
js_map.set(js_string!("hello"), js_string!("world"), context)?;

js_map.clear(context)?;

assert_eq!(js_map.get_size(context)?, 0.into());
source

pub fn has<T>(&self, key: T, context: &mut Context) -> JsResult<JsValue>
where T: Into<JsValue>,

Checks if JsMap has an entry with the provided key value.

§Example
let js_map = JsMap::new(context);
js_map.set(js_string!("foo"), js_string!("bar"), context)?;

let has_key = js_map.has(js_string!("foo"), context)?;

assert_eq!(has_key, true.into());
source

pub fn for_each( &self, callback: JsFunction, this_arg: JsValue, context: &mut Context ) -> JsResult<JsValue>

Executes the provided callback function for each key-value pair within the JsMap.

source

pub fn values(&self, context: &mut Context) -> JsResult<JsMapIterator>

Returns a new JsMapIterator object that yields the value for each element within the JsMap in insertion order.

Methods from Deref<Target = JsObject>§

source

pub fn downcast_ref<T: NativeObject>(&self) -> Option<Ref<'_, T>>

Downcasts a reference to the object, if the object is of type T.

§Panics

Panics if the object is currently mutably borrowed.

source

pub fn downcast_mut<T: NativeObject>( &self ) -> Option<RefMut<'_, ErasedObject, T>>

Downcasts a mutable reference to the object, if the object is type native object type T.

§Panics

Panics if the object is currently borrowed.

source

pub fn is<T: NativeObject>(&self) -> bool

Checks if this object is an instance of a certain NativeObject.

§Panics

Panics if the object is currently mutably borrowed.

source

pub fn is_ordinary(&self) -> bool

Checks if it’s an ordinary object.

§Panics

Panics if the object is currently mutably borrowed.

source

pub fn is_array(&self) -> bool

Checks if it’s an Array object.

source

pub fn to_property_descriptor( &self, context: &mut Context ) -> JsResult<PropertyDescriptor>

The abstract operation ToPropertyDescriptor.

More information:

source

pub fn copy_data_properties<K>( &self, source: &JsValue, excluded_keys: Vec<K>, context: &mut Context ) -> JsResult<()>
where K: Into<PropertyKey>,

7.3.25 CopyDataProperties ( target, source, excludedItems )

More information:

source

pub fn borrow(&self) -> Ref<'_, Object<T>>

Immutably borrows the Object.

The borrow lasts until the returned Ref exits scope. Multiple immutable borrows can be taken out at the same time.

§Panics

Panics if the object is currently mutably borrowed.

source

pub fn borrow_mut(&self) -> RefMut<'_, Object<T>, Object<T>>

Mutably borrows the Object.

The borrow lasts until the returned RefMut exits scope. The object cannot be borrowed while this borrow is active.

§Panics

Panics if the object is currently borrowed.

source

pub fn try_borrow(&self) -> StdResult<Ref<'_, Object<T>>, BorrowError>

Immutably borrows the Object, returning an error if the value is currently mutably borrowed.

The borrow lasts until the returned GcCellRef exits scope. Multiple immutable borrows can be taken out at the same time.

This is the non-panicking variant of borrow.

source

pub fn try_borrow_mut( &self ) -> StdResult<RefMut<'_, Object<T>, Object<T>>, BorrowMutError>

Mutably borrows the object, returning an error if the value is currently borrowed.

The borrow lasts until the returned GcCellRefMut exits scope. The object be borrowed while this borrow is active.

This is the non-panicking variant of borrow_mut.

source

pub fn prototype(&self) -> JsPrototype

Get the prototype of the object.

§Panics

Panics if the object is currently mutably borrowed.

source

pub fn set_prototype(&self, prototype: JsPrototype) -> bool

Set the prototype of the object.

§Panics

Panics if the object is currently mutably borrowed

source

pub fn insert_property<K, P>(&self, key: K, property: P) -> bool

Inserts a field in the object properties without checking if it’s writable.

If a field was already in the object with the same name, than true is returned with that field, otherwise false is returned.

source

pub fn is_callable(&self) -> bool

It determines if Object is a callable function with a [[Call]] internal method.

More information:

source

pub fn is_constructor(&self) -> bool

It determines if Object is a function object with a [[Construct]] internal method.

More information:

source

pub fn is_extensible(&self, context: &mut Context) -> JsResult<bool>

Check if object is extensible.

More information:

source

pub fn get<K>(&self, key: K, context: &mut Context) -> JsResult<JsValue>
where K: Into<PropertyKey>,

Get property from object or throw.

More information:

source

pub fn set<K, V>( &self, key: K, value: V, throw: bool, context: &mut Context ) -> JsResult<bool>
where K: Into<PropertyKey>, V: Into<JsValue>,

set property of object or throw if bool flag is passed.

More information:

source

pub fn create_data_property<K, V>( &self, key: K, value: V, context: &mut Context ) -> JsResult<bool>
where K: Into<PropertyKey>, V: Into<JsValue>,

Create data property

More information:

source

pub fn create_data_property_or_throw<K, V>( &self, key: K, value: V, context: &mut Context ) -> JsResult<bool>
where K: Into<PropertyKey>, V: Into<JsValue>,

Create data property or throw

More information:

source

pub fn define_property_or_throw<K, P>( &self, key: K, desc: P, context: &mut Context ) -> JsResult<bool>

Define property or throw.

More information:

source

pub fn delete_property_or_throw<K>( &self, key: K, context: &mut Context ) -> JsResult<bool>
where K: Into<PropertyKey>,

Defines the property or throws a TypeError if the operation fails.

More information:

source

pub fn has_property<K>(&self, key: K, context: &mut Context) -> JsResult<bool>
where K: Into<PropertyKey>,

Check if object has property.

More information:

source

pub fn has_own_property<K>( &self, key: K, context: &mut Context ) -> JsResult<bool>
where K: Into<PropertyKey>,

Check if object has an own property.

More information:

source

pub fn call( &self, this: &JsValue, args: &[JsValue], context: &mut Context ) -> JsResult<JsValue>

Call ( F, V [ , argumentsList ] )

§Panics

Panics if the object is currently mutably borrowed.

More information:

source

pub fn construct( &self, args: &[JsValue], new_target: Option<&Self>, context: &mut Context ) -> JsResult<Self>

Construct ( F [ , argumentsList [ , newTarget ] ] )

Construct an instance of this object with the specified arguments.

§Panics

Panics if the object is currently mutably borrowed.

More information:

source

pub fn set_integrity_level( &self, level: IntegrityLevel, context: &mut Context ) -> JsResult<bool>

Make the object sealed or frozen.

More information:

source

pub fn test_integrity_level( &self, level: IntegrityLevel, context: &mut Context ) -> JsResult<bool>

Check if the object is sealed or frozen.

More information:

Trait Implementations§

source§

impl Clone for JsMap

source§

fn clone(&self) -> JsMap

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for JsMap

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Deref for JsMap

§

type Target = JsObject

The resulting type after dereferencing.
source§

fn deref(&self) -> &Self::Target

Dereferences the value.
source§

impl Drop for JsMap

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl Finalize for JsMap

source§

fn finalize(&self)

Cleanup logic for a type.
source§

impl From<JsMap> for JsObject

source§

fn from(o: JsMap) -> Self

Converts to this type from the input type.
source§

impl From<JsMap> for JsValue

source§

fn from(o: JsMap) -> Self

Converts to this type from the input type.
source§

impl Trace for JsMap

source§

unsafe fn trace(&self, tracer: &mut Tracer)

Marks all contained Gcs. Read more
source§

unsafe fn trace_non_roots(&self)

Trace handles located in GC heap, and mark them as non root. Read more
source§

fn run_finalizer(&self)

Runs Finalize::finalize on this object and all contained subobjects.
source§

impl TryFromJs for JsMap

source§

fn try_from_js(value: &JsValue, _context: &mut Context) -> JsResult<Self>

This function tries to convert a JavaScript value into Self.

Auto Trait Implementations§

§

impl !RefUnwindSafe for JsMap

§

impl !Send for JsMap

§

impl !Sync for JsMap

§

impl Unpin for JsMap

§

impl !UnwindSafe for JsMap

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> Conv for T

source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Pipe for T
where T: ?Sized,

source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
source§

impl<T> Tap for T

source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> TryConv for T

source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> ErasedDestructor for T
where T: 'static,

source§

impl<T> MaybeSendSync for T