Skip to content

JsSerialize

Alex Godoy Wolff edited this page Nov 16, 2016 · 3 revisions

Serializes a parsed script to a buffer than can be reused.

Syntax

CHAKRA_API
       JsSerialize(
        _In_ JsValueRef script,
        _Out_ BYTE *buffer,
        _Inout_ unsigned int *bufferSize,
        _In_ JsParseScriptAttributes parseAttributes);

Parameters

  • script: The script to serialize.
  • buffer: The buffer to put the serialized script into. Can be null.
  • bufferSize: On entry, the size of the buffer, in bytes; on exit, the size of the buffer, in bytes, required to hold the serialized script.
  • parseAttributes: Encoding for the script

Return Value

The code JsNoError if the operation succeeded, a failure code otherwise.

Remarks

JsSerializeScript parses a script and then stores the parsed form of the script in a runtime-independent format. The serialized script then can be deserialized in any runtime without requiring the script to be re-parsed.

Script source can be either JavascriptString or JavascriptExternalArrayBuffer. In case it is an ExternalArrayBuffer, and the encoding of the buffer is Utf16, JsParseScriptAttributeArrayBufferIsUtf16Encoded is expected on parseAttributes.

Requires an active script context.

Use JavascriptExternalArrayBuffer with Utf8/ASCII script source for better performance and smaller memory footprint.

Clone this wiki locally