libv8-node 16.19.0.1-arm64-darwin → 17.9.1.1-arm64-darwin

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. checksums.yaml +4 -4
  2. data/lib/libv8/node/version.rb +3 -3
  3. data/vendor/v8/arm64-darwin/libv8/obj/libv8_monolith.a +0 -0
  4. data/vendor/v8/include/cppgc/allocation.h +11 -5
  5. data/vendor/v8/include/cppgc/cross-thread-persistent.h +78 -26
  6. data/vendor/v8/include/cppgc/internal/caged-heap-local-data.h +2 -2
  7. data/vendor/v8/include/cppgc/internal/finalizer-trait.h +2 -0
  8. data/vendor/v8/include/cppgc/internal/gc-info.h +90 -10
  9. data/vendor/v8/include/cppgc/internal/name-trait.h +11 -0
  10. data/vendor/v8/include/cppgc/internal/persistent-node.h +44 -12
  11. data/vendor/v8/include/cppgc/internal/pointer-policies.h +22 -11
  12. data/vendor/v8/include/cppgc/internal/write-barrier.h +9 -1
  13. data/vendor/v8/include/cppgc/persistent.h +1 -1
  14. data/vendor/v8/include/cppgc/prefinalizer.h +1 -1
  15. data/vendor/v8/include/v8-array-buffer.h +433 -0
  16. data/vendor/v8/include/v8-callbacks.h +377 -0
  17. data/vendor/v8/include/v8-container.h +129 -0
  18. data/vendor/v8/include/v8-context.h +418 -0
  19. data/vendor/v8/include/v8-cppgc.h +5 -2
  20. data/vendor/v8/include/v8-data.h +65 -0
  21. data/vendor/v8/include/v8-date.h +43 -0
  22. data/vendor/v8/include/v8-debug.h +151 -0
  23. data/vendor/v8/include/v8-embedder-heap.h +238 -0
  24. data/vendor/v8/include/v8-exception.h +224 -0
  25. data/vendor/v8/include/v8-extension.h +62 -0
  26. data/vendor/v8/include/v8-external.h +37 -0
  27. data/vendor/v8/include/v8-fast-api-calls.h +63 -11
  28. data/vendor/v8/include/v8-forward.h +81 -0
  29. data/vendor/v8/include/v8-function-callback.h +475 -0
  30. data/vendor/v8/include/v8-function.h +122 -0
  31. data/vendor/v8/include/v8-initialization.h +282 -0
  32. data/vendor/v8/include/v8-inspector.h +11 -21
  33. data/vendor/v8/include/v8-internal.h +85 -22
  34. data/vendor/v8/include/v8-isolate.h +1662 -0
  35. data/vendor/v8/include/v8-json.h +47 -0
  36. data/vendor/v8/include/v8-local-handle.h +459 -0
  37. data/vendor/v8/include/v8-locker.h +148 -0
  38. data/vendor/v8/include/v8-maybe.h +137 -0
  39. data/vendor/v8/include/v8-memory-span.h +43 -0
  40. data/vendor/v8/include/v8-message.h +241 -0
  41. data/vendor/v8/include/v8-metrics.h +37 -1
  42. data/vendor/v8/include/v8-microtask-queue.h +152 -0
  43. data/vendor/v8/include/v8-microtask.h +28 -0
  44. data/vendor/v8/include/v8-object.h +770 -0
  45. data/vendor/v8/include/v8-persistent-handle.h +590 -0
  46. data/vendor/v8/include/v8-platform.h +41 -17
  47. data/vendor/v8/include/v8-primitive-object.h +118 -0
  48. data/vendor/v8/include/v8-primitive.h +858 -0
  49. data/vendor/v8/include/v8-profiler.h +10 -11
  50. data/vendor/v8/include/v8-promise.h +174 -0
  51. data/vendor/v8/include/v8-proxy.h +50 -0
  52. data/vendor/v8/include/v8-regexp.h +105 -0
  53. data/vendor/v8/include/v8-script.h +771 -0
  54. data/vendor/v8/include/v8-snapshot.h +198 -0
  55. data/vendor/v8/include/v8-statistics.h +215 -0
  56. data/vendor/v8/include/v8-template.h +1052 -0
  57. data/vendor/v8/include/v8-traced-handle.h +605 -0
  58. data/vendor/v8/include/v8-typed-array.h +282 -0
  59. data/vendor/v8/include/v8-unwinder-state.h +4 -3
  60. data/vendor/v8/include/v8-unwinder.h +129 -0
  61. data/vendor/v8/include/v8-util.h +7 -1
  62. data/vendor/v8/include/v8-value-serializer.h +249 -0
  63. data/vendor/v8/include/v8-value.h +526 -0
  64. data/vendor/v8/include/v8-version.h +3 -3
  65. data/vendor/v8/include/v8-wasm.h +245 -0
  66. data/vendor/v8/include/v8-weak-callback-info.h +73 -0
  67. data/vendor/v8/include/v8.h +41 -12604
  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_