libv8-node 18.13.0.1-arm64-darwin → 20.2.0.0-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 (70) 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/common.h +0 -1
  5. data/vendor/v8/include/cppgc/cross-thread-persistent.h +11 -10
  6. data/vendor/v8/include/cppgc/heap-consistency.h +46 -3
  7. data/vendor/v8/include/cppgc/heap-handle.h +48 -0
  8. data/vendor/v8/include/cppgc/heap-statistics.h +2 -2
  9. data/vendor/v8/include/cppgc/heap.h +3 -7
  10. data/vendor/v8/include/cppgc/internal/api-constants.h +14 -1
  11. data/vendor/v8/include/cppgc/internal/base-page-handle.h +45 -0
  12. data/vendor/v8/include/cppgc/internal/caged-heap-local-data.h +40 -8
  13. data/vendor/v8/include/cppgc/internal/caged-heap.h +61 -0
  14. data/vendor/v8/include/cppgc/internal/gc-info.h +35 -34
  15. data/vendor/v8/include/cppgc/internal/member-storage.h +248 -0
  16. data/vendor/v8/include/cppgc/internal/name-trait.h +21 -6
  17. data/vendor/v8/include/cppgc/internal/persistent-node.h +11 -13
  18. data/vendor/v8/include/cppgc/internal/pointer-policies.h +65 -8
  19. data/vendor/v8/include/cppgc/internal/write-barrier.h +153 -101
  20. data/vendor/v8/include/cppgc/liveness-broker.h +8 -7
  21. data/vendor/v8/include/cppgc/macros.h +10 -1
  22. data/vendor/v8/include/cppgc/member.h +424 -111
  23. data/vendor/v8/include/cppgc/name-provider.h +4 -4
  24. data/vendor/v8/include/cppgc/persistent.h +27 -24
  25. data/vendor/v8/include/cppgc/platform.h +7 -5
  26. data/vendor/v8/include/cppgc/sentinel-pointer.h +1 -1
  27. data/vendor/v8/include/cppgc/trace-trait.h +4 -0
  28. data/vendor/v8/include/cppgc/type-traits.h +13 -3
  29. data/vendor/v8/include/cppgc/visitor.h +104 -57
  30. data/vendor/v8/include/libplatform/v8-tracing.h +2 -2
  31. data/vendor/v8/include/v8-array-buffer.h +59 -0
  32. data/vendor/v8/include/v8-callbacks.h +32 -5
  33. data/vendor/v8/include/v8-context.h +63 -11
  34. data/vendor/v8/include/v8-cppgc.h +22 -0
  35. data/vendor/v8/include/v8-data.h +1 -1
  36. data/vendor/v8/include/v8-date.h +5 -0
  37. data/vendor/v8/include/v8-embedder-heap.h +0 -164
  38. data/vendor/v8/include/v8-exception.h +1 -1
  39. data/vendor/v8/include/v8-fast-api-calls.h +49 -31
  40. data/vendor/v8/include/v8-function-callback.h +69 -42
  41. data/vendor/v8/include/v8-function.h +9 -0
  42. data/vendor/v8/include/v8-initialization.h +23 -49
  43. data/vendor/v8/include/v8-inspector.h +32 -11
  44. data/vendor/v8/include/v8-internal.h +480 -183
  45. data/vendor/v8/include/v8-isolate.h +52 -77
  46. data/vendor/v8/include/v8-local-handle.h +86 -53
  47. data/vendor/v8/include/v8-locker.h +0 -11
  48. data/vendor/v8/include/v8-maybe.h +24 -1
  49. data/vendor/v8/include/v8-message.h +2 -4
  50. data/vendor/v8/include/v8-metrics.h +48 -40
  51. data/vendor/v8/include/v8-microtask-queue.h +6 -1
  52. data/vendor/v8/include/v8-object.h +29 -18
  53. data/vendor/v8/include/v8-persistent-handle.h +25 -18
  54. data/vendor/v8/include/v8-platform.h +133 -35
  55. data/vendor/v8/include/v8-primitive.h +27 -20
  56. data/vendor/v8/include/v8-profiler.h +133 -53
  57. data/vendor/v8/include/v8-regexp.h +2 -1
  58. data/vendor/v8/include/v8-script.h +91 -7
  59. data/vendor/v8/include/v8-snapshot.h +4 -8
  60. data/vendor/v8/include/v8-template.h +16 -77
  61. data/vendor/v8/include/v8-traced-handle.h +22 -28
  62. data/vendor/v8/include/v8-unwinder-state.h +4 -4
  63. data/vendor/v8/include/v8-util.h +11 -7
  64. data/vendor/v8/include/v8-value-serializer.h +46 -23
  65. data/vendor/v8/include/v8-value.h +31 -4
  66. data/vendor/v8/include/v8-version.h +4 -4
  67. data/vendor/v8/include/v8-wasm.h +7 -63
  68. data/vendor/v8/include/v8-weak-callback-info.h +0 -7
  69. data/vendor/v8/include/v8config.h +353 -15
  70. metadata +5 -1
@@ -5,9 +5,11 @@
5
5
  #ifndef V8_V8_PLATFORM_H_
6
6
  #define V8_V8_PLATFORM_H_
7
7
 
8
+ #include <math.h>
8
9
  #include <stddef.h>
9
10
  #include <stdint.h>
10
11
  #include <stdlib.h> // For abort.
12
+
11
13
  #include <memory>
12
14
  #include <string>
13
15
 
@@ -158,9 +160,10 @@ class TaskRunner {
158
160
  class JobDelegate {
159
161
  public:
160
162
  /**
161
- * Returns true if this thread should return from the worker task on the
163
+ * Returns true if this thread *must* return from the worker task on the
162
164
  * current thread ASAP. Workers should periodically invoke ShouldYield (or
163
165
  * YieldIfNeeded()) as often as is reasonable.
166
+ * After this method returned true, ShouldYield must not be called again.
164
167
  */
165
168
  virtual bool ShouldYield() = 0;
166
169
 
@@ -264,6 +267,38 @@ class JobTask {
264
267
  virtual size_t GetMaxConcurrency(size_t worker_count) const = 0;
265
268
  };
266
269
 
270
+ /**
271
+ * A "blocking call" refers to any call that causes the calling thread to wait
272
+ * off-CPU. It includes but is not limited to calls that wait on synchronous
273
+ * file I/O operations: read or write a file from disk, interact with a pipe or
274
+ * a socket, rename or delete a file, enumerate files in a directory, etc.
275
+ * Acquiring a low contention lock is not considered a blocking call.
276
+ */
277
+
278
+ /**
279
+ * BlockingType indicates the likelihood that a blocking call will actually
280
+ * block.
281
+ */
282
+ enum class BlockingType {
283
+ // The call might block (e.g. file I/O that might hit in memory cache).
284
+ kMayBlock,
285
+ // The call will definitely block (e.g. cache already checked and now pinging
286
+ // server synchronously).
287
+ kWillBlock
288
+ };
289
+
290
+ /**
291
+ * This class is instantiated with CreateBlockingScope() in every scope where a
292
+ * blocking call is made and serves as a precise annotation of the scope that
293
+ * may/will block. May be implemented by an embedder to adjust the thread count.
294
+ * CPU usage should be minimal within that scope. ScopedBlockingCalls can be
295
+ * nested.
296
+ */
297
+ class ScopedBlockingCall {
298
+ public:
299
+ virtual ~ScopedBlockingCall() = default;
300
+ };
301
+
267
302
  /**
268
303
  * The interface represents complex arguments to trace events.
269
304
  */
@@ -284,6 +319,8 @@ class ConvertableToTraceFormat {
284
319
  * V8 Tracing controller.
285
320
  *
286
321
  * Can be implemented by an embedder to record trace events from V8.
322
+ *
323
+ * Will become obsolete in Perfetto SDK build (v8_use_perfetto = true).
287
324
  */
288
325
  class TracingController {
289
326
  public:
@@ -347,10 +384,16 @@ class TracingController {
347
384
  virtual void OnTraceDisabled() = 0;
348
385
  };
349
386
 
350
- /** Adds tracing state change observer. */
387
+ /**
388
+ * Adds tracing state change observer.
389
+ * Does nothing in Perfetto SDK build (v8_use_perfetto = true).
390
+ */
351
391
  virtual void AddTraceStateObserver(TraceStateObserver*) {}
352
392
 
353
- /** Removes tracing state change observer. */
393
+ /**
394
+ * Removes tracing state change observer.
395
+ * Does nothing in Perfetto SDK build (v8_use_perfetto = true).
396
+ */
354
397
  virtual void RemoveTraceStateObserver(TraceStateObserver*) {}
355
398
  };
356
399
 
@@ -429,6 +472,17 @@ class PageAllocator {
429
472
  virtual bool SetPermissions(void* address, size_t length,
430
473
  Permission permissions) = 0;
431
474
 
475
+ /**
476
+ * Recommits discarded pages in the given range with given permissions.
477
+ * Discarded pages must be recommitted with their original permissions
478
+ * before they are used again.
479
+ */
480
+ virtual bool RecommitPages(void* address, size_t length,
481
+ Permission permissions) {
482
+ // TODO(v8:12797): make it pure once it's implemented on Chromium side.
483
+ return false;
484
+ }
485
+
432
486
  /**
433
487
  * Frees memory in the given [address, address + size) range. address and size
434
488
  * should be operating system page-aligned. The next write to this
@@ -522,7 +576,7 @@ static constexpr PlatformSharedMemoryHandle kInvalidSharedMemoryHandle = -1;
522
576
  // to avoid pulling in large OS header files into this header file. Instead,
523
577
  // the users of these routines are expected to include the respecitve OS
524
578
  // headers in addition to this one.
525
- #if V8_OS_MACOS
579
+ #if V8_OS_DARWIN
526
580
  // Convert between a shared memory handle and a mach_port_t referencing a memory
527
581
  // entry object.
528
582
  inline PlatformSharedMemoryHandle SharedMemoryHandleFromMachMemoryEntry(
@@ -698,6 +752,10 @@ class VirtualAddressSpace {
698
752
  /**
699
753
  * Sets permissions of all allocated pages in the given range.
700
754
  *
755
+ * This operation can fail due to OOM, in which case false is returned. If
756
+ * the operation fails for a reason other than OOM, this function will
757
+ * terminate the process as this implies a bug in the client.
758
+ *
701
759
  * \param address The start address of the range. Must be aligned to
702
760
  * page_size().
703
761
  *
@@ -706,7 +764,7 @@ class VirtualAddressSpace {
706
764
  *
707
765
  * \param permissions The new permissions for the range.
708
766
  *
709
- * \returns true on success, false otherwise.
767
+ * \returns true on success, false on OOM.
710
768
  */
711
769
  virtual V8_WARN_UNUSED_RESULT bool SetPagePermissions(
712
770
  Address address, size_t size, PagePermissions permissions) = 0;
@@ -820,6 +878,24 @@ class VirtualAddressSpace {
820
878
  // takes a command enum as parameter.
821
879
  //
822
880
 
881
+ /**
882
+ * Recommits discarded pages in the given range with given permissions.
883
+ * Discarded pages must be recommitted with their original permissions
884
+ * before they are used again.
885
+ *
886
+ * \param address The start address of the range. Must be aligned to
887
+ * page_size().
888
+ *
889
+ * \param size The size in bytes of the range. Must be a multiple
890
+ * of page_size().
891
+ *
892
+ * \param permissions The permissions for the range that the pages must have.
893
+ *
894
+ * \returns true on success, false otherwise.
895
+ */
896
+ virtual V8_WARN_UNUSED_RESULT bool RecommitPages(
897
+ Address address, size_t size, PagePermissions permissions) = 0;
898
+
823
899
  /**
824
900
  * Frees memory in the given [address, address + size) range. address and
825
901
  * size should be aligned to the page_size(). The next write to this memory
@@ -889,11 +965,9 @@ class Platform {
889
965
 
890
966
  /**
891
967
  * Allows the embedder to manage memory page allocations.
968
+ * Returning nullptr will cause V8 to use the default page allocator.
892
969
  */
893
- virtual PageAllocator* GetPageAllocator() {
894
- // TODO(bbudge) Make this abstract after all embedders implement this.
895
- return nullptr;
896
- }
970
+ virtual PageAllocator* GetPageAllocator() = 0;
897
971
 
898
972
  /**
899
973
  * Allows the embedder to specify a custom allocator used for zones.
@@ -910,28 +984,15 @@ class Platform {
910
984
  * error.
911
985
  * Embedder overrides of this function must NOT call back into V8.
912
986
  */
913
- virtual void OnCriticalMemoryPressure() {
914
- // TODO(bbudge) Remove this when embedders override the following method.
915
- // See crbug.com/634547.
916
- }
987
+ virtual void OnCriticalMemoryPressure() {}
917
988
 
918
989
  /**
919
- * Enables the embedder to respond in cases where V8 can't allocate large
920
- * memory regions. The |length| parameter is the amount of memory needed.
921
- * Returns true if memory is now available. Returns false if no memory could
922
- * be made available. V8 will retry allocations until this method returns
923
- * false.
924
- *
925
- * Embedder overrides of this function must NOT call back into V8.
926
- */
927
- virtual bool OnCriticalMemoryPressure(size_t length) { return false; }
928
-
929
- /**
930
- * Gets the number of worker threads used by
931
- * Call(BlockingTask)OnWorkerThread(). This can be used to estimate the number
932
- * of tasks a work package should be split into. A return value of 0 means
933
- * that there are no worker threads available. Note that a value of 0 won't
934
- * prohibit V8 from posting tasks using |CallOnWorkerThread|.
990
+ * Gets the max number of worker threads that may be used to execute
991
+ * concurrent work scheduled for any single TaskPriority by
992
+ * Call(BlockingTask)OnWorkerThread() or PostJob(). This can be used to
993
+ * estimate the number of tasks a work package should be split into. A return
994
+ * value of 0 means that there are no worker threads available. Note that a
995
+ * value of 0 won't prohibit V8 from posting tasks using |CallOnWorkerThread|.
935
996
  */
936
997
  virtual int NumberOfWorkerThreads() = 0;
937
998
 
@@ -1022,18 +1083,38 @@ class Platform {
1022
1083
  * thread (A=>B/B=>A deadlock) and [2] JobTask::Run or
1023
1084
  * JobTask::GetMaxConcurrency may be invoked synchronously from JobHandle
1024
1085
  * (B=>JobHandle::foo=>B deadlock).
1086
+ */
1087
+ virtual std::unique_ptr<JobHandle> PostJob(
1088
+ TaskPriority priority, std::unique_ptr<JobTask> job_task) {
1089
+ auto handle = CreateJob(priority, std::move(job_task));
1090
+ handle->NotifyConcurrencyIncrease();
1091
+ return handle;
1092
+ }
1093
+
1094
+ /**
1095
+ * Creates and returns a JobHandle associated with a Job. Unlike PostJob(),
1096
+ * this doesn't immediately schedules |worker_task| to run; the Job is then
1097
+ * scheduled by calling either NotifyConcurrencyIncrease() or Join().
1025
1098
  *
1026
- * A sufficient PostJob() implementation that uses the default Job provided in
1027
- * libplatform looks like:
1028
- * std::unique_ptr<JobHandle> PostJob(
1099
+ * A sufficient CreateJob() implementation that uses the default Job provided
1100
+ * in libplatform looks like:
1101
+ * std::unique_ptr<JobHandle> CreateJob(
1029
1102
  * TaskPriority priority, std::unique_ptr<JobTask> job_task) override {
1030
1103
  * return v8::platform::NewDefaultJobHandle(
1031
1104
  * this, priority, std::move(job_task), NumberOfWorkerThreads());
1032
1105
  * }
1033
1106
  */
1034
- virtual std::unique_ptr<JobHandle> PostJob(
1107
+ virtual std::unique_ptr<JobHandle> CreateJob(
1035
1108
  TaskPriority priority, std::unique_ptr<JobTask> job_task) = 0;
1036
1109
 
1110
+ /**
1111
+ * Instantiates a ScopedBlockingCall to annotate a scope that may/will block.
1112
+ */
1113
+ virtual std::unique_ptr<ScopedBlockingCall> CreateBlockingScope(
1114
+ BlockingType blocking_type) {
1115
+ return nullptr;
1116
+ }
1117
+
1037
1118
  /**
1038
1119
  * Monotonically increasing time in seconds from an arbitrary fixed point in
1039
1120
  * the past. This function is expected to return at least
@@ -1044,11 +1125,28 @@ class Platform {
1044
1125
  virtual double MonotonicallyIncreasingTime() = 0;
1045
1126
 
1046
1127
  /**
1047
- * Current wall-clock time in milliseconds since epoch.
1048
- * This function is expected to return at least millisecond-precision values.
1128
+ * Current wall-clock time in milliseconds since epoch. Use
1129
+ * CurrentClockTimeMillisHighResolution() when higher precision is
1130
+ * required.
1131
+ */
1132
+ virtual int64_t CurrentClockTimeMilliseconds() {
1133
+ return floor(CurrentClockTimeMillis());
1134
+ }
1135
+
1136
+ /**
1137
+ * This function is deprecated and will be deleted. Use either
1138
+ * CurrentClockTimeMilliseconds() or
1139
+ * CurrentClockTimeMillisecondsHighResolution().
1049
1140
  */
1050
1141
  virtual double CurrentClockTimeMillis() = 0;
1051
1142
 
1143
+ /**
1144
+ * Same as CurrentClockTimeMilliseconds(), but with more precision.
1145
+ */
1146
+ virtual double CurrentClockTimeMillisecondsHighResolution() {
1147
+ return CurrentClockTimeMillis();
1148
+ }
1149
+
1052
1150
  typedef void (*StackTracePrinter)();
1053
1151
 
1054
1152
  /**
@@ -20,6 +20,7 @@ class String;
20
20
  namespace internal {
21
21
  class ExternalString;
22
22
  class ScopedExternalStringLock;
23
+ class StringForwardingTable;
23
24
  } // namespace internal
24
25
 
25
26
  /**
@@ -269,6 +270,7 @@ class V8_EXPORT String : public Name {
269
270
  private:
270
271
  friend class internal::ExternalString;
271
272
  friend class v8::String;
273
+ friend class internal::StringForwardingTable;
272
274
  friend class internal::ScopedExternalStringLock;
273
275
  };
274
276
 
@@ -491,8 +493,15 @@ class V8_EXPORT String : public Name {
491
493
  /**
492
494
  * Returns true if this string can be made external.
493
495
  */
496
+ V8_DEPRECATE_SOON("Use the version that takes an encoding as argument.")
494
497
  bool CanMakeExternal() const;
495
498
 
499
+ /**
500
+ * Returns true if this string can be made external, given the encoding for
501
+ * the external string resource.
502
+ */
503
+ bool CanMakeExternal(Encoding encoding) const;
504
+
496
505
  /**
497
506
  * Returns true if the strings values are equal. Same as JS ==/===.
498
507
  */
@@ -774,21 +783,20 @@ Local<String> String::Empty(Isolate* isolate) {
774
783
  using S = internal::Address;
775
784
  using I = internal::Internals;
776
785
  I::CheckInitialized(isolate);
777
- S* slot = I::GetRoot(isolate, I::kEmptyStringRootIndex);
778
- return Local<String>(reinterpret_cast<String*>(slot));
786
+ S* slot = I::GetRootSlot(isolate, I::kEmptyStringRootIndex);
787
+ return Local<String>::FromSlot(slot);
779
788
  }
780
789
 
781
790
  String::ExternalStringResource* String::GetExternalStringResource() const {
782
791
  using A = internal::Address;
783
792
  using I = internal::Internals;
784
- A obj = *reinterpret_cast<const A*>(this);
793
+ A obj = internal::ValueHelper::ValueAsAddress(this);
785
794
 
786
795
  ExternalStringResource* result;
787
796
  if (I::IsExternalTwoByteString(I::GetInstanceType(obj))) {
788
- internal::Isolate* isolate = I::GetIsolateForSandbox(obj);
789
- A value =
790
- I::ReadExternalPointerField(isolate, obj, I::kStringResourceOffset,
791
- internal::kExternalStringResourceTag);
797
+ Isolate* isolate = I::GetIsolateForSandbox(obj);
798
+ A value = I::ReadExternalPointerField<internal::kExternalStringResourceTag>(
799
+ isolate, obj, I::kStringResourceOffset);
792
800
  result = reinterpret_cast<String::ExternalStringResource*>(value);
793
801
  } else {
794
802
  result = GetExternalStringResourceSlow();
@@ -803,16 +811,15 @@ String::ExternalStringResourceBase* String::GetExternalStringResourceBase(
803
811
  String::Encoding* encoding_out) const {
804
812
  using A = internal::Address;
805
813
  using I = internal::Internals;
806
- A obj = *reinterpret_cast<const A*>(this);
814
+ A obj = internal::ValueHelper::ValueAsAddress(this);
807
815
  int type = I::GetInstanceType(obj) & I::kStringRepresentationAndEncodingMask;
808
816
  *encoding_out = static_cast<Encoding>(type & I::kStringEncodingMask);
809
817
  ExternalStringResourceBase* resource;
810
818
  if (type == I::kExternalOneByteRepresentationTag ||
811
819
  type == I::kExternalTwoByteRepresentationTag) {
812
- internal::Isolate* isolate = I::GetIsolateForSandbox(obj);
813
- A value =
814
- I::ReadExternalPointerField(isolate, obj, I::kStringResourceOffset,
815
- internal::kExternalStringResourceTag);
820
+ Isolate* isolate = I::GetIsolateForSandbox(obj);
821
+ A value = I::ReadExternalPointerField<internal::kExternalStringResourceTag>(
822
+ isolate, obj, I::kStringResourceOffset);
816
823
  resource = reinterpret_cast<ExternalStringResourceBase*>(value);
817
824
  } else {
818
825
  resource = GetExternalStringResourceBaseSlow(encoding_out);
@@ -829,32 +836,32 @@ V8_INLINE Local<Primitive> Undefined(Isolate* isolate) {
829
836
  using S = internal::Address;
830
837
  using I = internal::Internals;
831
838
  I::CheckInitialized(isolate);
832
- S* slot = I::GetRoot(isolate, I::kUndefinedValueRootIndex);
833
- return Local<Primitive>(reinterpret_cast<Primitive*>(slot));
839
+ S* slot = I::GetRootSlot(isolate, I::kUndefinedValueRootIndex);
840
+ return Local<Primitive>::FromSlot(slot);
834
841
  }
835
842
 
836
843
  V8_INLINE Local<Primitive> Null(Isolate* isolate) {
837
844
  using S = internal::Address;
838
845
  using I = internal::Internals;
839
846
  I::CheckInitialized(isolate);
840
- S* slot = I::GetRoot(isolate, I::kNullValueRootIndex);
841
- return Local<Primitive>(reinterpret_cast<Primitive*>(slot));
847
+ S* slot = I::GetRootSlot(isolate, I::kNullValueRootIndex);
848
+ return Local<Primitive>::FromSlot(slot);
842
849
  }
843
850
 
844
851
  V8_INLINE Local<Boolean> True(Isolate* isolate) {
845
852
  using S = internal::Address;
846
853
  using I = internal::Internals;
847
854
  I::CheckInitialized(isolate);
848
- S* slot = I::GetRoot(isolate, I::kTrueValueRootIndex);
849
- return Local<Boolean>(reinterpret_cast<Boolean*>(slot));
855
+ S* slot = I::GetRootSlot(isolate, I::kTrueValueRootIndex);
856
+ return Local<Boolean>::FromSlot(slot);
850
857
  }
851
858
 
852
859
  V8_INLINE Local<Boolean> False(Isolate* isolate) {
853
860
  using S = internal::Address;
854
861
  using I = internal::Internals;
855
862
  I::CheckInitialized(isolate);
856
- S* slot = I::GetRoot(isolate, I::kFalseValueRootIndex);
857
- return Local<Boolean>(reinterpret_cast<Boolean*>(slot));
863
+ S* slot = I::GetRootSlot(isolate, I::kFalseValueRootIndex);
864
+ return Local<Boolean>::FromSlot(slot);
858
865
  }
859
866
 
860
867
  Local<Boolean> Boolean::New(Isolate* isolate, bool value) {
@@ -175,6 +175,32 @@ class V8_EXPORT CpuProfileNode {
175
175
  static const int kNoColumnNumberInfo = Message::kNoColumnInfo;
176
176
  };
177
177
 
178
+ /**
179
+ * An interface for exporting data from V8, using "push" model.
180
+ */
181
+ class V8_EXPORT OutputStream {
182
+ public:
183
+ enum WriteResult { kContinue = 0, kAbort = 1 };
184
+ virtual ~OutputStream() = default;
185
+ /** Notify about the end of stream. */
186
+ virtual void EndOfStream() = 0;
187
+ /** Get preferred output chunk size. Called only once. */
188
+ virtual int GetChunkSize() { return 1024; }
189
+ /**
190
+ * Writes the next chunk of snapshot data into the stream. Writing
191
+ * can be stopped by returning kAbort as function result. EndOfStream
192
+ * will not be called in case writing was aborted.
193
+ */
194
+ virtual WriteResult WriteAsciiChunk(char* data, int size) = 0;
195
+ /**
196
+ * Writes the next chunk of heap stats data into the stream. Writing
197
+ * can be stopped by returning kAbort as function result. EndOfStream
198
+ * will not be called in case writing was aborted.
199
+ */
200
+ virtual WriteResult WriteHeapStatsChunk(HeapStatsUpdate* data, int count) {
201
+ return kAbort;
202
+ }
203
+ };
178
204
 
179
205
  /**
180
206
  * CpuProfile contains a CPU profile in a form of top-down call tree
@@ -182,6 +208,9 @@ class V8_EXPORT CpuProfileNode {
182
208
  */
183
209
  class V8_EXPORT CpuProfile {
184
210
  public:
211
+ enum SerializationFormat {
212
+ kJSON = 0 // See format description near 'Serialize' method.
213
+ };
185
214
  /** Returns CPU profile title. */
186
215
  Local<String> GetTitle() const;
187
216
 
@@ -235,6 +264,25 @@ class V8_EXPORT CpuProfile {
235
264
  * All pointers to nodes previously returned become invalid.
236
265
  */
237
266
  void Delete();
267
+
268
+ /**
269
+ * Prepare a serialized representation of the profile. The result
270
+ * is written into the stream provided in chunks of specified size.
271
+ *
272
+ * For the JSON format, heap contents are represented as an object
273
+ * with the following structure:
274
+ *
275
+ * {
276
+ * nodes: [nodes array],
277
+ * startTime: number,
278
+ * endTime: number
279
+ * samples: [strings array]
280
+ * timeDeltas: [numbers array]
281
+ * }
282
+ *
283
+ */
284
+ void Serialize(OutputStream* stream,
285
+ SerializationFormat format = kJSON) const;
238
286
  };
239
287
 
240
288
  enum CpuProfilingMode {
@@ -331,6 +379,9 @@ class V8_EXPORT CpuProfilingOptions {
331
379
  unsigned max_samples = kNoSampleLimit, int sampling_interval_us = 0,
332
380
  MaybeLocal<Context> filter_context = MaybeLocal<Context>());
333
381
 
382
+ CpuProfilingOptions(CpuProfilingOptions&&) = default;
383
+ CpuProfilingOptions& operator=(CpuProfilingOptions&&) = default;
384
+
334
385
  CpuProfilingMode mode() const { return mode_; }
335
386
  unsigned max_samples() const { return max_samples_; }
336
387
  int sampling_interval_us() const { return sampling_interval_us_; }
@@ -344,7 +395,7 @@ class V8_EXPORT CpuProfilingOptions {
344
395
  CpuProfilingMode mode_;
345
396
  unsigned max_samples_;
346
397
  int sampling_interval_us_;
347
- CopyablePersistentTraits<Context>::CopyablePersistent filter_context_;
398
+ Global<Context> filter_context_;
348
399
  };
349
400
 
350
401
  /**
@@ -542,7 +593,10 @@ class V8_EXPORT HeapGraphNode {
542
593
  kConsString = 10, // Concatenated string. A pair of pointers to strings.
543
594
  kSlicedString = 11, // Sliced string. A fragment of another string.
544
595
  kSymbol = 12, // A Symbol (ES6).
545
- kBigInt = 13 // BigInt.
596
+ kBigInt = 13, // BigInt.
597
+ kObjectShape = 14, // Internal data used for tracking the shapes (or
598
+ // "hidden classes") of JS objects.
599
+ kWasmObject = 15, // A WasmGC struct or array.
546
600
  };
547
601
 
548
602
  /** Returns node type (see HeapGraphNode::Type). */
@@ -571,37 +625,6 @@ class V8_EXPORT HeapGraphNode {
571
625
  const HeapGraphEdge* GetChild(int index) const;
572
626
  };
573
627
 
574
-
575
- /**
576
- * An interface for exporting data from V8, using "push" model.
577
- */
578
- class V8_EXPORT OutputStream {
579
- public:
580
- enum WriteResult {
581
- kContinue = 0,
582
- kAbort = 1
583
- };
584
- virtual ~OutputStream() = default;
585
- /** Notify about the end of stream. */
586
- virtual void EndOfStream() = 0;
587
- /** Get preferred output chunk size. Called only once. */
588
- virtual int GetChunkSize() { return 1024; }
589
- /**
590
- * Writes the next chunk of snapshot data into the stream. Writing
591
- * can be stopped by returning kAbort as function result. EndOfStream
592
- * will not be called in case writing was aborted.
593
- */
594
- virtual WriteResult WriteAsciiChunk(char* data, int size) = 0;
595
- /**
596
- * Writes the next chunk of heap stats data into the stream. Writing
597
- * can be stopped by returning kAbort as function result. EndOfStream
598
- * will not be called in case writing was aborted.
599
- */
600
- virtual WriteResult WriteHeapStatsChunk(HeapStatsUpdate* data, int count) {
601
- return kAbort;
602
- }
603
- };
604
-
605
628
  /**
606
629
  * HeapSnapshots record the state of the JS heap at some moment.
607
630
  */
@@ -898,6 +921,8 @@ class V8_EXPORT HeapProfiler {
898
921
  enum SamplingFlags {
899
922
  kSamplingNoFlags = 0,
900
923
  kSamplingForceGC = 1 << 0,
924
+ kSamplingIncludeObjectsCollectedByMajorGC = 1 << 1,
925
+ kSamplingIncludeObjectsCollectedByMinorGC = 1 << 2,
901
926
  };
902
927
 
903
928
  /**
@@ -975,14 +1000,71 @@ class V8_EXPORT HeapProfiler {
975
1000
  virtual ~ObjectNameResolver() = default;
976
1001
  };
977
1002
 
1003
+ enum class HeapSnapshotMode {
1004
+ /**
1005
+ * Heap snapshot for regular developers.
1006
+ */
1007
+ kRegular,
1008
+ /**
1009
+ * Heap snapshot is exposing internals that may be useful for experts.
1010
+ */
1011
+ kExposeInternals,
1012
+ };
1013
+
1014
+ enum class NumericsMode {
1015
+ /**
1016
+ * Numeric values are hidden as they are values of the corresponding
1017
+ * objects.
1018
+ */
1019
+ kHideNumericValues,
1020
+ /**
1021
+ * Numeric values are exposed in artificial fields.
1022
+ */
1023
+ kExposeNumericValues
1024
+ };
1025
+
1026
+ struct HeapSnapshotOptions final {
1027
+ // Manually define default constructor here to be able to use it in
1028
+ // `TakeSnapshot()` below.
1029
+ // NOLINTNEXTLINE
1030
+ HeapSnapshotOptions() {}
1031
+
1032
+ /**
1033
+ * The control used to report intermediate progress to.
1034
+ */
1035
+ ActivityControl* control = nullptr;
1036
+ /**
1037
+ * The resolver used by the snapshot generator to get names for V8 objects.
1038
+ */
1039
+ ObjectNameResolver* global_object_name_resolver = nullptr;
1040
+ /**
1041
+ * Mode for taking the snapshot, see `HeapSnapshotMode`.
1042
+ */
1043
+ HeapSnapshotMode snapshot_mode = HeapSnapshotMode::kRegular;
1044
+ /**
1045
+ * Mode for dealing with numeric values, see `NumericsMode`.
1046
+ */
1047
+ NumericsMode numerics_mode = NumericsMode::kHideNumericValues;
1048
+ };
1049
+
1050
+ /**
1051
+ * Takes a heap snapshot.
1052
+ *
1053
+ * \returns the snapshot.
1054
+ */
1055
+ const HeapSnapshot* TakeHeapSnapshot(
1056
+ const HeapSnapshotOptions& options = HeapSnapshotOptions());
1057
+
978
1058
  /**
979
- * Takes a heap snapshot and returns it.
1059
+ * Takes a heap snapshot. See `HeapSnapshotOptions` for details on the
1060
+ * parameters.
1061
+ *
1062
+ * \returns the snapshot.
980
1063
  */
981
1064
  const HeapSnapshot* TakeHeapSnapshot(
982
- ActivityControl* control = nullptr,
1065
+ ActivityControl* control,
983
1066
  ObjectNameResolver* global_object_name_resolver = nullptr,
984
- bool treat_global_objects_as_roots = true,
985
- bool capture_numeric_value = false);
1067
+ bool hide_internals = true, bool capture_numeric_value = false);
986
1068
 
987
1069
  /**
988
1070
  * Starts tracking of heap objects population statistics. After calling
@@ -1035,10 +1117,8 @@ class V8_EXPORT HeapProfiler {
1035
1117
  * |stack_depth| parameter controls the maximum number of stack frames to be
1036
1118
  * captured on each allocation.
1037
1119
  *
1038
- * NOTE: This is a proof-of-concept at this point. Right now we only sample
1039
- * newspace allocations. Support for paged space allocation (e.g. pre-tenured
1040
- * objects, large objects, code objects, etc.) and native allocations
1041
- * doesn't exist yet, but is anticipated in the future.
1120
+ * NOTE: Support for native allocations doesn't exist yet, but is anticipated
1121
+ * in the future.
1042
1122
  *
1043
1123
  * Objects allocated before the sampling is started will not be included in
1044
1124
  * the profile.
@@ -1101,18 +1181,18 @@ struct HeapStatsUpdate {
1101
1181
  uint32_t size; // New value of size field for the interval with this index.
1102
1182
  };
1103
1183
 
1104
- #define CODE_EVENTS_LIST(V) \
1105
- V(Builtin) \
1106
- V(Callback) \
1107
- V(Eval) \
1108
- V(Function) \
1109
- V(InterpretedFunction) \
1110
- V(Handler) \
1111
- V(BytecodeHandler) \
1112
- V(LazyCompile) \
1113
- V(RegExp) \
1114
- V(Script) \
1115
- V(Stub) \
1184
+ #define CODE_EVENTS_LIST(V) \
1185
+ V(Builtin) \
1186
+ V(Callback) \
1187
+ V(Eval) \
1188
+ V(Function) \
1189
+ V(InterpretedFunction) \
1190
+ V(Handler) \
1191
+ V(BytecodeHandler) \
1192
+ V(LazyCompile) /* Unused, use kFunction instead */ \
1193
+ V(RegExp) \
1194
+ V(Script) \
1195
+ V(Stub) \
1116
1196
  V(Relocation)
1117
1197
 
1118
1198
  /**
@@ -37,9 +37,10 @@ class V8_EXPORT RegExp : public Object {
37
37
  kDotAll = 1 << 5,
38
38
  kLinear = 1 << 6,
39
39
  kHasIndices = 1 << 7,
40
+ kUnicodeSets = 1 << 8,
40
41
  };
41
42
 
42
- static constexpr int kFlagCount = 8;
43
+ static constexpr int kFlagCount = 9;
43
44
 
44
45
  /**
45
46
  * Creates a regular expression from the given pattern string and