v8 12.4.254 (node 22.4.1)
V8 is Google's open source JavaScript engine
Loading...
Searching...
No Matches
SnapshotCreator Class Reference

#include <v8-snapshot.h>

Public Types

enum class  FunctionCodeHandling { kClear , kKeep }
 

Public Member Functions

 SnapshotCreator (Isolate *isolate, const intptr_t *external_references=nullptr, const StartupData *existing_blob=nullptr, bool owns_isolate=true)
 
 SnapshotCreator (const intptr_t *external_references=nullptr, const StartupData *existing_blob=nullptr)
 
 SnapshotCreator (const v8::Isolate::CreateParams &params)
 
 SnapshotCreator (v8::Isolate *isolate, const v8::Isolate::CreateParams &params)
 
 ~SnapshotCreator ()
 
IsolateGetIsolate ()
 
void SetDefaultContext (Local< Context > context, SerializeInternalFieldsCallback internal_fields_serializer=SerializeInternalFieldsCallback(), SerializeContextDataCallback context_data_serializer=SerializeContextDataCallback())
 
size_t AddContext (Local< Context > context, SerializeInternalFieldsCallback internal_fields_serializer=SerializeInternalFieldsCallback(), SerializeContextDataCallback context_data_serializer=SerializeContextDataCallback())
 
template<class T >
V8_INLINE size_t AddData (Local< Context > context, Local< T > object)
 
template<class T >
V8_INLINE size_t AddData (Local< T > object)
 
StartupData CreateBlob (FunctionCodeHandling function_code_handling)
 
 SnapshotCreator (const SnapshotCreator &)=delete
 
void operator= (const SnapshotCreator &)=delete
 
template<class T >
size_t AddData (Local< Context > context, Local< T > object)
 
template<class T >
size_t AddData (Local< T > object)
 

Friends

class internal::SnapshotCreatorImpl
 

Detailed Description

Helper class to create a snapshot data blob.

The Isolate used by a SnapshotCreator is owned by it, and will be entered and exited by the constructor and destructor, respectively; The destructor will also destroy the Isolate. Experimental language features, including those available by default, are not available while creating a snapshot.

Definition at line 108 of file v8-snapshot.h.

Member Enumeration Documentation

◆ FunctionCodeHandling

enum class FunctionCodeHandling
strong
Enumerator
kClear 
kKeep 

Definition at line 110 of file v8-snapshot.h.

Constructor & Destructor Documentation

◆ SnapshotCreator() [1/5]

SnapshotCreator ( Isolate isolate,
const intptr_t *  external_references = nullptr,
const StartupData existing_blob = nullptr,
bool  owns_isolate = true 
)
explicit

Initialize and enter an isolate, and set it up for serialization. The isolate is either created from scratch or from an existing snapshot. The caller keeps ownership of the argument snapshot.

Parameters
existing_blobexisting snapshot from which to create this one.
external_referencesa null-terminated array of external references that must be equivalent to CreateParams::external_references.
owns_isolatewhether this SnapshotCreator should call v8::Isolate::Dispose() during its destructor.

◆ SnapshotCreator() [2/5]

SnapshotCreator ( const intptr_t *  external_references = nullptr,
const StartupData existing_blob = nullptr 
)
explicit

Create and enter an isolate, and set it up for serialization. The isolate is either created from scratch or from an existing snapshot. The caller keeps ownership of the argument snapshot.

Parameters
existing_blobexisting snapshot from which to create this one.
external_referencesa null-terminated array of external references that must be equivalent to CreateParams::external_references.

◆ SnapshotCreator() [3/5]

SnapshotCreator ( const v8::Isolate::CreateParams params)
explicit

Creates an Isolate for serialization and enters it. The creator fully owns the Isolate and will invoke v8::Isolate::Dispose() during destruction.

Parameters
paramsThe parameters to initialize the Isolate for. Details:
  • params.external_references are expected to be a null-terminated array of external references.
  • params.existing_blob is an optional snapshot blob from which can be used to initialize the new blob.

◆ SnapshotCreator() [4/5]

SnapshotCreator ( v8::Isolate isolate,
const v8::Isolate::CreateParams params 
)

Initializes an Isolate for serialization and enters it. The creator does not own the Isolate but merely initialize it properly.

Parameters
isolateThe isolate that was allocated by Isolate::Allocate()~. \param params The parameters to initialize the Isolate for. Details: -params.external_referencesare expected to be a null-terminated array of external references. -params.existing_blob` is an optional snapshot blob from which can be used to initialize the new blob.

◆ ~SnapshotCreator()

Destroy the snapshot creator, and exit and dispose of the Isolate associated with it.

◆ SnapshotCreator() [5/5]

SnapshotCreator ( const SnapshotCreator )
delete

Member Function Documentation

◆ AddContext()

size_t AddContext ( Local< Context context,
SerializeInternalFieldsCallback  internal_fields_serializer = SerializeInternalFieldsCallback(),
SerializeContextDataCallback  context_data_serializer = SerializeContextDataCallback() 
)

Add additional context to be included in the snapshot blob. The snapshot will include the global proxy.

Parameters
internal_fields_serializerSimilar to internal_fields_serializer in SetDefaultContext() but only applies to the context being added.
context_data_serializerSimilar to context_data_serializer in SetDefaultContext() but only applies to the context being added.

◆ AddData() [1/4]

template<class T >
V8_INLINE size_t AddData ( Local< Context context,
Local< T >  object 
)

Attach arbitrary V8::Data to the context snapshot, which can be retrieved via Context::GetDataFromSnapshotOnce after deserialization. This data does not survive when a new snapshot is created from an existing snapshot.

Returns
the index for retrieval.

◆ AddData() [2/4]

template<class T >
size_t AddData ( Local< Context context,
Local< T >  object 
)

Definition at line 255 of file v8-snapshot.h.

◆ AddData() [3/4]

template<class T >
V8_INLINE size_t AddData ( Local< T >  object)

Attach arbitrary V8::Data to the isolate snapshot, which can be retrieved via Isolate::GetDataFromSnapshotOnce after deserialization. This data does not survive when a new snapshot is created from an existing snapshot.

Returns
the index for retrieval.

◆ AddData() [4/4]

template<class T >
size_t AddData ( Local< T >  object)

Definition at line 260 of file v8-snapshot.h.

◆ CreateBlob()

StartupData CreateBlob ( FunctionCodeHandling  function_code_handling)

Created a snapshot data blob. This must not be called from within a handle scope.

Parameters
function_code_handlingwhether to include compiled function code in the snapshot.
Returns
{ nullptr, 0 } on failure, and a startup snapshot on success. The caller acquires ownership of the data array in the return value.

◆ GetIsolate()

Isolate * GetIsolate ( )
Returns
the isolate prepared by the snapshot creator.

◆ operator=()

void operator= ( const SnapshotCreator )
delete

◆ SetDefaultContext()

void SetDefaultContext ( Local< Context context,
SerializeInternalFieldsCallback  internal_fields_serializer = SerializeInternalFieldsCallback(),
SerializeContextDataCallback  context_data_serializer = SerializeContextDataCallback() 
)

Set the default context to be included in the snapshot blob. The snapshot will not contain the global proxy, and we expect one or a global object template to create one, to be provided upon deserialization.

Parameters
internal_fields_serializerAn optional callback used to serialize internal pointer fields set by v8::Object::SetAlignedPointerInInternalField().
context_data_serializerAn optional callback used to serialize context embedder data set by v8::Context::SetAlignedPointerInEmbedderData().

Friends And Related Symbol Documentation

◆ internal::SnapshotCreatorImpl

friend class internal::SnapshotCreatorImpl
friend

Definition at line 251 of file v8-snapshot.h.


The documentation for this class was generated from the following file: