mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-26 18:09:45 +00:00 
			
		
		
		
	This reverts commit c14173f651. We
should only annotate the minimum number of symbols that external
consumers actually use, so I am starting from scratch to do that
		
	
			
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
 | |
|  * Copyright (c) 2023, Luke Wilde <lukew@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/Variant.h>
 | |
| #include <LibJS/Bytecode/Interpreter.h>
 | |
| #include <LibJS/Runtime/ExecutionContext.h>
 | |
| #include <LibJS/Runtime/Object.h>
 | |
| 
 | |
| namespace JS {
 | |
| 
 | |
| // 27.6.2 Properties of AsyncGenerator Instances, https://tc39.es/ecma262/#sec-properties-of-asyncgenerator-intances
 | |
| class AsyncGenerator final : public Object {
 | |
|     JS_OBJECT(AsyncGenerator, Object);
 | |
|     GC_DECLARE_ALLOCATOR(AsyncGenerator);
 | |
| 
 | |
| public:
 | |
|     enum class State {
 | |
|         SuspendedStart,
 | |
|         SuspendedYield,
 | |
|         Executing,
 | |
|         AwaitingReturn,
 | |
|         Completed,
 | |
|     };
 | |
| 
 | |
|     static ThrowCompletionOr<GC::Ref<AsyncGenerator>> create(Realm&, Value, ECMAScriptFunctionObject*, NonnullOwnPtr<ExecutionContext>);
 | |
| 
 | |
|     virtual ~AsyncGenerator() override;
 | |
| 
 | |
|     void async_generator_enqueue(Completion, GC::Ref<PromiseCapability>);
 | |
|     ThrowCompletionOr<void> resume(VM&, Completion completion);
 | |
|     void await_return();
 | |
|     void complete_step(Completion, bool done, Realm* realm = nullptr);
 | |
|     void drain_queue();
 | |
| 
 | |
|     State async_generator_state() const { return m_async_generator_state; }
 | |
|     void set_async_generator_state(Badge<AsyncGeneratorPrototype>, State value);
 | |
| 
 | |
|     Optional<String> const& generator_brand() const { return m_generator_brand; }
 | |
| 
 | |
| private:
 | |
|     AsyncGenerator(Realm&, Object& prototype, NonnullOwnPtr<ExecutionContext>);
 | |
| 
 | |
|     virtual void visit_edges(Cell::Visitor&) override;
 | |
| 
 | |
|     void execute(VM&, Completion completion);
 | |
|     ThrowCompletionOr<void> await(Value);
 | |
| 
 | |
|     // At the time of constructing an AsyncGenerator, we still need to point to an
 | |
|     // execution context on the stack, but later need to 'adopt' it.
 | |
|     State m_async_generator_state { State::SuspendedStart };   // [[AsyncGeneratorState]]
 | |
|     NonnullOwnPtr<ExecutionContext> m_async_generator_context; // [[AsyncGeneratorContext]]
 | |
|     Vector<AsyncGeneratorRequest> m_async_generator_queue;     // [[AsyncGeneratorQueue]]
 | |
|     Optional<String> m_generator_brand;                        // [[GeneratorBrand]]
 | |
| 
 | |
|     GC::Ptr<ECMAScriptFunctionObject> m_generating_function;
 | |
|     Value m_previous_value;
 | |
|     GC::Ptr<Promise> m_current_promise;
 | |
| };
 | |
| 
 | |
| }
 |