libv8-node 21.7.2.0-x86_64-linux-musl → 22.5.1.0-x86_64-linux-musl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (37) hide show
  1. checksums.yaml +4 -4
  2. data/lib/libv8/node/version.rb +3 -3
  3. data/vendor/v8/include/cppgc/internal/api-constants.h +1 -1
  4. data/vendor/v8/include/cppgc/type-traits.h +25 -4
  5. data/vendor/v8/include/v8-array-buffer.h +6 -0
  6. data/vendor/v8/include/v8-callbacks.h +6 -12
  7. data/vendor/v8/include/v8-container.h +54 -0
  8. data/vendor/v8/include/v8-context.h +51 -22
  9. data/vendor/v8/include/v8-embedder-heap.h +19 -3
  10. data/vendor/v8/include/v8-embedder-state-scope.h +2 -1
  11. data/vendor/v8/include/v8-exception.h +15 -9
  12. data/vendor/v8/include/v8-fast-api-calls.h +35 -26
  13. data/vendor/v8/include/v8-forward.h +1 -0
  14. data/vendor/v8/include/v8-function-callback.h +129 -20
  15. data/vendor/v8/include/v8-handle-base.h +32 -80
  16. data/vendor/v8/include/v8-inspector.h +16 -24
  17. data/vendor/v8/include/v8-internal.h +472 -65
  18. data/vendor/v8/include/v8-isolate.h +86 -51
  19. data/vendor/v8/include/v8-local-handle.h +257 -31
  20. data/vendor/v8/include/v8-memory-span.h +157 -2
  21. data/vendor/v8/include/v8-message.h +22 -3
  22. data/vendor/v8/include/v8-metrics.h +1 -0
  23. data/vendor/v8/include/v8-object.h +29 -10
  24. data/vendor/v8/include/v8-persistent-handle.h +5 -3
  25. data/vendor/v8/include/v8-platform.h +81 -44
  26. data/vendor/v8/include/v8-script.h +61 -11
  27. data/vendor/v8/include/v8-snapshot.h +94 -23
  28. data/vendor/v8/include/v8-statistics.h +10 -24
  29. data/vendor/v8/include/v8-template.h +410 -131
  30. data/vendor/v8/include/v8-traced-handle.h +81 -46
  31. data/vendor/v8/include/v8-typed-array.h +115 -7
  32. data/vendor/v8/include/v8-util.h +13 -12
  33. data/vendor/v8/include/v8-value.h +92 -4
  34. data/vendor/v8/include/v8-version.h +4 -4
  35. data/vendor/v8/include/v8config.h +35 -10
  36. data/vendor/v8/x86_64-linux-musl/libv8/obj/libv8_monolith.a +0 -0
  37. metadata +2 -2
@@ -6,6 +6,7 @@
6
6
  #define INCLUDE_V8_SNAPSHOT_H_
7
7
 
8
8
  #include "v8-internal.h" // NOLINT(build/include_directory)
9
+ #include "v8-isolate.h" // NOLINT(build/include_directory)
9
10
  #include "v8-local-handle.h" // NOLINT(build/include_directory)
10
11
  #include "v8config.h" // NOLINT(build/include_directory)
11
12
 
@@ -13,6 +14,10 @@ namespace v8 {
13
14
 
14
15
  class Object;
15
16
 
17
+ namespace internal {
18
+ class SnapshotCreatorImpl;
19
+ } // namespace internal
20
+
16
21
  class V8_EXPORT StartupData {
17
22
  public:
18
23
  /**
@@ -33,7 +38,7 @@ class V8_EXPORT StartupData {
33
38
 
34
39
  /**
35
40
  * Callback and supporting data used in SnapshotCreator to implement embedder
36
- * logic to serialize internal fields.
41
+ * logic to serialize internal fields of v8::Objects.
37
42
  * Internal fields that directly reference V8 objects are serialized without
38
43
  * calling this callback. Internal fields that contain aligned pointers are
39
44
  * serialized by this callback if it returns non-zero result. Otherwise it is
@@ -48,13 +53,24 @@ struct SerializeInternalFieldsCallback {
48
53
  CallbackFunction callback;
49
54
  void* data;
50
55
  };
51
- // Note that these fields are called "internal fields" in the API and called
52
- // "embedder fields" within V8.
53
- using SerializeEmbedderFieldsCallback = SerializeInternalFieldsCallback;
56
+
57
+ /**
58
+ * Similar to SerializeInternalFieldsCallback, but works with the embedder data
59
+ * in a v8::Context.
60
+ */
61
+ struct SerializeContextDataCallback {
62
+ using CallbackFunction = StartupData (*)(Local<Context> holder, int index,
63
+ void* data);
64
+ SerializeContextDataCallback(CallbackFunction function = nullptr,
65
+ void* data_arg = nullptr)
66
+ : callback(function), data(data_arg) {}
67
+ CallbackFunction callback;
68
+ void* data;
69
+ };
54
70
 
55
71
  /**
56
72
  * Callback and supporting data used to implement embedder logic to deserialize
57
- * internal fields.
73
+ * internal fields of v8::Objects.
58
74
  */
59
75
  struct DeserializeInternalFieldsCallback {
60
76
  using CallbackFunction = void (*)(Local<Object> holder, int index,
@@ -62,12 +78,24 @@ struct DeserializeInternalFieldsCallback {
62
78
  DeserializeInternalFieldsCallback(CallbackFunction function = nullptr,
63
79
  void* data_arg = nullptr)
64
80
  : callback(function), data(data_arg) {}
65
- void (*callback)(Local<Object> holder, int index, StartupData payload,
66
- void* data);
81
+
82
+ CallbackFunction callback;
67
83
  void* data;
68
84
  };
69
85
 
70
- using DeserializeEmbedderFieldsCallback = DeserializeInternalFieldsCallback;
86
+ /**
87
+ * Similar to DeserializeInternalFieldsCallback, but works with the embedder
88
+ * data in a v8::Context.
89
+ */
90
+ struct DeserializeContextDataCallback {
91
+ using CallbackFunction = void (*)(Local<Context> holder, int index,
92
+ StartupData payload, void* data);
93
+ DeserializeContextDataCallback(CallbackFunction function = nullptr,
94
+ void* data_arg = nullptr)
95
+ : callback(function), data(data_arg) {}
96
+ CallbackFunction callback;
97
+ void* data;
98
+ };
71
99
 
72
100
  /**
73
101
  * Helper class to create a snapshot data blob.
@@ -91,10 +119,11 @@ class V8_EXPORT SnapshotCreator {
91
119
  * \param owns_isolate whether this SnapshotCreator should call
92
120
  * v8::Isolate::Dispose() during its destructor.
93
121
  */
94
- SnapshotCreator(Isolate* isolate,
95
- const intptr_t* external_references = nullptr,
96
- const StartupData* existing_blob = nullptr,
97
- bool owns_isolate = true);
122
+ V8_DEPRECATE_SOON("Use the version that passes CreateParams instead.")
123
+ explicit SnapshotCreator(Isolate* isolate,
124
+ const intptr_t* external_references = nullptr,
125
+ const StartupData* existing_blob = nullptr,
126
+ bool owns_isolate = true);
98
127
 
99
128
  /**
100
129
  * Create and enter an isolate, and set it up for serialization.
@@ -104,8 +133,35 @@ class V8_EXPORT SnapshotCreator {
104
133
  * \param external_references a null-terminated array of external references
105
134
  * that must be equivalent to CreateParams::external_references.
106
135
  */
107
- SnapshotCreator(const intptr_t* external_references = nullptr,
108
- const StartupData* existing_blob = nullptr);
136
+ V8_DEPRECATE_SOON("Use the version that passes CreateParams instead.")
137
+ explicit SnapshotCreator(const intptr_t* external_references = nullptr,
138
+ const StartupData* existing_blob = nullptr);
139
+
140
+ /**
141
+ * Creates an Isolate for serialization and enters it. The creator fully owns
142
+ * the Isolate and will invoke `v8::Isolate::Dispose()` during destruction.
143
+ *
144
+ * \param params The parameters to initialize the Isolate for. Details:
145
+ * - `params.external_references` are expected to be a
146
+ * null-terminated array of external references.
147
+ * - `params.existing_blob` is an optional snapshot blob from
148
+ * which can be used to initialize the new blob.
149
+ */
150
+ explicit SnapshotCreator(const v8::Isolate::CreateParams& params);
151
+
152
+ /**
153
+ * Initializes an Isolate for serialization and enters it. The creator does
154
+ * not own the Isolate but merely initialize it properly.
155
+ *
156
+ * \param isolate The isolate that was allocated by `Isolate::Allocate()~.
157
+ * \param params The parameters to initialize the Isolate for. Details:
158
+ * - `params.external_references` are expected to be a
159
+ * null-terminated array of external references.
160
+ * - `params.existing_blob` is an optional snapshot blob from
161
+ * which can be used to initialize the new blob.
162
+ */
163
+ SnapshotCreator(v8::Isolate* isolate,
164
+ const v8::Isolate::CreateParams& params);
109
165
 
110
166
  /**
111
167
  * Destroy the snapshot creator, and exit and dispose of the Isolate
@@ -123,23 +179,37 @@ class V8_EXPORT SnapshotCreator {
123
179
  * The snapshot will not contain the global proxy, and we expect one or a
124
180
  * global object template to create one, to be provided upon deserialization.
125
181
  *
126
- * \param callback optional callback to serialize internal fields.
182
+ * \param internal_fields_serializer An optional callback used to serialize
183
+ * internal pointer fields set by
184
+ * v8::Object::SetAlignedPointerInInternalField().
185
+ *
186
+ * \param context_data_serializer An optional callback used to serialize
187
+ * context embedder data set by
188
+ * v8::Context::SetAlignedPointerInEmbedderData().
189
+ *
127
190
  */
128
- void SetDefaultContext(Local<Context> context,
129
- SerializeInternalFieldsCallback callback =
130
- SerializeInternalFieldsCallback());
191
+ void SetDefaultContext(
192
+ Local<Context> context,
193
+ SerializeInternalFieldsCallback internal_fields_serializer =
194
+ SerializeInternalFieldsCallback(),
195
+ SerializeContextDataCallback context_data_serializer =
196
+ SerializeContextDataCallback());
131
197
 
132
198
  /**
133
199
  * Add additional context to be included in the snapshot blob.
134
200
  * The snapshot will include the global proxy.
135
201
  *
136
- * \param callback optional callback to serialize internal fields.
202
+ * \param internal_fields_serializer Similar to internal_fields_serializer
203
+ * in SetDefaultContext() but only applies to the context being added.
137
204
  *
138
- * \returns the index of the context in the snapshot blob.
205
+ * \param context_data_serializer Similar to context_data_serializer
206
+ * in SetDefaultContext() but only applies to the context being added.
139
207
  */
140
208
  size_t AddContext(Local<Context> context,
141
- SerializeInternalFieldsCallback callback =
142
- SerializeInternalFieldsCallback());
209
+ SerializeInternalFieldsCallback internal_fields_serializer =
210
+ SerializeInternalFieldsCallback(),
211
+ SerializeContextDataCallback context_data_serializer =
212
+ SerializeContextDataCallback());
143
213
 
144
214
  /**
145
215
  * Attach arbitrary V8::Data to the context snapshot, which can be retrieved
@@ -177,7 +247,8 @@ class V8_EXPORT SnapshotCreator {
177
247
  size_t AddData(Local<Context> context, internal::Address object);
178
248
  size_t AddData(internal::Address object);
179
249
 
180
- void* data_;
250
+ internal::SnapshotCreatorImpl* impl_;
251
+ friend class internal::SnapshotCreatorImpl;
181
252
  };
182
253
 
183
254
  template <class T>
@@ -13,6 +13,7 @@
13
13
  #include <vector>
14
14
 
15
15
  #include "v8-local-handle.h" // NOLINT(build/include_directory)
16
+ #include "v8-memory-span.h" // NOLINT(build/include_directory)
16
17
  #include "v8-promise.h" // NOLINT(build/include_directory)
17
18
  #include "v8config.h" // NOLINT(build/include_directory)
18
19
 
@@ -60,42 +61,27 @@ class V8_EXPORT MeasureMemoryDelegate {
60
61
  */
61
62
  virtual bool ShouldMeasure(Local<Context> context) = 0;
62
63
 
63
- /**
64
- * This function is called when memory measurement finishes.
65
- *
66
- * \param context_sizes_in_bytes a vector of (context, size) pairs that
67
- * includes each context for which ShouldMeasure returned true and that
68
- * was not garbage collected while the memory measurement was in progress.
69
- *
70
- * \param unattributed_size_in_bytes total size of objects that were not
71
- * attributed to any context (i.e. are likely shared objects).
72
- */
73
- V8_DEPRECATE_SOON("Please use the version that takes a result struct")
74
- virtual void MeasurementComplete(
75
- const std::vector<std::pair<Local<Context>, size_t>>&
76
- context_sizes_in_bytes,
77
- size_t unattributed_size_in_bytes) {}
78
-
79
64
  /** Holds the result of a memory measurement request. */
80
65
  struct Result {
81
66
  /**
82
- * a vector of (context, size) pairs that includes each context for
83
- * which ShouldMeasure returned true and that was not garbage collected
84
- * while the memory measurement was in progress.
67
+ * Two spans of equal length: the first includes each context for which
68
+ * ShouldMeasure returned true and that was not garbage collected while
69
+ * the memory measurement was in progress; the second includes the size
70
+ * of the respective context.
85
71
  */
86
- const std::vector<std::pair<Local<Context>, size_t>>&
87
- context_sizes_in_bytes;
72
+ const MemorySpan<const Local<Context>>& contexts;
73
+ const MemorySpan<const size_t>& sizes_in_bytes;
88
74
 
89
75
  /**
90
- * total size of objects that were not attributed to any context (i.e. are
76
+ * Total size of objects that were not attributed to any context (i.e. are
91
77
  * likely shared objects).
92
78
  */
93
79
  size_t unattributed_size_in_bytes;
94
80
 
95
- /** total size of generated code for Wasm (shared across contexts). */
81
+ /** Total size of generated code for Wasm (shared across contexts). */
96
82
  size_t wasm_code_size_in_bytes;
97
83
 
98
- /** total size of Wasm metadata (except code; shared across contexts). */
84
+ /** Total size of Wasm metadata (except code; shared across contexts). */
99
85
  size_t wasm_metadata_size_in_bytes;
100
86
  };
101
87