| // Copyright 2024 the V8 project authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef V8_OBJECTS_JS_DISPOSABLE_STACK_H_ |
| #define V8_OBJECTS_JS_DISPOSABLE_STACK_H_ |
| |
| #include "src/base/bit-field.h" |
| #include "src/handles/handles.h" |
| #include "src/handles/maybe-handles.h" |
| #include "src/objects/contexts.h" |
| #include "src/objects/heap-object.h" |
| #include "src/objects/js-objects.h" |
| #include "src/objects/js-promise.h" |
| #include "torque-generated/bit-fields.h" |
| |
| // Has to be the last include (doesn't have include guards): |
| #include "src/objects/object-macros.h" |
| |
| namespace v8 { |
| namespace internal { |
| |
| #include "torque-generated/src/objects/js-disposable-stack-tq.inc" |
| |
| // Valid states for a DisposableStack. |
| // https://arai-a.github.io/ecma262-compare/?pr=3000&id=sec-disposablestack-objects |
| enum class DisposableStackState { kDisposed, kPending }; |
| |
| // kValueIsReceiver: Call the method with no argument |
| // kValueIsArgument: Pass the value as the argument to the dispose method, |
| // `disposablestack.prototype.adopt` is the only method that uses |
| // kValueIsArgument as DisposeMethodCallType. |
| enum class DisposeMethodCallType { kValueIsReceiver = 0, kValueIsArgument = 1 }; |
| |
| // Valid hints for a DisposableStack. |
| // https://arai-a.github.io/ecma262-compare/?pr=3000&id=sec-disposableresource-records |
| enum class DisposeMethodHint { kSyncDispose = 0, kAsyncDispose = 1 }; |
| |
| // Types of disposable resources in a DisposableStack. |
| enum class DisposableStackResourcesType { kAllSync, kAtLeastOneAsync }; |
| |
| using DisposeCallTypeBit = |
| base::BitField<DisposeMethodCallType, 0, 1, uint32_t>; |
| using DisposeHintBit = DisposeCallTypeBit::Next<DisposeMethodHint, 1>; |
| |
| class JSDisposableStackBase |
| : public TorqueGeneratedJSDisposableStackBase<JSDisposableStackBase, |
| JSObject> { |
| public: |
| DECL_PRINTER(JSDisposableStackBase) |
| DECL_VERIFIER(JSDisposableStackBase) |
| |
| DEFINE_TORQUE_GENERATED_DISPOSABLE_STACK_STATUS() |
| inline DisposableStackState state() const; |
| inline void set_state(DisposableStackState value); |
| DECL_BOOLEAN_ACCESSORS(needs_await) |
| DECL_BOOLEAN_ACCESSORS(has_awaited) |
| DECL_BOOLEAN_ACCESSORS(suppressed_error_created) |
| DECL_INT_ACCESSORS(length) |
| |
| enum class AsyncDisposableStackContextSlots { |
| kStack = Context::MIN_CONTEXT_SLOTS, |
| kOuterPromise, |
| kLength, |
| }; |
| |
| enum class AsyncDisposeFromSyncDisposeContextSlots { |
| kMethod = Context::MIN_CONTEXT_SLOTS, |
| kLength, |
| }; |
| |
| static void InitializeJSDisposableStackBase( |
| Isolate* isolate, DirectHandle<JSDisposableStackBase> stack); |
| static void Add(Isolate* isolate, |
| DirectHandle<JSDisposableStackBase> disposable_stack, |
| DirectHandle<Object> value, DirectHandle<Object> method, |
| DisposeMethodCallType type, DisposeMethodHint hint); |
| static MaybeDirectHandle<Object> CheckValueAndGetDisposeMethod( |
| Isolate* isolate, DirectHandle<JSAny> value, DisposeMethodHint hint); |
| static MaybeDirectHandle<Object> DisposeResources( |
| Isolate* isolate, DirectHandle<JSDisposableStackBase> disposable_stack, |
| MaybeHandle<Object> maybe_continuation_error, |
| DisposableStackResourcesType resources_type); |
| static MaybeDirectHandle<JSReceiver> ResolveAPromiseWithValueAndReturnIt( |
| Isolate* isolate, DirectHandle<Object> value); |
| static void HandleErrorInDisposal( |
| Isolate* isolate, DirectHandle<JSDisposableStackBase> disposable_stack, |
| Handle<Object> current_error, DirectHandle<Object> current_error_message); |
| |
| TQ_OBJECT_CONSTRUCTORS(JSDisposableStackBase) |
| }; |
| |
| class JSSyncDisposableStack |
| : public TorqueGeneratedJSSyncDisposableStack<JSSyncDisposableStack, |
| JSDisposableStackBase> { |
| public: |
| DECL_VERIFIER(JSSyncDisposableStack) |
| |
| TQ_OBJECT_CONSTRUCTORS(JSSyncDisposableStack) |
| }; |
| |
| class JSAsyncDisposableStack |
| : public TorqueGeneratedJSAsyncDisposableStack<JSAsyncDisposableStack, |
| JSDisposableStackBase> { |
| public: |
| DECL_PRINTER(JSAsyncDisposableStack) |
| DECL_VERIFIER(JSAsyncDisposableStack) |
| |
| static Maybe<bool> NextDisposeAsyncIteration( |
| Isolate* isolate, |
| DirectHandle<JSDisposableStackBase> async_disposable_stack, |
| DirectHandle<JSPromise> outer_promise); |
| |
| TQ_OBJECT_CONSTRUCTORS(JSAsyncDisposableStack) |
| }; |
| |
| } // namespace internal |
| } // namespace v8 |
| |
| #include "src/objects/object-macros-undef.h" |
| |
| #endif // V8_OBJECTS_JS_DISPOSABLE_STACK_H_ |