Skip to content

Add ArrayBuffer::detached method#55944

Open
tsaichien wants to merge 4 commits intomainfrom
export-D92993088
Open

Add ArrayBuffer::detached method#55944
tsaichien wants to merge 4 commits intomainfrom
export-D92993088

Conversation

@tsaichien
Copy link
Contributor

Summary:
Add a ArrayBuffer::detached method that returns true if the
ArrayBuffer is detached, false otherwise.

Default implementation just checks for the detached property

Differential Revision: D92993088

Summary:

After reviewing the feasibility of adding new Runtime functionality, we
realized the current state of `Runtime` makes it hard/inconvenient to
add new basic functionality. It requires creating a new interface (e.g.
`IRuntime2`) to declare the new APIs. Then, everywhere it is needed,
both the original `Runtime` and `IRuntime2` needs to passed in to access
both APIs.

After discussion, we decided to introduce `IRuntime`, which will declare
most of the `Runtime` functionalities. All "protected" APIs, which made
sense before interfaces were introduced, will now be public. The
protected static methods of `Runtime` will remain as is for the Friends
to access.

After we decided to cut "stable" (after incoming JSI improvements), new
functionalities will be added in `IRuntime2` interface. `IRuntime2` will
inherit `IRuntime` to make existing functionality easy to access.

Reviewed By: lavenzg

Differential Revision: D89093651
Summary:

Currently, the size of a jsi `Array` is immutable. Once the `Array` is
created, users can only set the element at an existing index, but not
append to it.

This change adds an `Array::push` API to improve ergonomics.
The default implementation is also provided in `jsi::Runtime`

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D82254334
Summary:
Adds `ArrayBuffer::tryGetMutableBuffer` to JSI. This allows the user to
retrieve a `MutableBuffer` from the `ArrayBuffer`. The returned buffer 
will point directly into the same buffer as the runtime object, rather than
copying it out.

The data referencedby the `MutableBuffer` will be alive during the entirety
 of the `MutableBuffer` lifespan.

Addresses: facebook/hermes#1578

Reviewed By: tmikov

Differential Revision: D91264901
Summary:
Add a `ArrayBuffer::detached` method that returns true if the
ArrayBuffer is detached, false otherwise.

Default implementation just checks for the `detached` property

Differential Revision: D92993088
@meta-cla meta-cla bot added the CLA Signed This label is managed by the Facebook bot. Authors need to sign the CLA before a PR can be reviewed. label Mar 5, 2026
@meta-codesync
Copy link

meta-codesync bot commented Mar 5, 2026

@tsaichien has exported this pull request. If you are a Meta employee, you can view the originating Diff in D92993088.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

CLA Signed This label is managed by the Facebook bot. Authors need to sign the CLA before a PR can be reviewed. fb-exported meta-exported p: Facebook Partner: Facebook Partner

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants