mirror of
https://github.com/RGBCube/serenity
synced 2026-01-12 23:20:59 +00:00
LibJS: Return Optional<T> from Completion::{value,target}(), not T
In the end this is a nicer API than having separate has_{value,target}()
and having to check those first, and then making another Optional from
the unwrapped value:
completion.has_value() ? completion.value() : Optional<Value> {}
// ^^^^^^^^^^^^^^^^^^
// Implicit creation of non-empty Optional<Value>
This way we need to unwrap the optional ourselves, but can easily pass
it to something else as well.
This is in anticipation of the AST using completions :^)
This commit is contained in:
parent
b39aede8fe
commit
85f0fc2b83
15 changed files with 55 additions and 57 deletions
|
|
@ -254,7 +254,7 @@ void GetVariable::execute_impl(Bytecode::Interpreter& interpreter) const
|
|||
|
||||
auto reference_or_error = interpreter.vm().resolve_binding(string);
|
||||
if (reference_or_error.is_throw_completion()) {
|
||||
interpreter.vm().throw_exception(interpreter.global_object(), reference_or_error.release_error().value());
|
||||
interpreter.vm().throw_exception(interpreter.global_object(), *reference_or_error.release_error().value());
|
||||
return Reference {};
|
||||
}
|
||||
|
||||
|
|
@ -278,7 +278,7 @@ void SetVariable::execute_impl(Bytecode::Interpreter& interpreter) const
|
|||
auto& vm = interpreter.vm();
|
||||
auto reference_or_error = vm.resolve_binding(interpreter.current_executable().get_identifier(m_identifier));
|
||||
if (reference_or_error.is_throw_completion()) {
|
||||
interpreter.vm().throw_exception(interpreter.global_object(), reference_or_error.release_error().value());
|
||||
interpreter.vm().throw_exception(interpreter.global_object(), *reference_or_error.release_error().value());
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue