diff --git a/Userland/Libraries/LibJS/AST.h b/Userland/Libraries/LibJS/AST.h index dd2395e810a..d243453aeb3 100644 --- a/Userland/Libraries/LibJS/AST.h +++ b/Userland/Libraries/LibJS/AST.h @@ -660,6 +660,7 @@ public: virtual Value execute(Interpreter&, GlobalObject&) const override; virtual void dump(int indent) const override; + virtual Optional generate_bytecode(Bytecode::Generator&) const override; private: String m_value; diff --git a/Userland/Libraries/LibJS/Bytecode/ASTCodegen.cpp b/Userland/Libraries/LibJS/Bytecode/ASTCodegen.cpp index e473aadf73f..8b56fa54cec 100644 --- a/Userland/Libraries/LibJS/Bytecode/ASTCodegen.cpp +++ b/Userland/Libraries/LibJS/Bytecode/ASTCodegen.cpp @@ -208,6 +208,13 @@ Optional NullLiteral::generate_bytecode(Bytecode::Generator& return dst; } +Optional BigIntLiteral::generate_bytecode(Bytecode::Generator& generator) const +{ + auto dst = generator.allocate_register(); + generator.emit(dst, Crypto::SignedBigInteger::from_base10(m_value.substring(0, m_value.length() - 1))); + return dst; +} + Optional StringLiteral::generate_bytecode(Bytecode::Generator& generator) const { auto dst = generator.allocate_register(); diff --git a/Userland/Libraries/LibJS/Bytecode/Instruction.h b/Userland/Libraries/LibJS/Bytecode/Instruction.h index 5679c47a922..6bea827a35e 100644 --- a/Userland/Libraries/LibJS/Bytecode/Instruction.h +++ b/Userland/Libraries/LibJS/Bytecode/Instruction.h @@ -26,6 +26,7 @@ O(AbstractEquals) \ O(TypedInequals) \ O(TypedEquals) \ + O(NewBigInt) \ O(NewString) \ O(NewObject) \ O(GetVariable) \ diff --git a/Userland/Libraries/LibJS/Bytecode/Op.cpp b/Userland/Libraries/LibJS/Bytecode/Op.cpp index 32057060f50..e2691681ed8 100644 --- a/Userland/Libraries/LibJS/Bytecode/Op.cpp +++ b/Userland/Libraries/LibJS/Bytecode/Op.cpp @@ -8,6 +8,7 @@ #include #include #include +#include #include #include #include @@ -112,6 +113,11 @@ static Value typeof_(GlobalObject& global_object, Value value) JS_ENUMERATE_COMMON_UNARY_OPS(JS_DEFINE_COMMON_UNARY_OP) +void NewBigInt::execute(Bytecode::Interpreter& interpreter) const +{ + interpreter.reg(m_dst) = js_bigint(interpreter.vm().heap(), m_bigint); +} + void NewString::execute(Bytecode::Interpreter& interpreter) const { interpreter.reg(m_dst) = js_string(interpreter.vm(), m_string); @@ -231,6 +237,11 @@ String LoadRegister::to_string() const return String::formatted("LoadRegister dst:{}, src:{}", m_dst, m_src); } +String NewBigInt::to_string() const +{ + return String::formatted("NewBigInt dst:{}, bigint:\"{}\"", m_dst, m_bigint.to_base10()); +} + String NewString::to_string() const { return String::formatted("NewString dst:{}, string:\"{}\"", m_dst, m_string); diff --git a/Userland/Libraries/LibJS/Bytecode/Op.h b/Userland/Libraries/LibJS/Bytecode/Op.h index b80b744a772..fb286ef2fa8 100644 --- a/Userland/Libraries/LibJS/Bytecode/Op.h +++ b/Userland/Libraries/LibJS/Bytecode/Op.h @@ -8,6 +8,7 @@ #pragma once #include +#include #include #include #include @@ -157,6 +158,23 @@ private: Register m_dst; }; +class NewBigInt final : public Instruction { +public: + explicit NewBigInt(Register dst, Crypto::SignedBigInteger bigint) + : Instruction(Type::NewBigInt) + , m_dst(dst) + , m_bigint(move(bigint)) + { + } + + void execute(Bytecode::Interpreter&) const; + String to_string() const; + +private: + Register m_dst; + Crypto::SignedBigInteger m_bigint; +}; + class SetVariable final : public Instruction { public: SetVariable(FlyString identifier, Register src)