Skip to content

Add ArrayBuffer::detached method (#55944)#55944

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

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

Conversation

@tsaichien
Copy link
Copy Markdown
Contributor

@tsaichien tsaichien commented Mar 5, 2026

Summary:

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

Default implementation just checks for the detached property

Changelog: [Internal]

Reviewed By: lavenzg

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
Copy Markdown

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.

@tsaichien tsaichien closed this Apr 14, 2026
@tsaichien tsaichien reopened this Apr 14, 2026
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.

Changelog: [Internal]

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

Changelog: [Internal]

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

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088
@meta-codesync meta-codesync bot changed the title Add ArrayBuffer::detached method Add ArrayBuffer::detached method (#55944) Apr 15, 2026
meta-codesync bot pushed a commit to facebook/hermes that referenced this pull request Apr 15, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
meta-codesync bot pushed a commit to facebook/hermes that referenced this pull request Apr 15, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
@meta-codesync meta-codesync bot closed this in 89e0df1 Apr 15, 2026
meta-codesync bot pushed a commit to facebook/hermes that referenced this pull request Apr 15, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
@facebook-github-tools facebook-github-tools bot added the Merged This PR has been merged. label Apr 15, 2026
@meta-codesync
Copy link
Copy Markdown

meta-codesync bot commented Apr 15, 2026

This pull request has been merged in 89e0df1.

tsaichien added a commit to tsaichien/hermes that referenced this pull request Apr 15, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
tsaichien added a commit to tsaichien/hermes that referenced this pull request Apr 15, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
tsaichien added a commit to tsaichien/hermes that referenced this pull request Apr 15, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
tsaichien added a commit to tsaichien/hermes that referenced this pull request Apr 15, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
tsaichien added a commit to tsaichien/hermes that referenced this pull request Apr 16, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
tsaichien added a commit to tsaichien/hermes that referenced this pull request Apr 16, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
tsaichien added a commit to facebook/hermes that referenced this pull request Apr 16, 2026
Summary:
X-link: facebook/react-native#55944

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

Default implementation just checks for the `detached` property

Changelog: [Internal]

Reviewed By: lavenzg

Differential Revision: D92993088

fbshipit-source-id: 77d7055ddc35c21e915915daa2415b44017f81bb
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 Merged This PR has been merged. meta-exported p: Facebook Partner: Facebook Partner

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants