libv8-node 16.19.0.1-x86_64-linux-musl → 17.9.1.1-x86_64-linux-musl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (68) hide show
  1. checksums.yaml +4 -4
  2. data/lib/libv8/node/version.rb +3 -3
  3. data/vendor/v8/include/cppgc/allocation.h +11 -5
  4. data/vendor/v8/include/cppgc/cross-thread-persistent.h +78 -26
  5. data/vendor/v8/include/cppgc/internal/caged-heap-local-data.h +2 -2
  6. data/vendor/v8/include/cppgc/internal/finalizer-trait.h +2 -0
  7. data/vendor/v8/include/cppgc/internal/gc-info.h +90 -10
  8. data/vendor/v8/include/cppgc/internal/name-trait.h +11 -0
  9. data/vendor/v8/include/cppgc/internal/persistent-node.h +44 -12
  10. data/vendor/v8/include/cppgc/internal/pointer-policies.h +22 -11
  11. data/vendor/v8/include/cppgc/internal/write-barrier.h +9 -1
  12. data/vendor/v8/include/cppgc/persistent.h +1 -1
  13. data/vendor/v8/include/cppgc/prefinalizer.h +1 -1
  14. data/vendor/v8/include/v8-array-buffer.h +433 -0
  15. data/vendor/v8/include/v8-callbacks.h +377 -0
  16. data/vendor/v8/include/v8-container.h +129 -0
  17. data/vendor/v8/include/v8-context.h +418 -0
  18. data/vendor/v8/include/v8-cppgc.h +5 -2
  19. data/vendor/v8/include/v8-data.h +65 -0
  20. data/vendor/v8/include/v8-date.h +43 -0
  21. data/vendor/v8/include/v8-debug.h +151 -0
  22. data/vendor/v8/include/v8-embedder-heap.h +238 -0
  23. data/vendor/v8/include/v8-exception.h +224 -0
  24. data/vendor/v8/include/v8-extension.h +62 -0
  25. data/vendor/v8/include/v8-external.h +37 -0
  26. data/vendor/v8/include/v8-fast-api-calls.h +63 -11
  27. data/vendor/v8/include/v8-forward.h +81 -0
  28. data/vendor/v8/include/v8-function-callback.h +475 -0
  29. data/vendor/v8/include/v8-function.h +122 -0
  30. data/vendor/v8/include/v8-initialization.h +282 -0
  31. data/vendor/v8/include/v8-inspector.h +11 -21
  32. data/vendor/v8/include/v8-internal.h +85 -22
  33. data/vendor/v8/include/v8-isolate.h +1662 -0
  34. data/vendor/v8/include/v8-json.h +47 -0
  35. data/vendor/v8/include/v8-local-handle.h +459 -0
  36. data/vendor/v8/include/v8-locker.h +148 -0
  37. data/vendor/v8/include/v8-maybe.h +137 -0
  38. data/vendor/v8/include/v8-memory-span.h +43 -0
  39. data/vendor/v8/include/v8-message.h +241 -0
  40. data/vendor/v8/include/v8-metrics.h +37 -1
  41. data/vendor/v8/include/v8-microtask-queue.h +152 -0
  42. data/vendor/v8/include/v8-microtask.h +28 -0
  43. data/vendor/v8/include/v8-object.h +770 -0
  44. data/vendor/v8/include/v8-persistent-handle.h +590 -0
  45. data/vendor/v8/include/v8-platform.h +41 -17
  46. data/vendor/v8/include/v8-primitive-object.h +118 -0
  47. data/vendor/v8/include/v8-primitive.h +858 -0
  48. data/vendor/v8/include/v8-profiler.h +10 -11
  49. data/vendor/v8/include/v8-promise.h +174 -0
  50. data/vendor/v8/include/v8-proxy.h +50 -0
  51. data/vendor/v8/include/v8-regexp.h +105 -0
  52. data/vendor/v8/include/v8-script.h +771 -0
  53. data/vendor/v8/include/v8-snapshot.h +198 -0
  54. data/vendor/v8/include/v8-statistics.h +215 -0
  55. data/vendor/v8/include/v8-template.h +1052 -0
  56. data/vendor/v8/include/v8-traced-handle.h +605 -0
  57. data/vendor/v8/include/v8-typed-array.h +282 -0
  58. data/vendor/v8/include/v8-unwinder-state.h +4 -3
  59. data/vendor/v8/include/v8-unwinder.h +129 -0
  60. data/vendor/v8/include/v8-util.h +7 -1
  61. data/vendor/v8/include/v8-value-serializer.h +249 -0
  62. data/vendor/v8/include/v8-value.h +526 -0
  63. data/vendor/v8/include/v8-version.h +3 -3
  64. data/vendor/v8/include/v8-wasm.h +245 -0
  65. data/vendor/v8/include/v8-weak-callback-info.h +73 -0
  66. data/vendor/v8/include/v8.h +41 -12604
  67. data/vendor/v8/x86_64-linux-musl/libv8/obj/libv8_monolith.a +0 -0
  68. metadata +43 -1
@@ -0,0 +1,770 @@
1
+ // Copyright 2021 the V8 project authors. All rights reserved.
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+
5
+ #ifndef INCLUDE_V8_OBJECT_H_
6
+ #define INCLUDE_V8_OBJECT_H_
7
+
8
+ #include "v8-local-handle.h" // NOLINT(build/include_directory)
9
+ #include "v8-maybe.h" // NOLINT(build/include_directory)
10
+ #include "v8-persistent-handle.h" // NOLINT(build/include_directory)
11
+ #include "v8-primitive.h" // NOLINT(build/include_directory)
12
+ #include "v8-traced-handle.h" // NOLINT(build/include_directory)
13
+ #include "v8-value.h" // NOLINT(build/include_directory)
14
+ #include "v8config.h" // NOLINT(build/include_directory)
15
+
16
+ namespace v8 {
17
+
18
+ class Array;
19
+ class Function;
20
+ class FunctionTemplate;
21
+ template <typename T>
22
+ class PropertyCallbackInfo;
23
+
24
+ /**
25
+ * A private symbol
26
+ *
27
+ * This is an experimental feature. Use at your own risk.
28
+ */
29
+ class V8_EXPORT Private : public Data {
30
+ public:
31
+ /**
32
+ * Returns the print name string of the private symbol, or undefined if none.
33
+ */
34
+ Local<Value> Name() const;
35
+
36
+ /**
37
+ * Create a private symbol. If name is not empty, it will be the description.
38
+ */
39
+ static Local<Private> New(Isolate* isolate,
40
+ Local<String> name = Local<String>());
41
+
42
+ /**
43
+ * Retrieve a global private symbol. If a symbol with this name has not
44
+ * been retrieved in the same isolate before, it is created.
45
+ * Note that private symbols created this way are never collected, so
46
+ * they should only be used for statically fixed properties.
47
+ * Also, there is only one global name space for the names used as keys.
48
+ * To minimize the potential for clashes, use qualified names as keys,
49
+ * e.g., "Class#property".
50
+ */
51
+ static Local<Private> ForApi(Isolate* isolate, Local<String> name);
52
+
53
+ V8_INLINE static Private* Cast(Data* data);
54
+
55
+ private:
56
+ Private();
57
+
58
+ static void CheckCast(Data* that);
59
+ };
60
+
61
+ /**
62
+ * An instance of a Property Descriptor, see Ecma-262 6.2.4.
63
+ *
64
+ * Properties in a descriptor are present or absent. If you do not set
65
+ * `enumerable`, `configurable`, and `writable`, they are absent. If `value`,
66
+ * `get`, or `set` are absent, but you must specify them in the constructor, use
67
+ * empty handles.
68
+ *
69
+ * Accessors `get` and `set` must be callable or undefined if they are present.
70
+ *
71
+ * \note Only query properties if they are present, i.e., call `x()` only if
72
+ * `has_x()` returns true.
73
+ *
74
+ * \code
75
+ * // var desc = {writable: false}
76
+ * v8::PropertyDescriptor d(Local<Value>()), false);
77
+ * d.value(); // error, value not set
78
+ * if (d.has_writable()) {
79
+ * d.writable(); // false
80
+ * }
81
+ *
82
+ * // var desc = {value: undefined}
83
+ * v8::PropertyDescriptor d(v8::Undefined(isolate));
84
+ *
85
+ * // var desc = {get: undefined}
86
+ * v8::PropertyDescriptor d(v8::Undefined(isolate), Local<Value>()));
87
+ * \endcode
88
+ */
89
+ class V8_EXPORT PropertyDescriptor {
90
+ public:
91
+ // GenericDescriptor
92
+ PropertyDescriptor();
93
+
94
+ // DataDescriptor
95
+ explicit PropertyDescriptor(Local<Value> value);
96
+
97
+ // DataDescriptor with writable property
98
+ PropertyDescriptor(Local<Value> value, bool writable);
99
+
100
+ // AccessorDescriptor
101
+ PropertyDescriptor(Local<Value> get, Local<Value> set);
102
+
103
+ ~PropertyDescriptor();
104
+
105
+ Local<Value> value() const;
106
+ bool has_value() const;
107
+
108
+ Local<Value> get() const;
109
+ bool has_get() const;
110
+ Local<Value> set() const;
111
+ bool has_set() const;
112
+
113
+ void set_enumerable(bool enumerable);
114
+ bool enumerable() const;
115
+ bool has_enumerable() const;
116
+
117
+ void set_configurable(bool configurable);
118
+ bool configurable() const;
119
+ bool has_configurable() const;
120
+
121
+ bool writable() const;
122
+ bool has_writable() const;
123
+
124
+ struct PrivateData;
125
+ PrivateData* get_private() const { return private_; }
126
+
127
+ PropertyDescriptor(const PropertyDescriptor&) = delete;
128
+ void operator=(const PropertyDescriptor&) = delete;
129
+
130
+ private:
131
+ PrivateData* private_;
132
+ };
133
+
134
+ /**
135
+ * PropertyAttribute.
136
+ */
137
+ enum PropertyAttribute {
138
+ /** None. **/
139
+ None = 0,
140
+ /** ReadOnly, i.e., not writable. **/
141
+ ReadOnly = 1 << 0,
142
+ /** DontEnum, i.e., not enumerable. **/
143
+ DontEnum = 1 << 1,
144
+ /** DontDelete, i.e., not configurable. **/
145
+ DontDelete = 1 << 2
146
+ };
147
+
148
+ /**
149
+ * Accessor[Getter|Setter] are used as callback functions when
150
+ * setting|getting a particular property. See Object and ObjectTemplate's
151
+ * method SetAccessor.
152
+ */
153
+ using AccessorGetterCallback =
154
+ void (*)(Local<String> property, const PropertyCallbackInfo<Value>& info);
155
+ using AccessorNameGetterCallback =
156
+ void (*)(Local<Name> property, const PropertyCallbackInfo<Value>& info);
157
+
158
+ using AccessorSetterCallback = void (*)(Local<String> property,
159
+ Local<Value> value,
160
+ const PropertyCallbackInfo<void>& info);
161
+ using AccessorNameSetterCallback =
162
+ void (*)(Local<Name> property, Local<Value> value,
163
+ const PropertyCallbackInfo<void>& info);
164
+
165
+ /**
166
+ * Access control specifications.
167
+ *
168
+ * Some accessors should be accessible across contexts. These
169
+ * accessors have an explicit access control parameter which specifies
170
+ * the kind of cross-context access that should be allowed.
171
+ *
172
+ * TODO(dcarney): Remove PROHIBITS_OVERWRITING as it is now unused.
173
+ */
174
+ enum AccessControl {
175
+ DEFAULT = 0,
176
+ ALL_CAN_READ = 1,
177
+ ALL_CAN_WRITE = 1 << 1,
178
+ PROHIBITS_OVERWRITING = 1 << 2
179
+ };
180
+
181
+ /**
182
+ * Property filter bits. They can be or'ed to build a composite filter.
183
+ */
184
+ enum PropertyFilter {
185
+ ALL_PROPERTIES = 0,
186
+ ONLY_WRITABLE = 1,
187
+ ONLY_ENUMERABLE = 2,
188
+ ONLY_CONFIGURABLE = 4,
189
+ SKIP_STRINGS = 8,
190
+ SKIP_SYMBOLS = 16
191
+ };
192
+
193
+ /**
194
+ * Options for marking whether callbacks may trigger JS-observable side effects.
195
+ * Side-effect-free callbacks are allowlisted during debug evaluation with
196
+ * throwOnSideEffect. It applies when calling a Function, FunctionTemplate,
197
+ * or an Accessor callback. For Interceptors, please see
198
+ * PropertyHandlerFlags's kHasNoSideEffect.
199
+ * Callbacks that only cause side effects to the receiver are allowlisted if
200
+ * invoked on receiver objects that are created within the same debug-evaluate
201
+ * call, as these objects are temporary and the side effect does not escape.
202
+ */
203
+ enum class SideEffectType {
204
+ kHasSideEffect,
205
+ kHasNoSideEffect,
206
+ kHasSideEffectToReceiver
207
+ };
208
+
209
+ /**
210
+ * Keys/Properties filter enums:
211
+ *
212
+ * KeyCollectionMode limits the range of collected properties. kOwnOnly limits
213
+ * the collected properties to the given Object only. kIncludesPrototypes will
214
+ * include all keys of the objects's prototype chain as well.
215
+ */
216
+ enum class KeyCollectionMode { kOwnOnly, kIncludePrototypes };
217
+
218
+ /**
219
+ * kIncludesIndices allows for integer indices to be collected, while
220
+ * kSkipIndices will exclude integer indices from being collected.
221
+ */
222
+ enum class IndexFilter { kIncludeIndices, kSkipIndices };
223
+
224
+ /**
225
+ * kConvertToString will convert integer indices to strings.
226
+ * kKeepNumbers will return numbers for integer indices.
227
+ */
228
+ enum class KeyConversionMode { kConvertToString, kKeepNumbers, kNoNumbers };
229
+
230
+ /**
231
+ * Integrity level for objects.
232
+ */
233
+ enum class IntegrityLevel { kFrozen, kSealed };
234
+
235
+ /**
236
+ * A JavaScript object (ECMA-262, 4.3.3)
237
+ */
238
+ class V8_EXPORT Object : public Value {
239
+ public:
240
+ /**
241
+ * Set only return Just(true) or Empty(), so if it should never fail, use
242
+ * result.Check().
243
+ */
244
+ V8_WARN_UNUSED_RESULT Maybe<bool> Set(Local<Context> context,
245
+ Local<Value> key, Local<Value> value);
246
+
247
+ V8_WARN_UNUSED_RESULT Maybe<bool> Set(Local<Context> context, uint32_t index,
248
+ Local<Value> value);
249
+
250
+ // Implements CreateDataProperty (ECMA-262, 7.3.4).
251
+ //
252
+ // Defines a configurable, writable, enumerable property with the given value
253
+ // on the object unless the property already exists and is not configurable
254
+ // or the object is not extensible.
255
+ //
256
+ // Returns true on success.
257
+ V8_WARN_UNUSED_RESULT Maybe<bool> CreateDataProperty(Local<Context> context,
258
+ Local<Name> key,
259
+ Local<Value> value);
260
+ V8_WARN_UNUSED_RESULT Maybe<bool> CreateDataProperty(Local<Context> context,
261
+ uint32_t index,
262
+ Local<Value> value);
263
+
264
+ // Implements DefineOwnProperty.
265
+ //
266
+ // In general, CreateDataProperty will be faster, however, does not allow
267
+ // for specifying attributes.
268
+ //
269
+ // Returns true on success.
270
+ V8_WARN_UNUSED_RESULT Maybe<bool> DefineOwnProperty(
271
+ Local<Context> context, Local<Name> key, Local<Value> value,
272
+ PropertyAttribute attributes = None);
273
+
274
+ // Implements Object.DefineProperty(O, P, Attributes), see Ecma-262 19.1.2.4.
275
+ //
276
+ // The defineProperty function is used to add an own property or
277
+ // update the attributes of an existing own property of an object.
278
+ //
279
+ // Both data and accessor descriptors can be used.
280
+ //
281
+ // In general, CreateDataProperty is faster, however, does not allow
282
+ // for specifying attributes or an accessor descriptor.
283
+ //
284
+ // The PropertyDescriptor can change when redefining a property.
285
+ //
286
+ // Returns true on success.
287
+ V8_WARN_UNUSED_RESULT Maybe<bool> DefineProperty(
288
+ Local<Context> context, Local<Name> key, PropertyDescriptor& descriptor);
289
+
290
+ V8_WARN_UNUSED_RESULT MaybeLocal<Value> Get(Local<Context> context,
291
+ Local<Value> key);
292
+
293
+ V8_WARN_UNUSED_RESULT MaybeLocal<Value> Get(Local<Context> context,
294
+ uint32_t index);
295
+
296
+ /**
297
+ * Gets the property attributes of a property which can be None or
298
+ * any combination of ReadOnly, DontEnum and DontDelete. Returns
299
+ * None when the property doesn't exist.
300
+ */
301
+ V8_WARN_UNUSED_RESULT Maybe<PropertyAttribute> GetPropertyAttributes(
302
+ Local<Context> context, Local<Value> key);
303
+
304
+ /**
305
+ * Returns Object.getOwnPropertyDescriptor as per ES2016 section 19.1.2.6.
306
+ */
307
+ V8_WARN_UNUSED_RESULT MaybeLocal<Value> GetOwnPropertyDescriptor(
308
+ Local<Context> context, Local<Name> key);
309
+
310
+ /**
311
+ * Object::Has() calls the abstract operation HasProperty(O, P) described
312
+ * in ECMA-262, 7.3.10. Has() returns
313
+ * true, if the object has the property, either own or on the prototype chain.
314
+ * Interceptors, i.e., PropertyQueryCallbacks, are called if present.
315
+ *
316
+ * Has() has the same side effects as JavaScript's `variable in object`.
317
+ * For example, calling Has() on a revoked proxy will throw an exception.
318
+ *
319
+ * \note Has() converts the key to a name, which possibly calls back into
320
+ * JavaScript.
321
+ *
322
+ * See also v8::Object::HasOwnProperty() and
323
+ * v8::Object::HasRealNamedProperty().
324
+ */
325
+ V8_WARN_UNUSED_RESULT Maybe<bool> Has(Local<Context> context,
326
+ Local<Value> key);
327
+
328
+ V8_WARN_UNUSED_RESULT Maybe<bool> Delete(Local<Context> context,
329
+ Local<Value> key);
330
+
331
+ V8_WARN_UNUSED_RESULT Maybe<bool> Has(Local<Context> context, uint32_t index);
332
+
333
+ V8_WARN_UNUSED_RESULT Maybe<bool> Delete(Local<Context> context,
334
+ uint32_t index);
335
+
336
+ /**
337
+ * Note: SideEffectType affects the getter only, not the setter.
338
+ */
339
+ V8_WARN_UNUSED_RESULT Maybe<bool> SetAccessor(
340
+ Local<Context> context, Local<Name> name,
341
+ AccessorNameGetterCallback getter,
342
+ AccessorNameSetterCallback setter = nullptr,
343
+ MaybeLocal<Value> data = MaybeLocal<Value>(),
344
+ AccessControl settings = DEFAULT, PropertyAttribute attribute = None,
345
+ SideEffectType getter_side_effect_type = SideEffectType::kHasSideEffect,
346
+ SideEffectType setter_side_effect_type = SideEffectType::kHasSideEffect);
347
+
348
+ void SetAccessorProperty(Local<Name> name, Local<Function> getter,
349
+ Local<Function> setter = Local<Function>(),
350
+ PropertyAttribute attribute = None,
351
+ AccessControl settings = DEFAULT);
352
+
353
+ /**
354
+ * Sets a native data property like Template::SetNativeDataProperty, but
355
+ * this method sets on this object directly.
356
+ */
357
+ V8_WARN_UNUSED_RESULT Maybe<bool> SetNativeDataProperty(
358
+ Local<Context> context, Local<Name> name,
359
+ AccessorNameGetterCallback getter,
360
+ AccessorNameSetterCallback setter = nullptr,
361
+ Local<Value> data = Local<Value>(), PropertyAttribute attributes = None,
362
+ SideEffectType getter_side_effect_type = SideEffectType::kHasSideEffect,
363
+ SideEffectType setter_side_effect_type = SideEffectType::kHasSideEffect);
364
+
365
+ /**
366
+ * Attempts to create a property with the given name which behaves like a data
367
+ * property, except that the provided getter is invoked (and provided with the
368
+ * data value) to supply its value the first time it is read. After the
369
+ * property is accessed once, it is replaced with an ordinary data property.
370
+ *
371
+ * Analogous to Template::SetLazyDataProperty.
372
+ */
373
+ V8_WARN_UNUSED_RESULT Maybe<bool> SetLazyDataProperty(
374
+ Local<Context> context, Local<Name> name,
375
+ AccessorNameGetterCallback getter, Local<Value> data = Local<Value>(),
376
+ PropertyAttribute attributes = None,
377
+ SideEffectType getter_side_effect_type = SideEffectType::kHasSideEffect,
378
+ SideEffectType setter_side_effect_type = SideEffectType::kHasSideEffect);
379
+
380
+ /**
381
+ * Functionality for private properties.
382
+ * This is an experimental feature, use at your own risk.
383
+ * Note: Private properties are not inherited. Do not rely on this, since it
384
+ * may change.
385
+ */
386
+ Maybe<bool> HasPrivate(Local<Context> context, Local<Private> key);
387
+ Maybe<bool> SetPrivate(Local<Context> context, Local<Private> key,
388
+ Local<Value> value);
389
+ Maybe<bool> DeletePrivate(Local<Context> context, Local<Private> key);
390
+ MaybeLocal<Value> GetPrivate(Local<Context> context, Local<Private> key);
391
+
392
+ /**
393
+ * Returns an array containing the names of the enumerable properties
394
+ * of this object, including properties from prototype objects. The
395
+ * array returned by this method contains the same values as would
396
+ * be enumerated by a for-in statement over this object.
397
+ */
398
+ V8_WARN_UNUSED_RESULT MaybeLocal<Array> GetPropertyNames(
399
+ Local<Context> context);
400
+ V8_WARN_UNUSED_RESULT MaybeLocal<Array> GetPropertyNames(
401
+ Local<Context> context, KeyCollectionMode mode,
402
+ PropertyFilter property_filter, IndexFilter index_filter,
403
+ KeyConversionMode key_conversion = KeyConversionMode::kKeepNumbers);
404
+
405
+ /**
406
+ * This function has the same functionality as GetPropertyNames but
407
+ * the returned array doesn't contain the names of properties from
408
+ * prototype objects.
409
+ */
410
+ V8_WARN_UNUSED_RESULT MaybeLocal<Array> GetOwnPropertyNames(
411
+ Local<Context> context);
412
+
413
+ /**
414
+ * Returns an array containing the names of the filtered properties
415
+ * of this object, including properties from prototype objects. The
416
+ * array returned by this method contains the same values as would
417
+ * be enumerated by a for-in statement over this object.
418
+ */
419
+ V8_WARN_UNUSED_RESULT MaybeLocal<Array> GetOwnPropertyNames(
420
+ Local<Context> context, PropertyFilter filter,
421
+ KeyConversionMode key_conversion = KeyConversionMode::kKeepNumbers);
422
+
423
+ /**
424
+ * Get the prototype object. This does not skip objects marked to
425
+ * be skipped by __proto__ and it does not consult the security
426
+ * handler.
427
+ */
428
+ Local<Value> GetPrototype();
429
+
430
+ /**
431
+ * Set the prototype object. This does not skip objects marked to
432
+ * be skipped by __proto__ and it does not consult the security
433
+ * handler.
434
+ */
435
+ V8_WARN_UNUSED_RESULT Maybe<bool> SetPrototype(Local<Context> context,
436
+ Local<Value> prototype);
437
+
438
+ /**
439
+ * Finds an instance of the given function template in the prototype
440
+ * chain.
441
+ */
442
+ Local<Object> FindInstanceInPrototypeChain(Local<FunctionTemplate> tmpl);
443
+
444
+ /**
445
+ * Call builtin Object.prototype.toString on this object.
446
+ * This is different from Value::ToString() that may call
447
+ * user-defined toString function. This one does not.
448
+ */
449
+ V8_WARN_UNUSED_RESULT MaybeLocal<String> ObjectProtoToString(
450
+ Local<Context> context);
451
+
452
+ /**
453
+ * Returns the name of the function invoked as a constructor for this object.
454
+ */
455
+ Local<String> GetConstructorName();
456
+
457
+ /**
458
+ * Sets the integrity level of the object.
459
+ */
460
+ Maybe<bool> SetIntegrityLevel(Local<Context> context, IntegrityLevel level);
461
+
462
+ /** Gets the number of internal fields for this Object. */
463
+ int InternalFieldCount() const;
464
+
465
+ /** Same as above, but works for PersistentBase. */
466
+ V8_INLINE static int InternalFieldCount(
467
+ const PersistentBase<Object>& object) {
468
+ return object.val_->InternalFieldCount();
469
+ }
470
+
471
+ /** Same as above, but works for BasicTracedReference. */
472
+ V8_INLINE static int InternalFieldCount(
473
+ const BasicTracedReference<Object>& object) {
474
+ return object->InternalFieldCount();
475
+ }
476
+
477
+ /** Gets the value from an internal field. */
478
+ V8_INLINE Local<Value> GetInternalField(int index);
479
+
480
+ /** Sets the value in an internal field. */
481
+ void SetInternalField(int index, Local<Value> value);
482
+
483
+ /**
484
+ * Gets a 2-byte-aligned native pointer from an internal field. This field
485
+ * must have been set by SetAlignedPointerInInternalField, everything else
486
+ * leads to undefined behavior.
487
+ */
488
+ V8_INLINE void* GetAlignedPointerFromInternalField(int index);
489
+
490
+ /** Same as above, but works for PersistentBase. */
491
+ V8_INLINE static void* GetAlignedPointerFromInternalField(
492
+ const PersistentBase<Object>& object, int index) {
493
+ return object.val_->GetAlignedPointerFromInternalField(index);
494
+ }
495
+
496
+ /** Same as above, but works for TracedGlobal. */
497
+ V8_INLINE static void* GetAlignedPointerFromInternalField(
498
+ const BasicTracedReference<Object>& object, int index) {
499
+ return object->GetAlignedPointerFromInternalField(index);
500
+ }
501
+
502
+ /**
503
+ * Sets a 2-byte-aligned native pointer in an internal field. To retrieve such
504
+ * a field, GetAlignedPointerFromInternalField must be used, everything else
505
+ * leads to undefined behavior.
506
+ */
507
+ void SetAlignedPointerInInternalField(int index, void* value);
508
+ void SetAlignedPointerInInternalFields(int argc, int indices[],
509
+ void* values[]);
510
+
511
+ /**
512
+ * HasOwnProperty() is like JavaScript's Object.prototype.hasOwnProperty().
513
+ *
514
+ * See also v8::Object::Has() and v8::Object::HasRealNamedProperty().
515
+ */
516
+ V8_WARN_UNUSED_RESULT Maybe<bool> HasOwnProperty(Local<Context> context,
517
+ Local<Name> key);
518
+ V8_WARN_UNUSED_RESULT Maybe<bool> HasOwnProperty(Local<Context> context,
519
+ uint32_t index);
520
+ /**
521
+ * Use HasRealNamedProperty() if you want to check if an object has an own
522
+ * property without causing side effects, i.e., without calling interceptors.
523
+ *
524
+ * This function is similar to v8::Object::HasOwnProperty(), but it does not
525
+ * call interceptors.
526
+ *
527
+ * \note Consider using non-masking interceptors, i.e., the interceptors are
528
+ * not called if the receiver has the real named property. See
529
+ * `v8::PropertyHandlerFlags::kNonMasking`.
530
+ *
531
+ * See also v8::Object::Has().
532
+ */
533
+ V8_WARN_UNUSED_RESULT Maybe<bool> HasRealNamedProperty(Local<Context> context,
534
+ Local<Name> key);
535
+ V8_WARN_UNUSED_RESULT Maybe<bool> HasRealIndexedProperty(
536
+ Local<Context> context, uint32_t index);
537
+ V8_WARN_UNUSED_RESULT Maybe<bool> HasRealNamedCallbackProperty(
538
+ Local<Context> context, Local<Name> key);
539
+
540
+ /**
541
+ * If result.IsEmpty() no real property was located in the prototype chain.
542
+ * This means interceptors in the prototype chain are not called.
543
+ */
544
+ V8_WARN_UNUSED_RESULT MaybeLocal<Value> GetRealNamedPropertyInPrototypeChain(
545
+ Local<Context> context, Local<Name> key);
546
+
547
+ /**
548
+ * Gets the property attributes of a real property in the prototype chain,
549
+ * which can be None or any combination of ReadOnly, DontEnum and DontDelete.
550
+ * Interceptors in the prototype chain are not called.
551
+ */
552
+ V8_WARN_UNUSED_RESULT Maybe<PropertyAttribute>
553
+ GetRealNamedPropertyAttributesInPrototypeChain(Local<Context> context,
554
+ Local<Name> key);
555
+
556
+ /**
557
+ * If result.IsEmpty() no real property was located on the object or
558
+ * in the prototype chain.
559
+ * This means interceptors in the prototype chain are not called.
560
+ */
561
+ V8_WARN_UNUSED_RESULT MaybeLocal<Value> GetRealNamedProperty(
562
+ Local<Context> context, Local<Name> key);
563
+
564
+ /**
565
+ * Gets the property attributes of a real property which can be
566
+ * None or any combination of ReadOnly, DontEnum and DontDelete.
567
+ * Interceptors in the prototype chain are not called.
568
+ */
569
+ V8_WARN_UNUSED_RESULT Maybe<PropertyAttribute> GetRealNamedPropertyAttributes(
570
+ Local<Context> context, Local<Name> key);
571
+
572
+ /** Tests for a named lookup interceptor.*/
573
+ bool HasNamedLookupInterceptor() const;
574
+
575
+ /** Tests for an index lookup interceptor.*/
576
+ bool HasIndexedLookupInterceptor() const;
577
+
578
+ /**
579
+ * Returns the identity hash for this object. The current implementation
580
+ * uses a hidden property on the object to store the identity hash.
581
+ *
582
+ * The return value will never be 0. Also, it is not guaranteed to be
583
+ * unique.
584
+ */
585
+ int GetIdentityHash();
586
+
587
+ /**
588
+ * Clone this object with a fast but shallow copy. Values will point
589
+ * to the same values as the original object.
590
+ */
591
+ // TODO(dcarney): take an isolate and optionally bail out?
592
+ Local<Object> Clone();
593
+
594
+ /**
595
+ * Returns the context in which the object was created.
596
+ */
597
+ V8_DEPRECATE_SOON("Use MaybeLocal<Context> GetCreationContext()")
598
+ Local<Context> CreationContext();
599
+ MaybeLocal<Context> GetCreationContext();
600
+
601
+ /** Same as above, but works for Persistents */
602
+ V8_DEPRECATE_SOON(
603
+ "Use MaybeLocal<Context> GetCreationContext(const "
604
+ "PersistentBase<Object>& object)")
605
+ static Local<Context> CreationContext(const PersistentBase<Object>& object);
606
+ V8_INLINE static MaybeLocal<Context> GetCreationContext(
607
+ const PersistentBase<Object>& object) {
608
+ return object.val_->GetCreationContext();
609
+ }
610
+
611
+ /**
612
+ * Checks whether a callback is set by the
613
+ * ObjectTemplate::SetCallAsFunctionHandler method.
614
+ * When an Object is callable this method returns true.
615
+ */
616
+ bool IsCallable() const;
617
+
618
+ /**
619
+ * True if this object is a constructor.
620
+ */
621
+ bool IsConstructor() const;
622
+
623
+ /**
624
+ * True if this object can carry information relevant to the embedder in its
625
+ * embedder fields, false otherwise. This is generally true for objects
626
+ * constructed through function templates but also holds for other types where
627
+ * V8 automatically adds internal fields at compile time, such as e.g.
628
+ * v8::ArrayBuffer.
629
+ */
630
+ bool IsApiWrapper() const;
631
+
632
+ /**
633
+ * True if this object was created from an object template which was marked
634
+ * as undetectable. See v8::ObjectTemplate::MarkAsUndetectable for more
635
+ * information.
636
+ */
637
+ bool IsUndetectable() const;
638
+
639
+ /**
640
+ * Call an Object as a function if a callback is set by the
641
+ * ObjectTemplate::SetCallAsFunctionHandler method.
642
+ */
643
+ V8_WARN_UNUSED_RESULT MaybeLocal<Value> CallAsFunction(Local<Context> context,
644
+ Local<Value> recv,
645
+ int argc,
646
+ Local<Value> argv[]);
647
+
648
+ /**
649
+ * Call an Object as a constructor if a callback is set by the
650
+ * ObjectTemplate::SetCallAsFunctionHandler method.
651
+ * Note: This method behaves like the Function::NewInstance method.
652
+ */
653
+ V8_WARN_UNUSED_RESULT MaybeLocal<Value> CallAsConstructor(
654
+ Local<Context> context, int argc, Local<Value> argv[]);
655
+
656
+ /**
657
+ * Return the isolate to which the Object belongs to.
658
+ */
659
+ Isolate* GetIsolate();
660
+
661
+ /**
662
+ * If this object is a Set, Map, WeakSet or WeakMap, this returns a
663
+ * representation of the elements of this object as an array.
664
+ * If this object is a SetIterator or MapIterator, this returns all
665
+ * elements of the underlying collection, starting at the iterator's current
666
+ * position.
667
+ * For other types, this will return an empty MaybeLocal<Array> (without
668
+ * scheduling an exception).
669
+ */
670
+ MaybeLocal<Array> PreviewEntries(bool* is_key_value);
671
+
672
+ static Local<Object> New(Isolate* isolate);
673
+
674
+ /**
675
+ * Creates a JavaScript object with the given properties, and
676
+ * a the given prototype_or_null (which can be any JavaScript
677
+ * value, and if it's null, the newly created object won't have
678
+ * a prototype at all). This is similar to Object.create().
679
+ * All properties will be created as enumerable, configurable
680
+ * and writable properties.
681
+ */
682
+ static Local<Object> New(Isolate* isolate, Local<Value> prototype_or_null,
683
+ Local<Name>* names, Local<Value>* values,
684
+ size_t length);
685
+
686
+ V8_INLINE static Object* Cast(Value* obj);
687
+
688
+ /**
689
+ * Support for TC39 "dynamic code brand checks" proposal.
690
+ *
691
+ * This API allows to query whether an object was constructed from a
692
+ * "code like" ObjectTemplate.
693
+ *
694
+ * See also: v8::ObjectTemplate::SetCodeLike
695
+ */
696
+ bool IsCodeLike(Isolate* isolate) const;
697
+
698
+ private:
699
+ Object();
700
+ static void CheckCast(Value* obj);
701
+ Local<Value> SlowGetInternalField(int index);
702
+ void* SlowGetAlignedPointerFromInternalField(int index);
703
+ };
704
+
705
+ // --- Implementation ---
706
+
707
+ Local<Value> Object::GetInternalField(int index) {
708
+ #ifndef V8_ENABLE_CHECKS
709
+ using A = internal::Address;
710
+ using I = internal::Internals;
711
+ A obj = *reinterpret_cast<A*>(this);
712
+ // Fast path: If the object is a plain JSObject, which is the common case, we
713
+ // know where to find the internal fields and can return the value directly.
714
+ int instance_type = I::GetInstanceType(obj);
715
+ if (v8::internal::CanHaveInternalField(instance_type)) {
716
+ int offset = I::kJSObjectHeaderSize + (I::kEmbedderDataSlotSize * index);
717
+ A value = I::ReadRawField<A>(obj, offset);
718
+ #ifdef V8_COMPRESS_POINTERS
719
+ // We read the full pointer value and then decompress it in order to avoid
720
+ // dealing with potential endiannes issues.
721
+ value = I::DecompressTaggedAnyField(obj, static_cast<uint32_t>(value));
722
+ #endif
723
+ internal::Isolate* isolate =
724
+ internal::IsolateFromNeverReadOnlySpaceObject(obj);
725
+ A* result = HandleScope::CreateHandle(isolate, value);
726
+ return Local<Value>(reinterpret_cast<Value*>(result));
727
+ }
728
+ #endif
729
+ return SlowGetInternalField(index);
730
+ }
731
+
732
+ void* Object::GetAlignedPointerFromInternalField(int index) {
733
+ #ifndef V8_ENABLE_CHECKS
734
+ using A = internal::Address;
735
+ using I = internal::Internals;
736
+ A obj = *reinterpret_cast<A*>(this);
737
+ // Fast path: If the object is a plain JSObject, which is the common case, we
738
+ // know where to find the internal fields and can return the value directly.
739
+ auto instance_type = I::GetInstanceType(obj);
740
+ if (v8::internal::CanHaveInternalField(instance_type)) {
741
+ int offset = I::kJSObjectHeaderSize + (I::kEmbedderDataSlotSize * index);
742
+ #ifdef V8_HEAP_SANDBOX
743
+ offset += I::kEmbedderDataSlotRawPayloadOffset;
744
+ #endif
745
+ internal::Isolate* isolate = I::GetIsolateForHeapSandbox(obj);
746
+ A value = I::ReadExternalPointerField(
747
+ isolate, obj, offset, internal::kEmbedderDataSlotPayloadTag);
748
+ return reinterpret_cast<void*>(value);
749
+ }
750
+ #endif
751
+ return SlowGetAlignedPointerFromInternalField(index);
752
+ }
753
+
754
+ Private* Private::Cast(Data* data) {
755
+ #ifdef V8_ENABLE_CHECKS
756
+ CheckCast(data);
757
+ #endif
758
+ return reinterpret_cast<Private*>(data);
759
+ }
760
+
761
+ Object* Object::Cast(v8::Value* value) {
762
+ #ifdef V8_ENABLE_CHECKS
763
+ CheckCast(value);
764
+ #endif
765
+ return static_cast<Object*>(value);
766
+ }
767
+
768
+ } // namespace v8
769
+
770
+ #endif // INCLUDE_V8_OBJECT_H_