libv8-node 15.14.0.1-aarch64-linux-musl → 18.8.0.0-aarch64-linux-musl

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 (103) hide show
  1. checksums.yaml +4 -4
  2. data/ext/libv8-node/location.rb +1 -1
  3. data/ext/libv8-node/paths.rb +5 -1
  4. data/lib/libv8/node/version.rb +3 -3
  5. data/vendor/v8/{out.gn → aarch64-linux-musl}/libv8/obj/libv8_monolith.a +0 -0
  6. data/vendor/v8/include/cppgc/allocation.h +184 -47
  7. data/vendor/v8/include/cppgc/common.h +9 -6
  8. data/vendor/v8/include/cppgc/cross-thread-persistent.h +465 -0
  9. data/vendor/v8/include/cppgc/custom-space.h +37 -2
  10. data/vendor/v8/include/cppgc/default-platform.h +40 -49
  11. data/vendor/v8/include/cppgc/ephemeron-pair.h +30 -0
  12. data/vendor/v8/include/cppgc/explicit-management.h +100 -0
  13. data/vendor/v8/include/cppgc/garbage-collected.h +19 -29
  14. data/vendor/v8/include/cppgc/heap-consistency.h +266 -0
  15. data/vendor/v8/include/cppgc/heap-state.h +82 -0
  16. data/vendor/v8/include/cppgc/heap-statistics.h +120 -0
  17. data/vendor/v8/include/cppgc/heap.h +73 -6
  18. data/vendor/v8/include/cppgc/internal/api-constants.h +11 -3
  19. data/vendor/v8/include/cppgc/internal/caged-heap-local-data.h +27 -15
  20. data/vendor/v8/include/cppgc/internal/compiler-specific.h +2 -2
  21. data/vendor/v8/include/cppgc/internal/finalizer-trait.h +4 -1
  22. data/vendor/v8/include/cppgc/internal/gc-info.h +124 -13
  23. data/vendor/v8/include/cppgc/internal/logging.h +3 -3
  24. data/vendor/v8/include/cppgc/internal/name-trait.h +122 -0
  25. data/vendor/v8/include/cppgc/internal/persistent-node.h +116 -16
  26. data/vendor/v8/include/cppgc/internal/pointer-policies.h +84 -32
  27. data/vendor/v8/include/cppgc/internal/write-barrier.h +392 -35
  28. data/vendor/v8/include/cppgc/liveness-broker.h +11 -2
  29. data/vendor/v8/include/cppgc/macros.h +2 -0
  30. data/vendor/v8/include/cppgc/member.h +91 -26
  31. data/vendor/v8/include/cppgc/name-provider.h +65 -0
  32. data/vendor/v8/include/cppgc/object-size-trait.h +58 -0
  33. data/vendor/v8/include/cppgc/persistent.h +70 -41
  34. data/vendor/v8/include/cppgc/platform.h +52 -26
  35. data/vendor/v8/include/cppgc/prefinalizer.h +36 -13
  36. data/vendor/v8/include/cppgc/process-heap-statistics.h +36 -0
  37. data/vendor/v8/include/cppgc/sentinel-pointer.h +32 -0
  38. data/vendor/v8/include/cppgc/source-location.h +2 -1
  39. data/vendor/v8/include/cppgc/testing.h +106 -0
  40. data/vendor/v8/include/cppgc/trace-trait.h +8 -3
  41. data/vendor/v8/include/cppgc/type-traits.h +163 -32
  42. data/vendor/v8/include/cppgc/visitor.h +194 -28
  43. data/vendor/v8/include/libplatform/libplatform.h +11 -11
  44. data/vendor/v8/include/libplatform/v8-tracing.h +2 -1
  45. data/vendor/v8/include/v8-array-buffer.h +445 -0
  46. data/vendor/v8/include/v8-callbacks.h +397 -0
  47. data/vendor/v8/include/v8-container.h +129 -0
  48. data/vendor/v8/include/v8-context.h +407 -0
  49. data/vendor/v8/include/v8-cppgc.h +151 -159
  50. data/vendor/v8/include/v8-data.h +80 -0
  51. data/vendor/v8/include/v8-date.h +43 -0
  52. data/vendor/v8/include/v8-debug.h +168 -0
  53. data/vendor/v8/include/v8-embedder-heap.h +218 -0
  54. data/vendor/v8/include/v8-embedder-state-scope.h +51 -0
  55. data/vendor/v8/include/v8-exception.h +217 -0
  56. data/vendor/v8/include/v8-extension.h +62 -0
  57. data/vendor/v8/include/v8-external.h +37 -0
  58. data/vendor/v8/include/v8-fast-api-calls.h +703 -152
  59. data/vendor/v8/include/v8-forward.h +81 -0
  60. data/vendor/v8/include/v8-function-callback.h +475 -0
  61. data/vendor/v8/include/v8-function.h +125 -0
  62. data/vendor/v8/include/v8-initialization.h +315 -0
  63. data/vendor/v8/include/v8-inspector.h +76 -27
  64. data/vendor/v8/include/v8-internal.h +285 -51
  65. data/vendor/v8/include/v8-isolate.h +1709 -0
  66. data/vendor/v8/include/v8-json.h +47 -0
  67. data/vendor/v8/include/v8-local-handle.h +455 -0
  68. data/vendor/v8/include/v8-locker.h +149 -0
  69. data/vendor/v8/include/v8-maybe.h +137 -0
  70. data/vendor/v8/include/v8-memory-span.h +43 -0
  71. data/vendor/v8/include/v8-message.h +216 -0
  72. data/vendor/v8/include/v8-metrics.h +131 -9
  73. data/vendor/v8/include/v8-microtask-queue.h +152 -0
  74. data/vendor/v8/include/v8-microtask.h +28 -0
  75. data/vendor/v8/include/v8-object.h +775 -0
  76. data/vendor/v8/include/v8-persistent-handle.h +590 -0
  77. data/vendor/v8/include/v8-platform.h +433 -25
  78. data/vendor/v8/include/v8-primitive-object.h +118 -0
  79. data/vendor/v8/include/v8-primitive.h +866 -0
  80. data/vendor/v8/include/v8-profiler.h +149 -10
  81. data/vendor/v8/include/v8-promise.h +174 -0
  82. data/vendor/v8/include/v8-proxy.h +50 -0
  83. data/vendor/v8/include/v8-regexp.h +105 -0
  84. data/vendor/v8/include/v8-script.h +747 -0
  85. data/vendor/v8/include/v8-snapshot.h +196 -0
  86. data/vendor/v8/include/v8-statistics.h +217 -0
  87. data/vendor/v8/include/v8-template.h +1079 -0
  88. data/vendor/v8/include/v8-traced-handle.h +420 -0
  89. data/vendor/v8/include/v8-typed-array.h +282 -0
  90. data/vendor/v8/include/v8-unwinder-state.h +31 -0
  91. data/vendor/v8/include/v8-unwinder.h +132 -0
  92. data/vendor/v8/include/v8-util.h +8 -2
  93. data/vendor/v8/include/v8-value-serializer-version.h +1 -1
  94. data/vendor/v8/include/v8-value-serializer.h +279 -0
  95. data/vendor/v8/include/v8-value.h +526 -0
  96. data/vendor/v8/include/v8-version.h +4 -4
  97. data/vendor/v8/include/v8-wasm.h +257 -0
  98. data/vendor/v8/include/v8-weak-callback-info.h +87 -0
  99. data/vendor/v8/include/v8.h +41 -12051
  100. data/vendor/v8/include/v8config.h +142 -21
  101. metadata +64 -10
  102. data/vendor/v8/include/cppgc/internal/prefinalizer-handler.h +0 -30
  103. data/vendor/v8/include/cppgc/internal/process-heap.h +0 -34
@@ -5,209 +5,196 @@
5
5
  #ifndef INCLUDE_V8_CPPGC_H_
6
6
  #define INCLUDE_V8_CPPGC_H_
7
7
 
8
+ #include <cstdint>
9
+ #include <memory>
10
+ #include <vector>
11
+
12
+ #include "cppgc/common.h"
13
+ #include "cppgc/custom-space.h"
14
+ #include "cppgc/heap-statistics.h"
8
15
  #include "cppgc/visitor.h"
9
- #include "v8-internal.h" // NOLINT(build/include_directory)
10
- #include "v8.h" // NOLINT(build/include_directory)
16
+ #include "v8-internal.h" // NOLINT(build/include_directory)
17
+ #include "v8-platform.h" // NOLINT(build/include_directory)
18
+ #include "v8-traced-handle.h" // NOLINT(build/include_directory)
19
+
20
+ namespace cppgc {
21
+ class AllocationHandle;
22
+ class HeapHandle;
23
+ } // namespace cppgc
11
24
 
12
25
  namespace v8 {
13
26
 
14
- class Isolate;
15
- template <typename T>
16
- class JSMember;
27
+ class Object;
17
28
 
18
29
  namespace internal {
30
+ class CppHeap;
31
+ } // namespace internal
19
32
 
20
- class JSMemberBaseExtractor;
33
+ class CustomSpaceStatisticsReceiver;
21
34
 
22
- class V8_EXPORT JSMemberBase {
23
- public:
35
+ /**
36
+ * Describes how V8 wrapper objects maintain references to garbage-collected C++
37
+ * objects.
38
+ */
39
+ struct WrapperDescriptor final {
24
40
  /**
25
- * Returns true if the reference is empty, i.e., has not been assigned
26
- * object.
41
+ * The index used on `v8::Ojbect::SetAlignedPointerFromInternalField()` and
42
+ * related APIs to add additional data to an object which is used to identify
43
+ * JS->C++ references.
27
44
  */
28
- bool IsEmpty() const { return val_ == nullptr; }
45
+ using InternalFieldIndex = int;
29
46
 
30
47
  /**
31
- * Clears the reference. IsEmpty() will return true after this call.
48
+ * Unknown embedder id. The value is reserved for internal usages and must not
49
+ * be used with `CppHeap`.
32
50
  */
33
- inline void Reset();
34
-
35
- private:
36
- static internal::Address* New(v8::Isolate* isolate,
37
- internal::Address* object_slot,
38
- internal::Address** this_slot);
39
- static void Delete(internal::Address* object);
40
- static void Copy(const internal::Address* const* from_slot,
41
- internal::Address** to_slot);
42
- static void Move(internal::Address** from_slot, internal::Address** to_slot);
43
-
44
- JSMemberBase() = default;
51
+ static constexpr uint16_t kUnknownEmbedderId = UINT16_MAX;
45
52
 
46
- JSMemberBase(v8::Isolate* isolate, internal::Address* object_slot)
47
- : val_(New(isolate, object_slot, &val_)) {}
53
+ constexpr WrapperDescriptor(InternalFieldIndex wrappable_type_index,
54
+ InternalFieldIndex wrappable_instance_index,
55
+ uint16_t embedder_id_for_garbage_collected)
56
+ : wrappable_type_index(wrappable_type_index),
57
+ wrappable_instance_index(wrappable_instance_index),
58
+ embedder_id_for_garbage_collected(embedder_id_for_garbage_collected) {}
48
59
 
49
- inline JSMemberBase& CopyImpl(const JSMemberBase& other);
50
- inline JSMemberBase& MoveImpl(JSMemberBase&& other);
60
+ /**
61
+ * Index of the wrappable type.
62
+ */
63
+ InternalFieldIndex wrappable_type_index;
51
64
 
52
- // val_ points to a GlobalHandles node.
53
- internal::Address* val_ = nullptr;
65
+ /**
66
+ * Index of the wrappable instance.
67
+ */
68
+ InternalFieldIndex wrappable_instance_index;
54
69
 
55
- template <typename T>
56
- friend class v8::JSMember;
57
- friend class v8::internal::JSMemberBaseExtractor;
70
+ /**
71
+ * Embedder id identifying instances of garbage-collected objects. It is
72
+ * expected that the first field of the wrappable type is a uint16_t holding
73
+ * the id. Only references to instances of wrappables types with an id of
74
+ * `embedder_id_for_garbage_collected` will be considered by CppHeap.
75
+ */
76
+ uint16_t embedder_id_for_garbage_collected;
58
77
  };
59
78
 
60
- JSMemberBase& JSMemberBase::CopyImpl(const JSMemberBase& other) {
61
- if (this != &other) {
62
- Reset();
63
- if (!other.IsEmpty()) {
64
- Copy(&other.val_, &val_);
65
- }
66
- }
67
- return *this;
68
- }
69
-
70
- JSMemberBase& JSMemberBase::MoveImpl(JSMemberBase&& other) {
71
- if (this != &other) {
72
- // No call to Reset() as Move() will conditionally reset itself when needed,
73
- // and otherwise reuse the internal meta data.
74
- Move(&other.val_, &val_);
75
- }
76
- return *this;
77
- }
78
-
79
- void JSMemberBase::Reset() {
80
- if (IsEmpty()) return;
81
- Delete(val_);
82
- val_ = nullptr;
83
- }
79
+ struct V8_EXPORT CppHeapCreateParams {
80
+ CppHeapCreateParams(const CppHeapCreateParams&) = delete;
81
+ CppHeapCreateParams& operator=(const CppHeapCreateParams&) = delete;
84
82
 
85
- } // namespace internal
83
+ std::vector<std::unique_ptr<cppgc::CustomSpaceBase>> custom_spaces;
84
+ WrapperDescriptor wrapper_descriptor;
85
+ };
86
86
 
87
87
  /**
88
- * A traced handle without destructor that clears the handle. The handle may
89
- * only be used in GarbageCollected objects and must be processed in a Trace()
90
- * method.
88
+ * A heap for allocating managed C++ objects.
91
89
  */
92
- template <typename T>
93
- class V8_EXPORT JSMember : public internal::JSMemberBase {
94
- static_assert(std::is_base_of<v8::Value, T>::value,
95
- "JSMember only supports references to v8::Value");
96
-
90
+ class V8_EXPORT CppHeap {
97
91
  public:
98
- JSMember() = default;
99
-
100
- template <typename U,
101
- typename = std::enable_if_t<std::is_base_of<T, U>::value>>
102
- JSMember(Isolate* isolate, Local<U> that)
103
- : internal::JSMemberBase(isolate,
104
- reinterpret_cast<internal::Address*>(*that)) {}
92
+ static std::unique_ptr<CppHeap> Create(v8::Platform* platform,
93
+ const CppHeapCreateParams& params);
105
94
 
106
- JSMember(const JSMember& other) { CopyImpl(other); }
95
+ virtual ~CppHeap() = default;
107
96
 
108
- template <typename U,
109
- typename = std::enable_if_t<std::is_base_of<T, U>::value>>
110
- JSMember(const JSMember<U>& other) { // NOLINT
111
- CopyImpl(other);
112
- }
97
+ /**
98
+ * \returns the opaque handle for allocating objects using
99
+ * `MakeGarbageCollected()`.
100
+ */
101
+ cppgc::AllocationHandle& GetAllocationHandle();
113
102
 
114
- JSMember(JSMember&& other) { MoveImpl(std::move(other)); }
103
+ /**
104
+ * \returns the opaque heap handle which may be used to refer to this heap in
105
+ * other APIs. Valid as long as the underlying `CppHeap` is alive.
106
+ */
107
+ cppgc::HeapHandle& GetHeapHandle();
115
108
 
116
- template <typename U,
117
- typename = std::enable_if_t<std::is_base_of<T, U>::value>>
118
- JSMember(JSMember<U>&& other) { // NOLINT
119
- MoveImpl(std::move(other));
120
- }
109
+ /**
110
+ * Terminate clears all roots and performs multiple garbage collections to
111
+ * reclaim potentially newly created objects in destructors.
112
+ *
113
+ * After this call, object allocation is prohibited.
114
+ */
115
+ void Terminate();
121
116
 
122
- JSMember& operator=(const JSMember& other) { return CopyImpl(other); }
117
+ /**
118
+ * \param detail_level specifies whether should return detailed
119
+ * statistics or only brief summary statistics.
120
+ * \returns current CppHeap statistics regarding memory consumption
121
+ * and utilization.
122
+ */
123
+ cppgc::HeapStatistics CollectStatistics(
124
+ cppgc::HeapStatistics::DetailLevel detail_level);
123
125
 
124
- template <typename U,
125
- typename = std::enable_if_t<std::is_base_of<T, U>::value>>
126
- JSMember& operator=(const JSMember<U>& other) {
127
- return CopyImpl(other);
128
- }
126
+ /**
127
+ * Collects statistics for the given spaces and reports them to the receiver.
128
+ *
129
+ * \param custom_spaces a collection of custom space indicies.
130
+ * \param receiver an object that gets the results.
131
+ */
132
+ void CollectCustomSpaceStatisticsAtLastGC(
133
+ std::vector<cppgc::CustomSpaceIndex> custom_spaces,
134
+ std::unique_ptr<CustomSpaceStatisticsReceiver> receiver);
129
135
 
130
- JSMember& operator=(JSMember&& other) { return MoveImpl(other); }
136
+ /**
137
+ * Enables a detached mode that allows testing garbage collection using
138
+ * `cppgc::testing` APIs. Once used, the heap cannot be attached to an
139
+ * `Isolate` anymore.
140
+ */
141
+ void EnableDetachedGarbageCollectionsForTesting();
131
142
 
132
- template <typename U,
133
- typename = std::enable_if_t<std::is_base_of<T, U>::value>>
134
- JSMember& operator=(JSMember<U>&& other) {
135
- return MoveImpl(other);
136
- }
143
+ /**
144
+ * Performs a stop-the-world garbage collection for testing purposes.
145
+ *
146
+ * \param stack_state The stack state to assume for the garbage collection.
147
+ */
148
+ void CollectGarbageForTesting(cppgc::EmbedderStackState stack_state);
137
149
 
138
- T* operator->() const { return reinterpret_cast<T*>(val_); }
139
- T* operator*() const { return reinterpret_cast<T*>(val_); }
150
+ /**
151
+ * Performs a stop-the-world minor garbage collection for testing purposes.
152
+ *
153
+ * \param stack_state The stack state to assume for the garbage collection.
154
+ */
155
+ void CollectGarbageInYoungGenerationForTesting(
156
+ cppgc::EmbedderStackState stack_state);
140
157
 
141
- using internal::JSMemberBase::Reset;
158
+ private:
159
+ CppHeap() = default;
142
160
 
143
- template <typename U,
144
- typename = std::enable_if_t<std::is_base_of<T, U>::value>>
145
- void Set(v8::Isolate* isolate, Local<U> that) {
146
- Reset();
147
- val_ = New(isolate, reinterpret_cast<internal::Address*>(*that), &val_);
148
- }
161
+ friend class internal::CppHeap;
149
162
  };
150
163
 
151
- template <typename T1, typename T2,
152
- typename = std::enable_if_t<std::is_base_of<T2, T1>::value ||
153
- std::is_base_of<T1, T2>::value>>
154
- inline bool operator==(const JSMember<T1>& lhs, const JSMember<T2>& rhs) {
155
- v8::internal::Address* a = reinterpret_cast<v8::internal::Address*>(*lhs);
156
- v8::internal::Address* b = reinterpret_cast<v8::internal::Address*>(*rhs);
157
- if (a == nullptr) return b == nullptr;
158
- if (b == nullptr) return false;
159
- return *a == *b;
160
- }
161
-
162
- template <typename T1, typename T2,
163
- typename = std::enable_if_t<std::is_base_of<T2, T1>::value ||
164
- std::is_base_of<T1, T2>::value>>
165
- inline bool operator!=(const JSMember<T1>& lhs, const JSMember<T2>& rhs) {
166
- return !(lhs == rhs);
167
- }
168
-
169
- template <typename T1, typename T2,
170
- typename = std::enable_if_t<std::is_base_of<T2, T1>::value ||
171
- std::is_base_of<T1, T2>::value>>
172
- inline bool operator==(const JSMember<T1>& lhs, const Local<T2>& rhs) {
173
- v8::internal::Address* a = reinterpret_cast<v8::internal::Address*>(*lhs);
174
- v8::internal::Address* b = reinterpret_cast<v8::internal::Address*>(*rhs);
175
- if (a == nullptr) return b == nullptr;
176
- if (b == nullptr) return false;
177
- return *a == *b;
178
- }
179
-
180
- template <typename T1, typename T2,
181
- typename = std::enable_if_t<std::is_base_of<T2, T1>::value ||
182
- std::is_base_of<T1, T2>::value>>
183
- inline bool operator==(const Local<T1>& lhs, const JSMember<T2> rhs) {
184
- return rhs == lhs;
185
- }
186
-
187
- template <typename T1, typename T2>
188
- inline bool operator!=(const JSMember<T1>& lhs, const T2& rhs) {
189
- return !(lhs == rhs);
190
- }
191
-
192
- template <typename T1, typename T2>
193
- inline bool operator!=(const T1& lhs, const JSMember<T2>& rhs) {
194
- return !(lhs == rhs);
195
- }
196
-
197
164
  class JSVisitor : public cppgc::Visitor {
198
165
  public:
199
166
  explicit JSVisitor(cppgc::Visitor::Key key) : cppgc::Visitor(key) {}
167
+ ~JSVisitor() override = default;
200
168
 
201
- template <typename T>
202
- void Trace(const JSMember<T>& ref) {
203
- if (ref.IsEmpty()) return;
169
+ void Trace(const TracedReferenceBase& ref) {
170
+ if (ref.IsEmptyThreadSafe()) return;
204
171
  Visit(ref);
205
172
  }
206
173
 
207
174
  protected:
208
175
  using cppgc::Visitor::Visit;
209
176
 
210
- virtual void Visit(const internal::JSMemberBase& ref) {}
177
+ virtual void Visit(const TracedReferenceBase& ref) {}
178
+ };
179
+
180
+ /**
181
+ * Provided as input to `CppHeap::CollectCustomSpaceStatisticsAtLastGC()`.
182
+ *
183
+ * Its method is invoked with the results of the statistic collection.
184
+ */
185
+ class CustomSpaceStatisticsReceiver {
186
+ public:
187
+ virtual ~CustomSpaceStatisticsReceiver() = default;
188
+ /**
189
+ * Reports the size of a space at the last GC. It is called for each space
190
+ * that was requested in `CollectCustomSpaceStatisticsAtLastGC()`.
191
+ *
192
+ * \param space_index The index of the space.
193
+ * \param bytes The total size of live objects in the space at the last GC.
194
+ * It is zero if there was no GC yet.
195
+ */
196
+ virtual void AllocatedBytes(cppgc::CustomSpaceIndex space_index,
197
+ size_t bytes) = 0;
211
198
  };
212
199
 
213
200
  } // namespace v8
@@ -215,9 +202,14 @@ class JSVisitor : public cppgc::Visitor {
215
202
  namespace cppgc {
216
203
 
217
204
  template <typename T>
218
- struct TraceTrait<v8::JSMember<T>> {
219
- static void Trace(Visitor* visitor, const v8::JSMember<T>* self) {
220
- static_cast<v8::JSVisitor*>(visitor)->Trace(*self);
205
+ struct TraceTrait<v8::TracedReference<T>> {
206
+ static cppgc::TraceDescriptor GetTraceDescriptor(const void* self) {
207
+ return {nullptr, Trace};
208
+ }
209
+
210
+ static void Trace(Visitor* visitor, const void* self) {
211
+ static_cast<v8::JSVisitor*>(visitor)->Trace(
212
+ *static_cast<const v8::TracedReference<T>*>(self));
221
213
  }
222
214
  };
223
215
 
@@ -0,0 +1,80 @@
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_DATA_H_
6
+ #define INCLUDE_V8_DATA_H_
7
+
8
+ #include "v8-local-handle.h" // NOLINT(build/include_directory)
9
+ #include "v8config.h" // NOLINT(build/include_directory)
10
+
11
+ namespace v8 {
12
+
13
+ class Context;
14
+
15
+ /**
16
+ * The superclass of objects that can reside on V8's heap.
17
+ */
18
+ class V8_EXPORT Data {
19
+ public:
20
+ /**
21
+ * Returns true if this data is a |v8::Value|.
22
+ */
23
+ bool IsValue() const;
24
+
25
+ /**
26
+ * Returns true if this data is a |v8::Module|.
27
+ */
28
+ bool IsModule() const;
29
+
30
+ /**
31
+ * Returns tru if this data is a |v8::FixedArray|
32
+ */
33
+ bool IsFixedArray() const;
34
+
35
+ /**
36
+ * Returns true if this data is a |v8::Private|.
37
+ */
38
+ bool IsPrivate() const;
39
+
40
+ /**
41
+ * Returns true if this data is a |v8::ObjectTemplate|.
42
+ */
43
+ bool IsObjectTemplate() const;
44
+
45
+ /**
46
+ * Returns true if this data is a |v8::FunctionTemplate|.
47
+ */
48
+ bool IsFunctionTemplate() const;
49
+
50
+ /**
51
+ * Returns true if this data is a |v8::Context|.
52
+ */
53
+ bool IsContext() const;
54
+
55
+ private:
56
+ Data();
57
+ };
58
+
59
+ /**
60
+ * A fixed-sized array with elements of type Data.
61
+ */
62
+ class V8_EXPORT FixedArray : public Data {
63
+ public:
64
+ int Length() const;
65
+ Local<Data> Get(Local<Context> context, int i) const;
66
+
67
+ V8_INLINE static FixedArray* Cast(Data* data) {
68
+ #ifdef V8_ENABLE_CHECKS
69
+ CheckCast(data);
70
+ #endif
71
+ return reinterpret_cast<FixedArray*>(data);
72
+ }
73
+
74
+ private:
75
+ static void CheckCast(Data* obj);
76
+ };
77
+
78
+ } // namespace v8
79
+
80
+ #endif // INCLUDE_V8_DATA_H_
@@ -0,0 +1,43 @@
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_DATE_H_
6
+ #define INCLUDE_V8_DATE_H_
7
+
8
+ #include "v8-local-handle.h" // NOLINT(build/include_directory)
9
+ #include "v8-object.h" // NOLINT(build/include_directory)
10
+ #include "v8config.h" // NOLINT(build/include_directory)
11
+
12
+ namespace v8 {
13
+
14
+ class Context;
15
+
16
+ /**
17
+ * An instance of the built-in Date constructor (ECMA-262, 15.9).
18
+ */
19
+ class V8_EXPORT Date : public Object {
20
+ public:
21
+ static V8_WARN_UNUSED_RESULT MaybeLocal<Value> New(Local<Context> context,
22
+ double time);
23
+
24
+ /**
25
+ * A specialization of Value::NumberValue that is more efficient
26
+ * because we know the structure of this object.
27
+ */
28
+ double ValueOf() const;
29
+
30
+ V8_INLINE static Date* Cast(Value* value) {
31
+ #ifdef V8_ENABLE_CHECKS
32
+ CheckCast(value);
33
+ #endif
34
+ return static_cast<Date*>(value);
35
+ }
36
+
37
+ private:
38
+ static void CheckCast(Value* obj);
39
+ };
40
+
41
+ } // namespace v8
42
+
43
+ #endif // INCLUDE_V8_DATE_H_
@@ -0,0 +1,168 @@
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_DEBUG_H_
6
+ #define INCLUDE_V8_DEBUG_H_
7
+
8
+ #include <stdint.h>
9
+
10
+ #include "v8-script.h" // NOLINT(build/include_directory)
11
+ #include "v8config.h" // NOLINT(build/include_directory)
12
+
13
+ namespace v8 {
14
+
15
+ class Isolate;
16
+ class String;
17
+
18
+ /**
19
+ * A single JavaScript stack frame.
20
+ */
21
+ class V8_EXPORT StackFrame {
22
+ public:
23
+ /**
24
+ * Returns the source location, 0-based, for the associated function call.
25
+ */
26
+ Location GetLocation() const;
27
+
28
+ /**
29
+ * Returns the number, 1-based, of the line for the associate function call.
30
+ * This method will return Message::kNoLineNumberInfo if it is unable to
31
+ * retrieve the line number, or if kLineNumber was not passed as an option
32
+ * when capturing the StackTrace.
33
+ */
34
+ int GetLineNumber() const { return GetLocation().GetLineNumber() + 1; }
35
+
36
+ /**
37
+ * Returns the 1-based column offset on the line for the associated function
38
+ * call.
39
+ * This method will return Message::kNoColumnInfo if it is unable to retrieve
40
+ * the column number, or if kColumnOffset was not passed as an option when
41
+ * capturing the StackTrace.
42
+ */
43
+ int GetColumn() const { return GetLocation().GetColumnNumber() + 1; }
44
+
45
+ /**
46
+ * Returns the id of the script for the function for this StackFrame.
47
+ * This method will return Message::kNoScriptIdInfo if it is unable to
48
+ * retrieve the script id, or if kScriptId was not passed as an option when
49
+ * capturing the StackTrace.
50
+ */
51
+ int GetScriptId() const;
52
+
53
+ /**
54
+ * Returns the name of the resource that contains the script for the
55
+ * function for this StackFrame.
56
+ */
57
+ Local<String> GetScriptName() const;
58
+
59
+ /**
60
+ * Returns the name of the resource that contains the script for the
61
+ * function for this StackFrame or sourceURL value if the script name
62
+ * is undefined and its source ends with //# sourceURL=... string or
63
+ * deprecated //@ sourceURL=... string.
64
+ */
65
+ Local<String> GetScriptNameOrSourceURL() const;
66
+
67
+ /**
68
+ * Returns the source of the script for the function for this StackFrame.
69
+ */
70
+ Local<String> GetScriptSource() const;
71
+
72
+ /**
73
+ * Returns the source mapping URL (if one is present) of the script for
74
+ * the function for this StackFrame.
75
+ */
76
+ Local<String> GetScriptSourceMappingURL() const;
77
+
78
+ /**
79
+ * Returns the name of the function associated with this stack frame.
80
+ */
81
+ Local<String> GetFunctionName() const;
82
+
83
+ /**
84
+ * Returns whether or not the associated function is compiled via a call to
85
+ * eval().
86
+ */
87
+ bool IsEval() const;
88
+
89
+ /**
90
+ * Returns whether or not the associated function is called as a
91
+ * constructor via "new".
92
+ */
93
+ bool IsConstructor() const;
94
+
95
+ /**
96
+ * Returns whether or not the associated functions is defined in wasm.
97
+ */
98
+ bool IsWasm() const;
99
+
100
+ /**
101
+ * Returns whether or not the associated function is defined by the user.
102
+ */
103
+ bool IsUserJavaScript() const;
104
+ };
105
+
106
+ /**
107
+ * Representation of a JavaScript stack trace. The information collected is a
108
+ * snapshot of the execution stack and the information remains valid after
109
+ * execution continues.
110
+ */
111
+ class V8_EXPORT StackTrace {
112
+ public:
113
+ /**
114
+ * Flags that determine what information is placed captured for each
115
+ * StackFrame when grabbing the current stack trace.
116
+ * Note: these options are deprecated and we always collect all available
117
+ * information (kDetailed).
118
+ */
119
+ enum StackTraceOptions {
120
+ kLineNumber = 1,
121
+ kColumnOffset = 1 << 1 | kLineNumber,
122
+ kScriptName = 1 << 2,
123
+ kFunctionName = 1 << 3,
124
+ kIsEval = 1 << 4,
125
+ kIsConstructor = 1 << 5,
126
+ kScriptNameOrSourceURL = 1 << 6,
127
+ kScriptId = 1 << 7,
128
+ kExposeFramesAcrossSecurityOrigins = 1 << 8,
129
+ kOverview = kLineNumber | kColumnOffset | kScriptName | kFunctionName,
130
+ kDetailed = kOverview | kIsEval | kIsConstructor | kScriptNameOrSourceURL
131
+ };
132
+
133
+ /**
134
+ * Returns a StackFrame at a particular index.
135
+ */
136
+ Local<StackFrame> GetFrame(Isolate* isolate, uint32_t index) const;
137
+
138
+ /**
139
+ * Returns the number of StackFrames.
140
+ */
141
+ int GetFrameCount() const;
142
+
143
+ /**
144
+ * Grab a snapshot of the current JavaScript execution stack.
145
+ *
146
+ * \param frame_limit The maximum number of stack frames we want to capture.
147
+ * \param options Enumerates the set of things we will capture for each
148
+ * StackFrame.
149
+ */
150
+ static Local<StackTrace> CurrentStackTrace(
151
+ Isolate* isolate, int frame_limit, StackTraceOptions options = kDetailed);
152
+
153
+ /**
154
+ * Returns the first valid script name or source URL starting at the top of
155
+ * the JS stack. The returned string is either an empty handle if no script
156
+ * name/url was found or a non-zero-length string.
157
+ *
158
+ * This method is equivalent to calling StackTrace::CurrentStackTrace and
159
+ * walking the resulting frames from the beginning until a non-empty script
160
+ * name/url is found. The difference is that this method won't allocate
161
+ * a stack trace.
162
+ */
163
+ static Local<String> CurrentScriptNameOrSourceURL(Isolate* isolate);
164
+ };
165
+
166
+ } // namespace v8
167
+
168
+ #endif // INCLUDE_V8_DEBUG_H_