libv8-node 19.9.0.0-x86_64-darwin → 20.2.0.0-x86_64-darwin

Sign up to get free protection for your applications and to get access to all the features.
Files changed (48) hide show
  1. checksums.yaml +4 -4
  2. data/lib/libv8/node/version.rb +3 -3
  3. data/vendor/v8/include/cppgc/cross-thread-persistent.h +4 -2
  4. data/vendor/v8/include/cppgc/heap-consistency.h +2 -2
  5. data/vendor/v8/include/cppgc/heap-handle.h +5 -0
  6. data/vendor/v8/include/cppgc/internal/api-constants.h +4 -1
  7. data/vendor/v8/include/cppgc/internal/gc-info.h +35 -33
  8. data/vendor/v8/include/cppgc/internal/member-storage.h +19 -7
  9. data/vendor/v8/include/cppgc/internal/pointer-policies.h +38 -2
  10. data/vendor/v8/include/cppgc/internal/write-barrier.h +15 -5
  11. data/vendor/v8/include/cppgc/macros.h +10 -1
  12. data/vendor/v8/include/cppgc/member.h +167 -129
  13. data/vendor/v8/include/cppgc/persistent.h +22 -15
  14. data/vendor/v8/include/cppgc/platform.h +6 -4
  15. data/vendor/v8/include/cppgc/type-traits.h +4 -3
  16. data/vendor/v8/include/cppgc/visitor.h +16 -1
  17. data/vendor/v8/include/libplatform/v8-tracing.h +2 -2
  18. data/vendor/v8/include/v8-array-buffer.h +59 -0
  19. data/vendor/v8/include/v8-callbacks.h +14 -1
  20. data/vendor/v8/include/v8-context.h +50 -3
  21. data/vendor/v8/include/v8-cppgc.h +10 -0
  22. data/vendor/v8/include/v8-data.h +1 -1
  23. data/vendor/v8/include/v8-embedder-heap.h +0 -169
  24. data/vendor/v8/include/v8-fast-api-calls.h +7 -3
  25. data/vendor/v8/include/v8-function-callback.h +69 -42
  26. data/vendor/v8/include/v8-function.h +1 -0
  27. data/vendor/v8/include/v8-inspector.h +20 -5
  28. data/vendor/v8/include/v8-internal.h +242 -150
  29. data/vendor/v8/include/v8-isolate.h +30 -40
  30. data/vendor/v8/include/v8-local-handle.h +81 -48
  31. data/vendor/v8/include/v8-metrics.h +28 -2
  32. data/vendor/v8/include/v8-microtask-queue.h +5 -0
  33. data/vendor/v8/include/v8-object.h +21 -3
  34. data/vendor/v8/include/v8-persistent-handle.h +25 -16
  35. data/vendor/v8/include/v8-platform.h +79 -10
  36. data/vendor/v8/include/v8-primitive.h +19 -12
  37. data/vendor/v8/include/v8-profiler.h +49 -31
  38. data/vendor/v8/include/v8-script.h +29 -1
  39. data/vendor/v8/include/v8-snapshot.h +4 -8
  40. data/vendor/v8/include/v8-template.h +3 -1
  41. data/vendor/v8/include/v8-traced-handle.h +22 -28
  42. data/vendor/v8/include/v8-util.h +9 -3
  43. data/vendor/v8/include/v8-value.h +31 -4
  44. data/vendor/v8/include/v8-version.h +4 -4
  45. data/vendor/v8/include/v8-wasm.h +2 -1
  46. data/vendor/v8/include/v8config.h +73 -2
  47. data/vendor/v8/x86_64-darwin/libv8/obj/libv8_monolith.a +0 -0
  48. metadata +1 -1
@@ -28,13 +28,11 @@ namespace internal {
28
28
 
29
29
  // MemberBase always refers to the object as const object and defers to
30
30
  // BasicMember on casting to the right type as needed.
31
+ template <typename StorageType>
31
32
  class V8_TRIVIAL_ABI MemberBase {
32
33
  public:
33
- #if defined(CPPGC_POINTER_COMPRESSION)
34
- using RawStorage = CompressedPointer;
35
- #else // !defined(CPPGC_POINTER_COMPRESSION)
36
- using RawStorage = RawPointer;
37
- #endif // !defined(CPPGC_POINTER_COMPRESSION)
34
+ using RawStorage = StorageType;
35
+
38
36
  protected:
39
37
  struct AtomicInitializerTag {};
40
38
 
@@ -75,16 +73,19 @@ class V8_TRIVIAL_ABI MemberBase {
75
73
 
76
74
  // The basic class from which all Member classes are 'generated'.
77
75
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
78
- typename CheckingPolicy>
79
- class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
76
+ typename CheckingPolicy, typename StorageType>
77
+ class V8_TRIVIAL_ABI BasicMember final : private MemberBase<StorageType>,
80
78
  private CheckingPolicy {
79
+ using Base = MemberBase<StorageType>;
80
+
81
81
  public:
82
82
  using PointeeType = T;
83
+ using RawStorage = typename Base::RawStorage;
83
84
 
84
85
  V8_INLINE constexpr BasicMember() = default;
85
- V8_INLINE constexpr BasicMember(std::nullptr_t) {} // NOLINT
86
- V8_INLINE BasicMember(SentinelPointer s) : MemberBase(s) {} // NOLINT
87
- V8_INLINE BasicMember(T* raw) : MemberBase(raw) { // NOLINT
86
+ V8_INLINE constexpr BasicMember(std::nullptr_t) {} // NOLINT
87
+ V8_INLINE BasicMember(SentinelPointer s) : Base(s) {} // NOLINT
88
+ V8_INLINE BasicMember(T* raw) : Base(raw) { // NOLINT
88
89
  InitializingWriteBarrier(raw);
89
90
  this->CheckPointer(Get());
90
91
  }
@@ -94,13 +95,13 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
94
95
  // Atomic ctor. Using the AtomicInitializerTag forces BasicMember to
95
96
  // initialize using atomic assignments. This is required for preventing
96
97
  // data races with concurrent marking.
97
- using AtomicInitializerTag = MemberBase::AtomicInitializerTag;
98
+ using AtomicInitializerTag = typename Base::AtomicInitializerTag;
98
99
  V8_INLINE BasicMember(std::nullptr_t, AtomicInitializerTag atomic)
99
- : MemberBase(nullptr, atomic) {}
100
+ : Base(nullptr, atomic) {}
100
101
  V8_INLINE BasicMember(SentinelPointer s, AtomicInitializerTag atomic)
101
- : MemberBase(s, atomic) {}
102
+ : Base(s, atomic) {}
102
103
  V8_INLINE BasicMember(T* raw, AtomicInitializerTag atomic)
103
- : MemberBase(raw, atomic) {
104
+ : Base(raw, atomic) {
104
105
  InitializingWriteBarrier(raw);
105
106
  this->CheckPointer(Get());
106
107
  }
@@ -119,7 +120,7 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
119
120
  std::enable_if_t<internal::IsDecayedSameV<T, U>>* = nullptr>
120
121
  V8_INLINE BasicMember( // NOLINT
121
122
  const BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy,
122
- OtherCheckingPolicy>& other)
123
+ OtherCheckingPolicy, StorageType>& other)
123
124
  : BasicMember(other.GetRawStorage()) {}
124
125
 
125
126
  template <typename U, typename OtherBarrierPolicy, typename OtherWeaknessTag,
@@ -127,7 +128,7 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
127
128
  std::enable_if_t<internal::IsStrictlyBaseOfV<T, U>>* = nullptr>
128
129
  V8_INLINE BasicMember( // NOLINT
129
130
  const BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy,
130
- OtherCheckingPolicy>& other)
131
+ OtherCheckingPolicy, StorageType>& other)
131
132
  : BasicMember(other.Get()) {}
132
133
 
133
134
  // Move ctor.
@@ -142,8 +143,9 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
142
143
  template <typename U, typename OtherBarrierPolicy, typename OtherWeaknessTag,
143
144
  typename OtherCheckingPolicy,
144
145
  std::enable_if_t<internal::IsDecayedSameV<T, U>>* = nullptr>
145
- V8_INLINE BasicMember(BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy,
146
- OtherCheckingPolicy>&& other) noexcept
146
+ V8_INLINE BasicMember(
147
+ BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy, OtherCheckingPolicy,
148
+ StorageType>&& other) noexcept
147
149
  : BasicMember(other.GetRawStorage()) {
148
150
  other.Clear();
149
151
  }
@@ -151,8 +153,9 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
151
153
  template <typename U, typename OtherBarrierPolicy, typename OtherWeaknessTag,
152
154
  typename OtherCheckingPolicy,
153
155
  std::enable_if_t<internal::IsStrictlyBaseOfV<T, U>>* = nullptr>
154
- V8_INLINE BasicMember(BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy,
155
- OtherCheckingPolicy>&& other) noexcept
156
+ V8_INLINE BasicMember(
157
+ BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy, OtherCheckingPolicy,
158
+ StorageType>&& other) noexcept
156
159
  : BasicMember(other.Get()) {
157
160
  other.Clear();
158
161
  }
@@ -179,7 +182,7 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
179
182
  typename OtherCheckingPolicy>
180
183
  V8_INLINE BasicMember& operator=(
181
184
  const BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy,
182
- OtherCheckingPolicy>& other) {
185
+ OtherCheckingPolicy, StorageType>& other) {
183
186
  if constexpr (internal::IsDecayedSameV<T, U>) {
184
187
  return operator=(other.GetRawStorage());
185
188
  } else {
@@ -201,8 +204,8 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
201
204
  template <typename U, typename OtherWeaknessTag, typename OtherBarrierPolicy,
202
205
  typename OtherCheckingPolicy>
203
206
  V8_INLINE BasicMember& operator=(
204
- BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy,
205
- OtherCheckingPolicy>&& other) noexcept {
207
+ BasicMember<U, OtherWeaknessTag, OtherBarrierPolicy, OtherCheckingPolicy,
208
+ StorageType>&& other) noexcept {
206
209
  if constexpr (internal::IsDecayedSameV<T, U>) {
207
210
  operator=(other.GetRawStorage());
208
211
  } else {
@@ -226,7 +229,7 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
226
229
  }
227
230
 
228
231
  V8_INLINE BasicMember& operator=(T* other) {
229
- SetRawAtomic(other);
232
+ Base::SetRawAtomic(other);
230
233
  AssigningWriteBarrier(other);
231
234
  this->CheckPointer(Get());
232
235
  return *this;
@@ -237,20 +240,20 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
237
240
  return *this;
238
241
  }
239
242
  V8_INLINE BasicMember& operator=(SentinelPointer s) {
240
- SetRawAtomic(s);
243
+ Base::SetRawAtomic(s);
241
244
  return *this;
242
245
  }
243
246
 
244
247
  template <typename OtherWeaknessTag, typename OtherBarrierPolicy,
245
248
  typename OtherCheckingPolicy>
246
249
  V8_INLINE void Swap(BasicMember<T, OtherWeaknessTag, OtherBarrierPolicy,
247
- OtherCheckingPolicy>& other) {
250
+ OtherCheckingPolicy, StorageType>& other) {
248
251
  auto tmp = GetRawStorage();
249
252
  *this = other;
250
253
  other = tmp;
251
254
  }
252
255
 
253
- V8_INLINE explicit operator bool() const { return !IsCleared(); }
256
+ V8_INLINE explicit operator bool() const { return !Base::IsCleared(); }
254
257
  V8_INLINE operator T*() const { return Get(); }
255
258
  V8_INLINE T* operator->() const { return Get(); }
256
259
  V8_INLINE T& operator*() const { return *Get(); }
@@ -264,10 +267,12 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
264
267
  // The const_cast below removes the constness from MemberBase storage. The
265
268
  // following static_cast re-adds any constness if specified through the
266
269
  // user-visible template parameter T.
267
- return static_cast<T*>(const_cast<void*>(MemberBase::GetRaw()));
270
+ return static_cast<T*>(const_cast<void*>(Base::GetRaw()));
268
271
  }
269
272
 
270
- V8_INLINE void Clear() { SetRawStorageAtomic(RawStorage{}); }
273
+ V8_INLINE void Clear() {
274
+ Base::SetRawStorageAtomic(RawStorage{});
275
+ }
271
276
 
272
277
  V8_INLINE T* Release() {
273
278
  T* result = Get();
@@ -276,41 +281,44 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
276
281
  }
277
282
 
278
283
  V8_INLINE const T** GetSlotForTesting() const {
279
- return reinterpret_cast<const T**>(GetRawSlot());
284
+ return reinterpret_cast<const T**>(Base::GetRawSlot());
280
285
  }
281
286
 
282
287
  V8_INLINE RawStorage GetRawStorage() const {
283
- return MemberBase::GetRawStorage();
288
+ return Base::GetRawStorage();
284
289
  }
285
290
 
286
291
  private:
287
- V8_INLINE explicit BasicMember(RawStorage raw) : MemberBase(raw) {
292
+ V8_INLINE explicit BasicMember(RawStorage raw) : Base(raw) {
288
293
  InitializingWriteBarrier(Get());
289
294
  this->CheckPointer(Get());
290
295
  }
291
296
 
292
297
  V8_INLINE BasicMember& operator=(RawStorage other) {
293
- SetRawStorageAtomic(other);
298
+ Base::SetRawStorageAtomic(other);
294
299
  AssigningWriteBarrier();
295
300
  this->CheckPointer(Get());
296
301
  return *this;
297
302
  }
298
303
 
299
304
  V8_INLINE const T* GetRawAtomic() const {
300
- return static_cast<const T*>(MemberBase::GetRawAtomic());
305
+ return static_cast<const T*>(Base::GetRawAtomic());
301
306
  }
302
307
 
303
308
  V8_INLINE void InitializingWriteBarrier(T* value) const {
304
- WriteBarrierPolicy::InitializingBarrier(GetRawSlot(), value);
309
+ WriteBarrierPolicy::InitializingBarrier(Base::GetRawSlot(), value);
305
310
  }
306
311
  V8_INLINE void AssigningWriteBarrier(T* value) const {
307
- WriteBarrierPolicy::AssigningBarrier(GetRawSlot(), value);
312
+ WriteBarrierPolicy::template AssigningBarrier<
313
+ StorageType::kWriteBarrierSlotType>(Base::GetRawSlot(), value);
308
314
  }
309
315
  V8_INLINE void AssigningWriteBarrier() const {
310
- WriteBarrierPolicy::AssigningBarrier(GetRawSlot(), GetRawStorage());
316
+ WriteBarrierPolicy::template AssigningBarrier<
317
+ StorageType::kWriteBarrierSlotType>(Base::GetRawSlot(),
318
+ Base::GetRawStorage());
311
319
  }
312
320
 
313
- V8_INLINE void ClearFromGC() const { MemberBase::ClearFromGC(); }
321
+ V8_INLINE void ClearFromGC() const { Base::ClearFromGC(); }
314
322
 
315
323
  V8_INLINE T* GetFromGC() const { return Get(); }
316
324
 
@@ -319,19 +327,20 @@ class V8_TRIVIAL_ABI BasicMember final : private MemberBase,
319
327
  template <typename U>
320
328
  friend struct cppgc::TraceTrait;
321
329
  template <typename T1, typename WeaknessTag1, typename WriteBarrierPolicy1,
322
- typename CheckingPolicy1>
330
+ typename CheckingPolicy1, typename StorageType1>
323
331
  friend class BasicMember;
324
332
  };
325
333
 
326
334
  // Member equality operators.
327
335
  template <typename T1, typename WeaknessTag1, typename WriteBarrierPolicy1,
328
336
  typename CheckingPolicy1, typename T2, typename WeaknessTag2,
329
- typename WriteBarrierPolicy2, typename CheckingPolicy2>
337
+ typename WriteBarrierPolicy2, typename CheckingPolicy2,
338
+ typename StorageType>
330
339
  V8_INLINE bool operator==(
331
- const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1>&
332
- member1,
333
- const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2>&
334
- member2) {
340
+ const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1,
341
+ StorageType>& member1,
342
+ const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2,
343
+ StorageType>& member2) {
335
344
  if constexpr (internal::IsDecayedSameV<T1, T2>) {
336
345
  // Check compressed pointers if types are the same.
337
346
  return member1.GetRawStorage() == member2.GetRawStorage();
@@ -345,31 +354,32 @@ V8_INLINE bool operator==(
345
354
 
346
355
  template <typename T1, typename WeaknessTag1, typename WriteBarrierPolicy1,
347
356
  typename CheckingPolicy1, typename T2, typename WeaknessTag2,
348
- typename WriteBarrierPolicy2, typename CheckingPolicy2>
357
+ typename WriteBarrierPolicy2, typename CheckingPolicy2,
358
+ typename StorageType>
349
359
  V8_INLINE bool operator!=(
350
- const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1>&
351
- member1,
352
- const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2>&
353
- member2) {
360
+ const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1,
361
+ StorageType>& member1,
362
+ const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2,
363
+ StorageType>& member2) {
354
364
  return !(member1 == member2);
355
365
  }
356
366
 
357
367
  // Equality with raw pointers.
358
368
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
359
- typename CheckingPolicy, typename U>
360
- V8_INLINE bool operator==(const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
361
- CheckingPolicy>& member,
362
- U* raw) {
369
+ typename CheckingPolicy, typename StorageType, typename U>
370
+ V8_INLINE bool operator==(
371
+ const BasicMember<T, WeaknessTag, WriteBarrierPolicy, CheckingPolicy,
372
+ StorageType>& member,
373
+ U* raw) {
363
374
  // Never allow comparison with erased pointers.
364
375
  static_assert(!internal::IsDecayedSameV<void, U>);
365
376
 
366
377
  if constexpr (internal::IsDecayedSameV<T, U>) {
367
378
  // Check compressed pointers if types are the same.
368
- return member.GetRawStorage() == MemberBase::RawStorage(raw);
379
+ return member.GetRawStorage() == StorageType(raw);
369
380
  } else if constexpr (internal::IsStrictlyBaseOfV<T, U>) {
370
381
  // Cast the raw pointer to T, which may adjust the pointer.
371
- return member.GetRawStorage() ==
372
- MemberBase::RawStorage(static_cast<T*>(raw));
382
+ return member.GetRawStorage() == StorageType(static_cast<T*>(raw));
373
383
  } else {
374
384
  // Otherwise, decompressed the member.
375
385
  return member.Get() == raw;
@@ -377,104 +387,112 @@ V8_INLINE bool operator==(const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
377
387
  }
378
388
 
379
389
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
380
- typename CheckingPolicy, typename U>
381
- V8_INLINE bool operator!=(const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
382
- CheckingPolicy>& member,
383
- U* raw) {
390
+ typename CheckingPolicy, typename StorageType, typename U>
391
+ V8_INLINE bool operator!=(
392
+ const BasicMember<T, WeaknessTag, WriteBarrierPolicy, CheckingPolicy,
393
+ StorageType>& member,
394
+ U* raw) {
384
395
  return !(member == raw);
385
396
  }
386
397
 
387
398
  template <typename T, typename U, typename WeaknessTag,
388
- typename WriteBarrierPolicy, typename CheckingPolicy>
389
- V8_INLINE bool operator==(T* raw,
390
- const BasicMember<U, WeaknessTag, WriteBarrierPolicy,
391
- CheckingPolicy>& member) {
399
+ typename WriteBarrierPolicy, typename CheckingPolicy,
400
+ typename StorageType>
401
+ V8_INLINE bool operator==(
402
+ T* raw, const BasicMember<U, WeaknessTag, WriteBarrierPolicy,
403
+ CheckingPolicy, StorageType>& member) {
392
404
  return member == raw;
393
405
  }
394
406
 
395
407
  template <typename T, typename U, typename WeaknessTag,
396
- typename WriteBarrierPolicy, typename CheckingPolicy>
397
- V8_INLINE bool operator!=(T* raw,
398
- const BasicMember<U, WeaknessTag, WriteBarrierPolicy,
399
- CheckingPolicy>& member) {
408
+ typename WriteBarrierPolicy, typename CheckingPolicy,
409
+ typename StorageType>
410
+ V8_INLINE bool operator!=(
411
+ T* raw, const BasicMember<U, WeaknessTag, WriteBarrierPolicy,
412
+ CheckingPolicy, StorageType>& member) {
400
413
  return !(raw == member);
401
414
  }
402
415
 
403
416
  // Equality with sentinel.
404
417
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
405
- typename CheckingPolicy>
406
- V8_INLINE bool operator==(const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
407
- CheckingPolicy>& member,
408
- SentinelPointer) {
418
+ typename CheckingPolicy, typename StorageType>
419
+ V8_INLINE bool operator==(
420
+ const BasicMember<T, WeaknessTag, WriteBarrierPolicy, CheckingPolicy,
421
+ StorageType>& member,
422
+ SentinelPointer) {
409
423
  return member.GetRawStorage().IsSentinel();
410
424
  }
411
425
 
412
426
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
413
- typename CheckingPolicy>
414
- V8_INLINE bool operator!=(const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
415
- CheckingPolicy>& member,
416
- SentinelPointer s) {
427
+ typename CheckingPolicy, typename StorageType>
428
+ V8_INLINE bool operator!=(
429
+ const BasicMember<T, WeaknessTag, WriteBarrierPolicy, CheckingPolicy,
430
+ StorageType>& member,
431
+ SentinelPointer s) {
417
432
  return !(member == s);
418
433
  }
419
434
 
420
435
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
421
- typename CheckingPolicy>
422
- V8_INLINE bool operator==(SentinelPointer s,
423
- const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
424
- CheckingPolicy>& member) {
436
+ typename CheckingPolicy, typename StorageType>
437
+ V8_INLINE bool operator==(
438
+ SentinelPointer s, const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
439
+ CheckingPolicy, StorageType>& member) {
425
440
  return member == s;
426
441
  }
427
442
 
428
443
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
429
- typename CheckingPolicy>
430
- V8_INLINE bool operator!=(SentinelPointer s,
431
- const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
432
- CheckingPolicy>& member) {
444
+ typename CheckingPolicy, typename StorageType>
445
+ V8_INLINE bool operator!=(
446
+ SentinelPointer s, const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
447
+ CheckingPolicy, StorageType>& member) {
433
448
  return !(s == member);
434
449
  }
435
450
 
436
451
  // Equality with nullptr.
437
452
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
438
- typename CheckingPolicy>
439
- V8_INLINE bool operator==(const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
440
- CheckingPolicy>& member,
441
- std::nullptr_t) {
453
+ typename CheckingPolicy, typename StorageType>
454
+ V8_INLINE bool operator==(
455
+ const BasicMember<T, WeaknessTag, WriteBarrierPolicy, CheckingPolicy,
456
+ StorageType>& member,
457
+ std::nullptr_t) {
442
458
  return !static_cast<bool>(member);
443
459
  }
444
460
 
445
461
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
446
- typename CheckingPolicy>
447
- V8_INLINE bool operator!=(const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
448
- CheckingPolicy>& member,
449
- std::nullptr_t n) {
462
+ typename CheckingPolicy, typename StorageType>
463
+ V8_INLINE bool operator!=(
464
+ const BasicMember<T, WeaknessTag, WriteBarrierPolicy, CheckingPolicy,
465
+ StorageType>& member,
466
+ std::nullptr_t n) {
450
467
  return !(member == n);
451
468
  }
452
469
 
453
470
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
454
- typename CheckingPolicy>
455
- V8_INLINE bool operator==(std::nullptr_t n,
456
- const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
457
- CheckingPolicy>& member) {
471
+ typename CheckingPolicy, typename StorageType>
472
+ V8_INLINE bool operator==(
473
+ std::nullptr_t n, const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
474
+ CheckingPolicy, StorageType>& member) {
458
475
  return member == n;
459
476
  }
460
477
 
461
478
  template <typename T, typename WeaknessTag, typename WriteBarrierPolicy,
462
- typename CheckingPolicy>
463
- V8_INLINE bool operator!=(std::nullptr_t n,
464
- const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
465
- CheckingPolicy>& member) {
479
+ typename CheckingPolicy, typename StorageType>
480
+ V8_INLINE bool operator!=(
481
+ std::nullptr_t n, const BasicMember<T, WeaknessTag, WriteBarrierPolicy,
482
+ CheckingPolicy, StorageType>& member) {
466
483
  return !(n == member);
467
484
  }
468
485
 
469
486
  // Relational operators.
470
487
  template <typename T1, typename WeaknessTag1, typename WriteBarrierPolicy1,
471
488
  typename CheckingPolicy1, typename T2, typename WeaknessTag2,
472
- typename WriteBarrierPolicy2, typename CheckingPolicy2>
489
+ typename WriteBarrierPolicy2, typename CheckingPolicy2,
490
+ typename StorageType>
473
491
  V8_INLINE bool operator<(
474
- const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1>&
475
- member1,
476
- const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2>&
477
- member2) {
492
+ const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1,
493
+ StorageType>& member1,
494
+ const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2,
495
+ StorageType>& member2) {
478
496
  static_assert(
479
497
  internal::IsDecayedSameV<T1, T2>,
480
498
  "Comparison works only for same pointer type modulo cv-qualifiers");
@@ -483,12 +501,13 @@ V8_INLINE bool operator<(
483
501
 
484
502
  template <typename T1, typename WeaknessTag1, typename WriteBarrierPolicy1,
485
503
  typename CheckingPolicy1, typename T2, typename WeaknessTag2,
486
- typename WriteBarrierPolicy2, typename CheckingPolicy2>
504
+ typename WriteBarrierPolicy2, typename CheckingPolicy2,
505
+ typename StorageType>
487
506
  V8_INLINE bool operator<=(
488
- const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1>&
489
- member1,
490
- const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2>&
491
- member2) {
507
+ const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1,
508
+ StorageType>& member1,
509
+ const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2,
510
+ StorageType>& member2) {
492
511
  static_assert(
493
512
  internal::IsDecayedSameV<T1, T2>,
494
513
  "Comparison works only for same pointer type modulo cv-qualifiers");
@@ -497,12 +516,13 @@ V8_INLINE bool operator<=(
497
516
 
498
517
  template <typename T1, typename WeaknessTag1, typename WriteBarrierPolicy1,
499
518
  typename CheckingPolicy1, typename T2, typename WeaknessTag2,
500
- typename WriteBarrierPolicy2, typename CheckingPolicy2>
519
+ typename WriteBarrierPolicy2, typename CheckingPolicy2,
520
+ typename StorageType>
501
521
  V8_INLINE bool operator>(
502
- const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1>&
503
- member1,
504
- const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2>&
505
- member2) {
522
+ const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1,
523
+ StorageType>& member1,
524
+ const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2,
525
+ StorageType>& member2) {
506
526
  static_assert(
507
527
  internal::IsDecayedSameV<T1, T2>,
508
528
  "Comparison works only for same pointer type modulo cv-qualifiers");
@@ -511,21 +531,23 @@ V8_INLINE bool operator>(
511
531
 
512
532
  template <typename T1, typename WeaknessTag1, typename WriteBarrierPolicy1,
513
533
  typename CheckingPolicy1, typename T2, typename WeaknessTag2,
514
- typename WriteBarrierPolicy2, typename CheckingPolicy2>
534
+ typename WriteBarrierPolicy2, typename CheckingPolicy2,
535
+ typename StorageType>
515
536
  V8_INLINE bool operator>=(
516
- const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1>&
517
- member1,
518
- const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2>&
519
- member2) {
537
+ const BasicMember<T1, WeaknessTag1, WriteBarrierPolicy1, CheckingPolicy1,
538
+ StorageType>& member1,
539
+ const BasicMember<T2, WeaknessTag2, WriteBarrierPolicy2, CheckingPolicy2,
540
+ StorageType>& member2) {
520
541
  static_assert(
521
542
  internal::IsDecayedSameV<T1, T2>,
522
543
  "Comparison works only for same pointer type modulo cv-qualifiers");
523
544
  return member1.GetRawStorage() >= member2.GetRawStorage();
524
545
  }
525
546
 
526
- template <typename T, typename WriteBarrierPolicy, typename CheckingPolicy>
527
- struct IsWeak<
528
- internal::BasicMember<T, WeakMemberTag, WriteBarrierPolicy, CheckingPolicy>>
547
+ template <typename T, typename WriteBarrierPolicy, typename CheckingPolicy,
548
+ typename StorageType>
549
+ struct IsWeak<internal::BasicMember<T, WeakMemberTag, WriteBarrierPolicy,
550
+ CheckingPolicy, StorageType>>
529
551
  : std::true_type {};
530
552
 
531
553
  } // namespace internal
@@ -536,8 +558,9 @@ struct IsWeak<
536
558
  * trace method.
537
559
  */
538
560
  template <typename T>
539
- using Member = internal::BasicMember<T, internal::StrongMemberTag,
540
- internal::DijkstraWriteBarrierPolicy>;
561
+ using Member = internal::BasicMember<
562
+ T, internal::StrongMemberTag, internal::DijkstraWriteBarrierPolicy,
563
+ internal::DefaultMemberCheckingPolicy, internal::DefaultMemberStorage>;
541
564
 
542
565
  /**
543
566
  * WeakMember is similar to Member in that it is used to point to other garbage
@@ -548,8 +571,9 @@ using Member = internal::BasicMember<T, internal::StrongMemberTag,
548
571
  * will automatically be set to null.
549
572
  */
550
573
  template <typename T>
551
- using WeakMember = internal::BasicMember<T, internal::WeakMemberTag,
552
- internal::DijkstraWriteBarrierPolicy>;
574
+ using WeakMember = internal::BasicMember<
575
+ T, internal::WeakMemberTag, internal::DijkstraWriteBarrierPolicy,
576
+ internal::DefaultMemberCheckingPolicy, internal::DefaultMemberStorage>;
553
577
 
554
578
  /**
555
579
  * UntracedMember is a pointer to an on-heap object that is not traced for some
@@ -558,8 +582,22 @@ using WeakMember = internal::BasicMember<T, internal::WeakMemberTag,
558
582
  * must be kept alive through other means.
559
583
  */
560
584
  template <typename T>
561
- using UntracedMember = internal::BasicMember<T, internal::UntracedMemberTag,
562
- internal::NoWriteBarrierPolicy>;
585
+ using UntracedMember = internal::BasicMember<
586
+ T, internal::UntracedMemberTag, internal::NoWriteBarrierPolicy,
587
+ internal::DefaultMemberCheckingPolicy, internal::DefaultMemberStorage>;
588
+
589
+ namespace subtle {
590
+
591
+ /**
592
+ * UncompressedMember. Use with care in hot paths that would otherwise cause
593
+ * many decompression cycles.
594
+ */
595
+ template <typename T>
596
+ using UncompressedMember = internal::BasicMember<
597
+ T, internal::StrongMemberTag, internal::DijkstraWriteBarrierPolicy,
598
+ internal::DefaultMemberCheckingPolicy, internal::RawPointer>;
599
+
600
+ } // namespace subtle
563
601
 
564
602
  } // namespace cppgc
565
603
 
@@ -114,11 +114,12 @@ class BasicPersistent final : public PersistentBase,
114
114
  // Constructor from member.
115
115
  template <typename U, typename MemberBarrierPolicy,
116
116
  typename MemberWeaknessTag, typename MemberCheckingPolicy,
117
+ typename MemberStorageType,
117
118
  typename = std::enable_if_t<std::is_base_of<T, U>::value>>
118
- BasicPersistent(
119
- const internal::BasicMember<U, MemberBarrierPolicy, MemberWeaknessTag,
120
- MemberCheckingPolicy>& member,
121
- const SourceLocation& loc = SourceLocation::Current())
119
+ BasicPersistent(const internal::BasicMember<
120
+ U, MemberBarrierPolicy, MemberWeaknessTag,
121
+ MemberCheckingPolicy, MemberStorageType>& member,
122
+ const SourceLocation& loc = SourceLocation::Current())
122
123
  : BasicPersistent(member.Get(), loc) {}
123
124
 
124
125
  ~BasicPersistent() { Clear(); }
@@ -154,10 +155,12 @@ class BasicPersistent final : public PersistentBase,
154
155
  // Assignment from member.
155
156
  template <typename U, typename MemberBarrierPolicy,
156
157
  typename MemberWeaknessTag, typename MemberCheckingPolicy,
158
+ typename MemberStorageType,
157
159
  typename = std::enable_if_t<std::is_base_of<T, U>::value>>
158
160
  BasicPersistent& operator=(
159
161
  const internal::BasicMember<U, MemberBarrierPolicy, MemberWeaknessTag,
160
- MemberCheckingPolicy>& member) {
162
+ MemberCheckingPolicy, MemberStorageType>&
163
+ member) {
161
164
  return operator=(member.Get());
162
165
  }
163
166
 
@@ -286,36 +289,39 @@ bool operator!=(const BasicPersistent<T1, WeaknessPolicy1, LocationPolicy1,
286
289
  template <typename T1, typename PersistentWeaknessPolicy,
287
290
  typename PersistentLocationPolicy, typename PersistentCheckingPolicy,
288
291
  typename T2, typename MemberWriteBarrierPolicy,
289
- typename MemberWeaknessTag, typename MemberCheckingPolicy>
292
+ typename MemberWeaknessTag, typename MemberCheckingPolicy,
293
+ typename MemberStorageType>
290
294
  bool operator==(
291
295
  const BasicPersistent<T1, PersistentWeaknessPolicy,
292
296
  PersistentLocationPolicy, PersistentCheckingPolicy>&
293
297
  p,
294
298
  const BasicMember<T2, MemberWeaknessTag, MemberWriteBarrierPolicy,
295
- MemberCheckingPolicy>& m) {
299
+ MemberCheckingPolicy, MemberStorageType>& m) {
296
300
  return p.Get() == m.Get();
297
301
  }
298
302
 
299
303
  template <typename T1, typename PersistentWeaknessPolicy,
300
304
  typename PersistentLocationPolicy, typename PersistentCheckingPolicy,
301
305
  typename T2, typename MemberWriteBarrierPolicy,
302
- typename MemberWeaknessTag, typename MemberCheckingPolicy>
306
+ typename MemberWeaknessTag, typename MemberCheckingPolicy,
307
+ typename MemberStorageType>
303
308
  bool operator!=(
304
309
  const BasicPersistent<T1, PersistentWeaknessPolicy,
305
310
  PersistentLocationPolicy, PersistentCheckingPolicy>&
306
311
  p,
307
312
  const BasicMember<T2, MemberWeaknessTag, MemberWriteBarrierPolicy,
308
- MemberCheckingPolicy>& m) {
313
+ MemberCheckingPolicy, MemberStorageType>& m) {
309
314
  return !(p == m);
310
315
  }
311
316
 
312
317
  template <typename T1, typename MemberWriteBarrierPolicy,
313
318
  typename MemberWeaknessTag, typename MemberCheckingPolicy,
314
- typename T2, typename PersistentWeaknessPolicy,
315
- typename PersistentLocationPolicy, typename PersistentCheckingPolicy>
319
+ typename MemberStorageType, typename T2,
320
+ typename PersistentWeaknessPolicy, typename PersistentLocationPolicy,
321
+ typename PersistentCheckingPolicy>
316
322
  bool operator==(
317
323
  const BasicMember<T2, MemberWeaknessTag, MemberWriteBarrierPolicy,
318
- MemberCheckingPolicy>& m,
324
+ MemberCheckingPolicy, MemberStorageType>& m,
319
325
  const BasicPersistent<T1, PersistentWeaknessPolicy,
320
326
  PersistentLocationPolicy, PersistentCheckingPolicy>&
321
327
  p) {
@@ -324,11 +330,12 @@ bool operator==(
324
330
 
325
331
  template <typename T1, typename MemberWriteBarrierPolicy,
326
332
  typename MemberWeaknessTag, typename MemberCheckingPolicy,
327
- typename T2, typename PersistentWeaknessPolicy,
328
- typename PersistentLocationPolicy, typename PersistentCheckingPolicy>
333
+ typename MemberStorageType, typename T2,
334
+ typename PersistentWeaknessPolicy, typename PersistentLocationPolicy,
335
+ typename PersistentCheckingPolicy>
329
336
  bool operator!=(
330
337
  const BasicMember<T2, MemberWeaknessTag, MemberWriteBarrierPolicy,
331
- MemberCheckingPolicy>& m,
338
+ MemberCheckingPolicy, MemberStorageType>& m,
332
339
  const BasicPersistent<T1, PersistentWeaknessPolicy,
333
340
  PersistentLocationPolicy, PersistentCheckingPolicy>&
334
341
  p) {