summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSoni L. <EnderMoneyMod@gmail.com>2024-11-20 14:51:48 -0300
committerGitHub <noreply@github.com>2024-11-20 09:51:48 -0800
commita0b7abef00b59eeafed58c774195189425d020b0 (patch)
tree6f7b0747d3a3ef435bda9ac14ca22d417877796b
parent958d0a72030227bf3133c8b99c7c670bcdbc7636 (diff)
downloadwabt-a0b7abef00b59eeafed58c774195189425d020b0.tar.gz
wabt-a0b7abef00b59eeafed58c774195189425d020b0.tar.bz2
wabt-a0b7abef00b59eeafed58c774195189425d020b0.zip
binary/wat: Implement EHv4 (#2470)
This pull request implements EHv4. Binary is mostly untested until interp is working.
-rw-r--r--include/wabt/binary-reader-logging.h3
-rw-r--r--include/wabt/binary-reader-nop.h5
-rw-r--r--include/wabt/binary-reader.h10
-rw-r--r--include/wabt/common.h8
-rw-r--r--include/wabt/expr-visitor.h7
-rw-r--r--include/wabt/ir.h29
-rw-r--r--include/wabt/opcode.def2
-rw-r--r--include/wabt/shared-validator.h4
-rw-r--r--include/wabt/token.def4
-rw-r--r--include/wabt/type-checker.h5
-rw-r--r--include/wabt/wast-parser.h1
-rw-r--r--src/apply-names.cc19
-rw-r--r--src/binary-reader-ir.cc32
-rw-r--r--src/binary-reader-logging.cc34
-rw-r--r--src/binary-reader-objdump.cc46
-rw-r--r--src/binary-reader.cc39
-rw-r--r--src/binary-writer.cc23
-rw-r--r--src/c-writer.cc2
-rw-r--r--src/expr-visitor.cc23
-rw-r--r--src/generate-names.cc6
-rw-r--r--src/interp/interp.cc2
-rw-r--r--src/interp/istream.cc2
-rw-r--r--src/ir-util.cc7
-rw-r--r--src/ir.cc2
-rw-r--r--src/lexer-keywords.txt4
-rw-r--r--src/opcode.cc2
-rw-r--r--src/prebuilt/lexer-keywords.cc2589
-rw-r--r--src/resolve-names.cc19
-rw-r--r--src/shared-validator.cc40
-rw-r--r--src/type-checker.cc35
-rw-r--r--src/validator.cc24
-rw-r--r--src/wast-parser.cc77
-rw-r--r--src/wat-writer.cc106
-rw-r--r--test/parse/expr/try-table.txt21
-rw-r--r--test/parse/func/bad-local-binding-no-type.txt2
-rw-r--r--test/parse/func/bad-local-binding.txt2
-rw-r--r--test/parse/func/bad-param-binding.txt2
-rw-r--r--test/parse/module/bad-array-no-fields.txt2
-rw-r--r--test/roundtrip/fold-try-table.txt35
-rw-r--r--test/roundtrip/fold-unreachable.txt16
-rw-r--r--test/roundtrip/try-table.txt38
-rw-r--r--test/spec/obsolete-keywords.txt2
-rwxr-xr-xtest/update-spec-tests.py1
43 files changed, 2011 insertions, 1321 deletions
diff --git a/include/wabt/binary-reader-logging.h b/include/wabt/binary-reader-logging.h
index fd166011..4a031f74 100644
--- a/include/wabt/binary-reader-logging.h
+++ b/include/wabt/binary-reader-logging.h
@@ -232,7 +232,10 @@ class BinaryReaderLogging : public BinaryReaderDelegate {
Address alignment_log2,
Address offset) override;
Result OnThrowExpr(Index tag_index) override;
+ Result OnThrowRefExpr() override;
Result OnTryExpr(Type sig_type) override;
+ Result OnTryTableExpr(Type sig_type,
+ const CatchClauseVector& catches) override;
Result OnUnaryExpr(Opcode opcode) override;
Result OnTernaryExpr(Opcode opcode) override;
Result OnUnreachableExpr() override;
diff --git a/include/wabt/binary-reader-nop.h b/include/wabt/binary-reader-nop.h
index 85906062..fdb7d14a 100644
--- a/include/wabt/binary-reader-nop.h
+++ b/include/wabt/binary-reader-nop.h
@@ -319,7 +319,12 @@ class BinaryReaderNop : public BinaryReaderDelegate {
return Result::Ok;
}
Result OnThrowExpr(Index depth) override { return Result::Ok; }
+ Result OnThrowRefExpr() override { return Result::Ok; }
Result OnTryExpr(Type sig_type) override { return Result::Ok; }
+ Result OnTryTableExpr(Type sig_type,
+ const CatchClauseVector& catches) override {
+ return Result::Ok;
+ }
Result OnUnaryExpr(Opcode opcode) override { return Result::Ok; }
Result OnTernaryExpr(Opcode opcode) override { return Result::Ok; }
Result OnUnreachableExpr() override { return Result::Ok; }
diff --git a/include/wabt/binary-reader.h b/include/wabt/binary-reader.h
index 90161264..94b19c11 100644
--- a/include/wabt/binary-reader.h
+++ b/include/wabt/binary-reader.h
@@ -59,6 +59,13 @@ struct TypeMut {
};
using TypeMutVector = std::vector<TypeMut>;
+struct CatchClause {
+ CatchKind kind;
+ Index tag;
+ Index depth;
+};
+using CatchClauseVector = std::vector<CatchClause>;
+
class BinaryReaderDelegate {
public:
struct State {
@@ -302,7 +309,10 @@ class BinaryReaderDelegate {
Address alignment_log2,
Address offset) = 0;
virtual Result OnThrowExpr(Index tag_index) = 0;
+ virtual Result OnThrowRefExpr() = 0;
virtual Result OnTryExpr(Type sig_type) = 0;
+ virtual Result OnTryTableExpr(Type sig_type,
+ const CatchClauseVector& catches) = 0;
virtual Result OnUnaryExpr(Opcode opcode) = 0;
virtual Result OnTernaryExpr(Opcode opcode) = 0;
diff --git a/include/wabt/common.h b/include/wabt/common.h
index 6962f06d..e1411b48 100644
--- a/include/wabt/common.h
+++ b/include/wabt/common.h
@@ -194,6 +194,7 @@ enum class LabelType {
If,
Else,
Try,
+ TryTable,
Catch,
First = Func,
@@ -239,6 +240,13 @@ enum class SegmentKind {
Declared,
};
+enum class CatchKind {
+ Catch,
+ CatchRef,
+ CatchAll,
+ CatchAllRef,
+};
+
// Used in test asserts for special expected values "nan:canonical" and
// "nan:arithmetic"
enum class ExpectedNan {
diff --git a/include/wabt/expr-visitor.h b/include/wabt/expr-visitor.h
index cbc317cd..5be78793 100644
--- a/include/wabt/expr-visitor.h
+++ b/include/wabt/expr-visitor.h
@@ -41,6 +41,7 @@ class ExprVisitor {
IfFalse,
Loop,
Try,
+ TryTable,
Catch,
};
@@ -73,6 +74,8 @@ class ExprVisitor::Delegate {
virtual Result OnBrExpr(BrExpr*) = 0;
virtual Result OnBrIfExpr(BrIfExpr*) = 0;
virtual Result OnBrTableExpr(BrTableExpr*) = 0;
+ virtual Result BeginTryTableExpr(TryTableExpr*) = 0;
+ virtual Result EndTryTableExpr(TryTableExpr*) = 0;
virtual Result OnCallExpr(CallExpr*) = 0;
virtual Result OnCallIndirectExpr(CallIndirectExpr*) = 0;
virtual Result OnCallRefExpr(CallRefExpr*) = 0;
@@ -122,6 +125,7 @@ class ExprVisitor::Delegate {
virtual Result OnDelegateExpr(TryExpr*) = 0;
virtual Result EndTryExpr(TryExpr*) = 0;
virtual Result OnThrowExpr(ThrowExpr*) = 0;
+ virtual Result OnThrowRefExpr(ThrowRefExpr*) = 0;
virtual Result OnRethrowExpr(RethrowExpr*) = 0;
virtual Result OnAtomicWaitExpr(AtomicWaitExpr*) = 0;
virtual Result OnAtomicFenceExpr(AtomicFenceExpr*) = 0;
@@ -147,6 +151,8 @@ class ExprVisitor::DelegateNop : public ExprVisitor::Delegate {
Result OnBrExpr(BrExpr*) override { return Result::Ok; }
Result OnBrIfExpr(BrIfExpr*) override { return Result::Ok; }
Result OnBrTableExpr(BrTableExpr*) override { return Result::Ok; }
+ Result BeginTryTableExpr(TryTableExpr*) override { return Result::Ok; }
+ Result EndTryTableExpr(TryTableExpr*) override { return Result::Ok; }
Result OnCallExpr(CallExpr*) override { return Result::Ok; }
Result OnCallIndirectExpr(CallIndirectExpr*) override { return Result::Ok; }
Result OnCallRefExpr(CallRefExpr*) override { return Result::Ok; }
@@ -198,6 +204,7 @@ class ExprVisitor::DelegateNop : public ExprVisitor::Delegate {
Result OnDelegateExpr(TryExpr*) override { return Result::Ok; }
Result EndTryExpr(TryExpr*) override { return Result::Ok; }
Result OnThrowExpr(ThrowExpr*) override { return Result::Ok; }
+ Result OnThrowRefExpr(ThrowRefExpr*) override { return Result::Ok; }
Result OnRethrowExpr(RethrowExpr*) override { return Result::Ok; }
Result OnAtomicWaitExpr(AtomicWaitExpr*) override { return Result::Ok; }
Result OnAtomicFenceExpr(AtomicFenceExpr*) override { return Result::Ok; }
diff --git a/include/wabt/ir.h b/include/wabt/ir.h
index e300b66c..25264bcd 100644
--- a/include/wabt/ir.h
+++ b/include/wabt/ir.h
@@ -21,11 +21,11 @@
#include <cstddef>
#include <cstdint>
#include <memory>
+#include <set>
#include <string>
#include <string_view>
#include <type_traits>
#include <vector>
-#include <set>
#include "wabt/binding-hash.h"
#include "wabt/common.h"
@@ -422,7 +422,9 @@ enum class ExprType {
TableFill,
Ternary,
Throw,
+ ThrowRef,
Try,
+ TryTable,
Unary,
Unreachable,
@@ -460,6 +462,21 @@ struct Catch {
};
using CatchVector = std::vector<Catch>;
+struct TableCatch {
+ explicit TableCatch(const Location& loc = Location()) : loc(loc) {}
+ Location loc;
+ Var tag;
+ Var target;
+ CatchKind kind;
+ bool IsCatchAll() const {
+ return kind == CatchKind::CatchAll || kind == CatchKind::CatchAllRef;
+ }
+ bool IsRef() const {
+ return kind == CatchKind::CatchRef || kind == CatchKind::CatchAllRef;
+ }
+};
+using TryTableVector = std::vector<TableCatch>;
+
enum class TryKind { Plain, Catch, Delegate };
class Expr : public intrusive_list_base<Expr> {
@@ -516,6 +533,7 @@ using DropExpr = ExprMixin<ExprType::Drop>;
using NopExpr = ExprMixin<ExprType::Nop>;
using ReturnExpr = ExprMixin<ExprType::Return>;
using UnreachableExpr = ExprMixin<ExprType::Unreachable>;
+using ThrowRefExpr = ExprMixin<ExprType::ThrowRef>;
using MemoryGrowExpr = MemoryExpr<ExprType::MemoryGrow>;
using MemorySizeExpr = MemoryExpr<ExprType::MemorySize>;
@@ -743,6 +761,15 @@ class IfExpr : public ExprMixin<ExprType::If> {
Location false_end_loc;
};
+class TryTableExpr : public ExprMixin<ExprType::TryTable> {
+ public:
+ explicit TryTableExpr(const Location& loc = Location())
+ : ExprMixin<ExprType::TryTable>(loc) {}
+
+ Block block;
+ TryTableVector catches;
+};
+
class TryExpr : public ExprMixin<ExprType::Try> {
public:
explicit TryExpr(const Location& loc = Location())
diff --git a/include/wabt/opcode.def b/include/wabt/opcode.def
index bebab458..f8369ea7 100644
--- a/include/wabt/opcode.def
+++ b/include/wabt/opcode.def
@@ -45,6 +45,7 @@ WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x06, Try, "try", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x07, Catch, "catch", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x08, Throw, "throw", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x09, Rethrow, "rethrow", "")
+WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x0a, ThrowRef, "throw_ref", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x0b, End, "end", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x0c, Br, "br", "")
WABT_OPCODE(___, I32, ___, ___, 0, 0, 0x0d, BrIf, "br_if", "")
@@ -60,6 +61,7 @@ WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x19, CatchAll, "catch_all", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x1a, Drop, "drop", "")
WABT_OPCODE(___, ___, ___, I32, 0, 0, 0x1b, Select, "select", "")
WABT_OPCODE(___, ___, ___, I32, 0, 0, 0x1c, SelectT, "select", "")
+WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x1f, TryTable, "try_table", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x20, LocalGet, "local.get", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x21, LocalSet, "local.set", "")
WABT_OPCODE(___, ___, ___, ___, 0, 0, 0x22, LocalTee, "local.tee", "")
diff --git a/include/wabt/shared-validator.h b/include/wabt/shared-validator.h
index df02b594..fa7f5aba 100644
--- a/include/wabt/shared-validator.h
+++ b/include/wabt/shared-validator.h
@@ -211,7 +211,11 @@ class SharedValidator {
Result OnTableSize(const Location&, Var table_var);
Result OnTernary(const Location&, Opcode);
Result OnThrow(const Location&, Var tag_var);
+ Result OnThrowRef(const Location&);
Result OnTry(const Location&, Type sig_type);
+ Result BeginTryTable(const Location&, Type sig_type);
+ Result OnTryTableCatch(const Location&, const TableCatch&);
+ Result EndTryTable(const Location&, Type sig_type);
Result OnUnary(const Location&, Opcode);
Result OnUnreachable(const Location&);
diff --git a/include/wabt/token.def b/include/wabt/token.def
index 53d1fabb..f2f05aec 100644
--- a/include/wabt/token.def
+++ b/include/wabt/token.def
@@ -105,6 +105,8 @@ WABT_TOKEN(CallIndirect, "call_indirect")
WABT_TOKEN(CallRef, "call_ref")
WABT_TOKEN(Catch, "catch")
WABT_TOKEN(CatchAll, "catch_all")
+WABT_TOKEN(CatchRef, "catch_ref")
+WABT_TOKEN(CatchAllRef, "catch_all_ref")
WABT_TOKEN(Compare, "COMPARE")
WABT_TOKEN(Const, "CONST")
WABT_TOKEN(Convert, "CONVERT")
@@ -151,7 +153,9 @@ WABT_TOKEN(TableSet, "table.set")
WABT_TOKEN(TableSize, "table.size")
WABT_TOKEN(Ternary, "TERNARY")
WABT_TOKEN(Throw, "throw")
+WABT_TOKEN(ThrowRef, "throw_ref")
WABT_TOKEN(Try, "try")
+WABT_TOKEN(TryTable, "try_table")
WABT_TOKEN(Unary, "UNARY")
WABT_TOKEN(Unreachable, "unreachable")
WABT_TOKEN_FIRST(Opcode, AtomicFence)
diff --git a/include/wabt/type-checker.h b/include/wabt/type-checker.h
index 7b3f4192..85575c3c 100644
--- a/include/wabt/type-checker.h
+++ b/include/wabt/type-checker.h
@@ -128,7 +128,12 @@ class TypeChecker {
Result OnStore(Opcode, const Limits& limits);
Result OnTernary(Opcode);
Result OnThrow(const TypeVector& sig);
+ Result OnThrowRef();
Result OnTry(const TypeVector& param_types, const TypeVector& result_types);
+ Result OnTryTableCatch(const TypeVector& sig, Index);
+ Result BeginTryTable(const TypeVector& param_types);
+ Result EndTryTable(const TypeVector& param_types,
+ const TypeVector& result_types);
Result OnUnary(Opcode);
Result OnUnreachable();
Result EndFunction();
diff --git a/include/wabt/wast-parser.h b/include/wabt/wast-parser.h
index 8ba71e47..34b73e71 100644
--- a/include/wabt/wast-parser.h
+++ b/include/wabt/wast-parser.h
@@ -203,6 +203,7 @@ class WastParser {
Result ParseBlock(Block*);
Result ParseExprList(ExprList*);
Result ParseExpr(ExprList*);
+ Result ParseTryTableCatches(TryTableVector* catches);
Result ParseCatchInstrList(CatchVector* catches);
Result ParseCatchExprList(CatchVector* catches);
Result ParseGlobalType(Global*);
diff --git a/src/apply-names.cc b/src/apply-names.cc
index 6d531be2..c8516c8c 100644
--- a/src/apply-names.cc
+++ b/src/apply-names.cc
@@ -73,6 +73,8 @@ class NameApplier : public ExprVisitor::DelegateNop {
Result OnStoreExpr(StoreExpr*) override;
Result BeginTryExpr(TryExpr*) override;
Result EndTryExpr(TryExpr*) override;
+ Result BeginTryTableExpr(TryTableExpr*) override;
+ Result EndTryTableExpr(TryTableExpr*) override;
Result OnCatchExpr(TryExpr*, Catch*) override;
Result OnDelegateExpr(TryExpr*) override;
Result OnThrowExpr(ThrowExpr*) override;
@@ -369,6 +371,23 @@ Result NameApplier::EndTryExpr(TryExpr*) {
return Result::Ok;
}
+Result NameApplier::BeginTryTableExpr(TryTableExpr* expr) {
+ for (TableCatch& catch_ : expr->catches) {
+ if (!catch_.IsCatchAll()) {
+ CHECK_RESULT(UseNameForTagVar(&catch_.tag));
+ }
+ std::string_view label = FindLabelByVar(&catch_.target);
+ UseNameForVar(label, &catch_.target);
+ }
+ PushLabel(expr->block.label);
+ return Result::Ok;
+}
+
+Result NameApplier::EndTryTableExpr(TryTableExpr*) {
+ PopLabel();
+ return Result::Ok;
+}
+
Result NameApplier::OnCatchExpr(TryExpr*, Catch* expr) {
if (!expr->IsCatchAll()) {
CHECK_RESULT(UseNameForTagVar(&expr->var));
diff --git a/src/binary-reader-ir.cc b/src/binary-reader-ir.cc
index 04b2e90b..2029b0f7 100644
--- a/src/binary-reader-ir.cc
+++ b/src/binary-reader-ir.cc
@@ -258,7 +258,10 @@ class BinaryReaderIR : public BinaryReaderNop {
Address alignment_log2,
Address offset) override;
Result OnThrowExpr(Index tag_index) override;
+ Result OnThrowRefExpr() override;
Result OnTryExpr(Type sig_type) override;
+ Result OnTryTableExpr(Type sig_type,
+ const CatchClauseVector& catches) override;
Result OnUnaryExpr(Opcode opcode) override;
Result OnTernaryExpr(Opcode opcode) override;
Result OnUnreachableExpr() override;
@@ -999,6 +1002,9 @@ Result BinaryReaderIR::OnEndExpr() {
case LabelType::Try:
cast<TryExpr>(expr)->block.end_loc = GetLocation();
break;
+ case LabelType::TryTable:
+ cast<TryTableExpr>(expr)->block.end_loc = GetLocation();
+ break;
case LabelType::InitExpr:
case LabelType::Func:
@@ -1195,6 +1201,11 @@ Result BinaryReaderIR::OnThrowExpr(Index tag_index) {
return AppendExpr(std::make_unique<ThrowExpr>(Var(tag_index, GetLocation())));
}
+Result BinaryReaderIR::OnThrowRefExpr() {
+ module_->features_used.exceptions = true;
+ return AppendExpr(std::make_unique<ThrowRefExpr>());
+}
+
Result BinaryReaderIR::OnLocalTeeExpr(Index local_index) {
return AppendExpr(
std::make_unique<LocalTeeExpr>(Var(local_index, GetLocation())));
@@ -1248,6 +1259,27 @@ Result BinaryReaderIR::OnCatchAllExpr() {
return AppendCatch(Catch(GetLocation()));
}
+Result BinaryReaderIR::OnTryTableExpr(Type sig_type,
+ const CatchClauseVector& catches) {
+ auto expr_ptr = std::make_unique<TryTableExpr>();
+ TryTableExpr* expr = expr_ptr.get();
+ expr->catches.reserve(catches.size());
+ SetBlockDeclaration(&expr->block.decl, sig_type);
+ ExprList* expr_list = &expr->block.exprs;
+
+ for (auto& raw_catch : catches) {
+ TableCatch catch_;
+ catch_.kind = raw_catch.kind;
+ catch_.tag = Var(raw_catch.tag, GetLocation());
+ catch_.target = Var(raw_catch.depth, GetLocation());
+ expr->catches.push_back(std::move(catch_));
+ }
+
+ CHECK_RESULT(AppendExpr(std::move(expr_ptr)));
+ module_->features_used.exceptions = true;
+ return PushLabel(LabelType::TryTable, expr_list, expr);
+}
+
Result BinaryReaderIR::OnDelegateExpr(Index depth) {
LabelNode* label = nullptr;
CHECK_RESULT(TopLabel(&label));
diff --git a/src/binary-reader-logging.cc b/src/binary-reader-logging.cc
index 0c3fcda6..0c136225 100644
--- a/src/binary-reader-logging.cc
+++ b/src/binary-reader-logging.cc
@@ -394,6 +394,39 @@ Result BinaryReaderLogging::OnTryExpr(Type sig_type) {
return reader_->OnTryExpr(sig_type);
}
+Result BinaryReaderLogging::OnTryTableExpr(Type sig_type,
+ const CatchClauseVector& catches) {
+ LOGF("OnTryTableExpr(sig: ");
+ LogType(sig_type);
+ Index count = catches.size();
+ LOGF_NOINDENT(", n: %" PRIindex ", catches: [", count);
+
+ for (auto& catch_ : catches) {
+ auto tag = catch_.tag;
+ auto depth = catch_.depth;
+ switch (catch_.kind) {
+ case CatchKind::Catch:
+ LOGF_NOINDENT("catch %" PRIindex " %" PRIindex, tag, depth);
+ break;
+ case CatchKind::CatchRef:
+ LOGF_NOINDENT("catch_ref %" PRIindex " %" PRIindex, tag, depth);
+ break;
+ case CatchKind::CatchAll:
+ LOGF_NOINDENT("catch_all %" PRIindex, depth);
+ break;
+ case CatchKind::CatchAllRef:
+ LOGF_NOINDENT("catch_all_ref %" PRIindex, depth);
+ break;
+ }
+ if (--count != 0) {
+ LOGF_NOINDENT(", ");
+ }
+ }
+ LOGF_NOINDENT("])\n");
+
+ return reader_->OnTryTableExpr(sig_type, catches);
+}
+
Result BinaryReaderLogging::OnSimdLaneOpExpr(Opcode opcode, uint64_t value) {
LOGF("OnSimdLaneOpExpr (lane: %" PRIu64 ")\n", value);
return reader_->OnSimdLaneOpExpr(opcode, value);
@@ -852,6 +885,7 @@ DEFINE_LOAD_STORE_OPCODE(OnLoadZeroExpr);
DEFINE_LOAD_STORE_OPCODE(OnStoreExpr);
DEFINE_INDEX_DESC(OnThrowExpr, "tag_index")
DEFINE0(OnUnreachableExpr)
+DEFINE0(OnThrowRefExpr)
DEFINE_OPCODE(OnUnaryExpr)
DEFINE_OPCODE(OnTernaryExpr)
DEFINE_SIMD_LOAD_STORE_LANE_OPCODE(OnSimdLoadLaneExpr);
diff --git a/src/binary-reader-objdump.cc b/src/binary-reader-objdump.cc
index 52e6d27a..80850541 100644
--- a/src/binary-reader-objdump.cc
+++ b/src/binary-reader-objdump.cc
@@ -548,6 +548,8 @@ class BinaryReaderObjdumpDisassemble : public BinaryReaderObjdumpBase {
Result OnOpcodeBlockSig(Type sig_type) override;
Result OnOpcodeType(Type type) override;
+ Result OnTryTableExpr(Type sig_type,
+ const CatchClauseVector& catches) override;
Result OnBrTableExpr(Index num_targets,
Index* target_depths,
Index default_target_depth) override;
@@ -903,6 +905,50 @@ Result BinaryReaderObjdumpDisassemble::OnOpcodeType(Type type) {
return Result::Ok;
}
+Result BinaryReaderObjdumpDisassemble::OnTryTableExpr(
+ Type sig_type,
+ const CatchClauseVector& catches) {
+ if (!in_function_body) {
+ return Result::Ok;
+ }
+
+ std::string buffer = std::string();
+
+ if (sig_type != Type::Void) {
+ buffer.append(BlockSigToString(sig_type).c_str()).append(" ");
+ }
+
+ for (auto& catch_ : catches) {
+ switch (catch_.kind) {
+ case CatchKind::Catch:
+ buffer.append("catch ");
+ break;
+ case CatchKind::CatchRef:
+ buffer.append("catch_ref ");
+ break;
+ case CatchKind::CatchAll:
+ buffer.append("catch_all ");
+ break;
+ case CatchKind::CatchAllRef:
+ buffer.append("catch_all_ref ");
+ break;
+ }
+ if (catch_.kind == CatchKind::Catch || catch_.kind == CatchKind::CatchRef) {
+ buffer.append(std::to_string(catch_.tag));
+ }
+ buffer.append(" ").append(std::to_string(catch_.depth)).append(" ");
+ }
+
+ if (!buffer.empty()) {
+ // remove trailing space
+ buffer.pop_back();
+ }
+
+ LogOpcode("%s", buffer.c_str());
+ indent_level++;
+ return Result::Ok;
+}
+
Result BinaryReaderObjdumpDisassemble::OnBrTableExpr(
Index num_targets,
Index* target_depths,
diff --git a/src/binary-reader.cc b/src/binary-reader.cc
index 18b57e05..7b0b4187 100644
--- a/src/binary-reader.cc
+++ b/src/binary-reader.cc
@@ -192,6 +192,7 @@ class BinaryReader {
TypeVector result_types_;
TypeMutVector fields_;
std::vector<Index> target_depths_;
+ CatchClauseVector catches_;
const ReadBinaryOptions& options_;
BinarySection last_known_section_ = BinarySection::Invalid;
bool did_read_names_section_ = false;
@@ -1524,6 +1525,38 @@ Result BinaryReader::ReadInstructions(Offset end_offset, const char* context) {
break;
}
+ case Opcode::TryTable: {
+ nested_blocks.push(opcode);
+ Type sig_type;
+ CHECK_RESULT(ReadType(&sig_type, "try_table signature type"));
+ ERROR_UNLESS(IsBlockType(sig_type),
+ "expected valid block signature type");
+ Index count;
+ CHECK_RESULT(ReadCount(&count, "catch count"));
+
+ catches_.resize(count);
+ for (Index i = 0; i < count; i++) {
+ uint8_t handler;
+ CHECK_RESULT(ReadU8(&handler, "catch handler"));
+ ERROR_UNLESS(handler < 4, "expected valid catch handler");
+ bool is_catch_all = handler & 2;
+ Index tag = kInvalidIndex;
+ if (!(is_catch_all)) {
+ CHECK_RESULT(ReadIndex(&tag, "catch tag"));
+ }
+ Index depth;
+ CHECK_RESULT(ReadIndex(&depth, "catch depth"));
+ CatchClause catch_;
+ catch_.kind = CatchKind(handler);
+ catch_.tag = tag;
+ catch_.depth = depth;
+ catches_[i] = catch_;
+ }
+
+ CALLBACK(OnTryTableExpr, sig_type, catches_);
+ break;
+ }
+
case Opcode::Catch: {
Index index;
CHECK_RESULT(ReadIndex(&index, "tag index"));
@@ -1565,6 +1598,12 @@ Result BinaryReader::ReadInstructions(Offset end_offset, const char* context) {
break;
}
+ case Opcode::ThrowRef: {
+ CALLBACK(OnThrowRefExpr);
+ CALLBACK(OnOpcodeBare);
+ break;
+ }
+
case Opcode::I32Extend8S:
case Opcode::I32Extend16S:
case Opcode::I64Extend8S:
diff --git a/src/binary-writer.cc b/src/binary-writer.cc
index 60863d62..600154b9 100644
--- a/src/binary-writer.cc
+++ b/src/binary-writer.cc
@@ -1050,6 +1050,9 @@ void BinaryWriter::WriteExpr(const Func* func, const Expr* expr) {
WriteU32Leb128(stream_, GetTagVarDepth(&cast<ThrowExpr>(expr)->var),
"throw tag");
break;
+ case ExprType::ThrowRef:
+ WriteOpcode(stream_, Opcode::ThrowRef);
+ break;
case ExprType::Try: {
auto* try_expr = cast<TryExpr>(expr);
WriteOpcode(stream_, Opcode::Try);
@@ -1079,6 +1082,26 @@ void BinaryWriter::WriteExpr(const Func* func, const Expr* expr) {
}
break;
}
+ case ExprType::TryTable: {
+ auto* try_table_expr = cast<TryTableExpr>(expr);
+ WriteOpcode(stream_, Opcode::TryTable);
+ WriteBlockDecl(try_table_expr->block.decl);
+ WriteU32Leb128(stream_, try_table_expr->catches.size(), "num catches");
+ for (const TableCatch& catch_ : try_table_expr->catches) {
+ uint8_t catch_type =
+ (catch_.IsCatchAll() ? 2 : 0) | (catch_.IsRef() ? 1 : 0);
+ stream_->WriteU8(catch_type, "catch handler");
+ if (!catch_.IsCatchAll()) {
+ Index tag = GetTagVarDepth(&catch_.tag);
+ WriteU32Leb128(stream_, tag, "catch tag");
+ }
+ Index depth = GetLabelVarDepth(&catch_.target);
+ WriteU32Leb128(stream_, depth, "catch depth");
+ }
+ WriteExprList(func, try_table_expr->block.exprs);
+ WriteOpcode(stream_, Opcode::End);
+ break;
+ }
case ExprType::Unary:
WriteOpcode(stream_, cast<UnaryExpr>(expr)->opcode);
break;
diff --git a/src/c-writer.cc b/src/c-writer.cc
index 76ff52f9..7a0c548b 100644
--- a/src/c-writer.cc
+++ b/src/c-writer.cc
@@ -4129,6 +4129,8 @@ void CWriter::Write(const ExprList& exprs) {
case ExprType::AtomicWait:
case ExprType::AtomicNotify:
case ExprType::CallRef:
+ case ExprType::ThrowRef:
+ case ExprType::TryTable:
UNIMPLEMENTED("...");
break;
}
diff --git a/src/expr-visitor.cc b/src/expr-visitor.cc
index 05cd2798..217d45cc 100644
--- a/src/expr-visitor.cc
+++ b/src/expr-visitor.cc
@@ -90,6 +90,18 @@ Result ExprVisitor::VisitExpr(Expr* root_expr) {
break;
}
+ case State::TryTable: {
+ auto try_table_expr = cast<TryTableExpr>(expr);
+ auto& iter = expr_iter_stack_.back();
+ if (iter != try_table_expr->block.exprs.end()) {
+ PushDefault(&*iter++);
+ } else {
+ CHECK_RESULT(delegate_->EndTryTableExpr(try_table_expr));
+ PopExprlist();
+ }
+ break;
+ }
+
case State::Try: {
auto try_expr = cast<TryExpr>(expr);
auto& iter = expr_iter_stack_.back();
@@ -386,6 +398,17 @@ Result ExprVisitor::HandleDefaultState(Expr* expr) {
CHECK_RESULT(delegate_->OnThrowExpr(cast<ThrowExpr>(expr)));
break;
+ case ExprType::ThrowRef:
+ CHECK_RESULT(delegate_->OnThrowRefExpr(cast<ThrowRefExpr>(expr)));
+ break;
+
+ case ExprType::TryTable: {
+ auto try_table_expr = cast<TryTableExpr>(expr);
+ CHECK_RESULT(delegate_->BeginTryTableExpr(try_table_expr));
+ PushExprlist(State::TryTable, expr, try_table_expr->block.exprs);
+ break;
+ }
+
case ExprType::Try: {
auto try_expr = cast<TryExpr>(expr);
CHECK_RESULT(delegate_->BeginTryExpr(try_expr));
diff --git a/src/generate-names.cc b/src/generate-names.cc
index ec3612d7..d029db84 100644
--- a/src/generate-names.cc
+++ b/src/generate-names.cc
@@ -38,6 +38,7 @@ class NameGenerator : public ExprVisitor::DelegateNop {
// Implementation of ExprVisitor::DelegateNop.
Result BeginBlockExpr(BlockExpr* expr) override;
Result BeginTryExpr(TryExpr* expr) override;
+ Result BeginTryTableExpr(TryTableExpr* expr) override;
Result BeginLoopExpr(LoopExpr* expr) override;
Result BeginIfExpr(IfExpr* expr) override;
@@ -218,6 +219,11 @@ Result NameGenerator::BeginTryExpr(TryExpr* expr) {
return Result::Ok;
}
+Result NameGenerator::BeginTryTableExpr(TryTableExpr* expr) {
+ MaybeGenerateName("T", label_count_++, &expr->block.label);
+ return Result::Ok;
+}
+
Result NameGenerator::BeginLoopExpr(LoopExpr* expr) {
MaybeGenerateName("L", label_count_++, &expr->block.label);
return Result::Ok;
diff --git a/src/interp/interp.cc b/src/interp/interp.cc
index f93fa5a6..800d81f3 100644
--- a/src/interp/interp.cc
+++ b/src/interp/interp.cc
@@ -1978,6 +1978,8 @@ RunResult Thread::StepInternal(Trap::Ptr* out_trap) {
case O::Delegate:
case O::InterpData:
case O::Invalid:
+ case O::TryTable:
+ case O::ThrowRef:
WABT_UNREACHABLE;
break;
}
diff --git a/src/interp/istream.cc b/src/interp/istream.cc
index 8e5cb5a3..25627ba2 100644
--- a/src/interp/istream.cc
+++ b/src/interp/istream.cc
@@ -794,6 +794,8 @@ Instr Istream::Read(Offset* offset) const {
case Opcode::Loop:
case Opcode::Try:
case Opcode::ReturnCall:
+ case Opcode::TryTable:
+ case Opcode::ThrowRef:
// Not used.
break;
}
diff --git a/src/ir-util.cc b/src/ir-util.cc
index ee9262cc..5266a264 100644
--- a/src/ir-util.cc
+++ b/src/ir-util.cc
@@ -223,9 +223,16 @@ ModuleContext::Arities ModuleContext::GetExprArity(const Expr& expr) const {
return {operand_count, 0, true};
}
+ case ExprType::ThrowRef: {
+ return {1, 1, true};
+ }
+
case ExprType::Try:
return {0, cast<TryExpr>(&expr)->block.decl.sig.GetNumResults()};
+ case ExprType::TryTable:
+ return {0, cast<TryTableExpr>(&expr)->block.decl.sig.GetNumResults()};
+
case ExprType::Ternary:
return {3, 1};
diff --git a/src/ir.cc b/src/ir.cc
index 88db7d5f..a2f9c48e 100644
--- a/src/ir.cc
+++ b/src/ir.cc
@@ -85,7 +85,9 @@ const char* ExprTypeName[] = {
"TableFill",
"Ternary",
"Throw",
+ "ThrowRef",
"Try",
+ "TryTable",
"Unary",
"Unreachable",
};
diff --git a/src/lexer-keywords.txt b/src/lexer-keywords.txt
index 1c72983b..5923c710 100644
--- a/src/lexer-keywords.txt
+++ b/src/lexer-keywords.txt
@@ -38,6 +38,8 @@ call_ref, TokenType::CallRef, Opcode::CallRef
call, TokenType::Call, Opcode::Call
catch, TokenType::Catch, Opcode::Catch
catch_all, TokenType::CatchAll, Opcode::CatchAll
+catch_ref, TokenType::CatchRef
+catch_all_ref, TokenType::CatchAllRef
code, TokenType::Code
data.drop, TokenType::DataDrop, Opcode::DataDrop
data, TokenType::Data
@@ -584,7 +586,9 @@ table.size, TokenType::TableSize, Opcode::TableSize
table, TokenType::Table
then, TokenType::Then
throw, TokenType::Throw, Opcode::Throw
+throw_ref, TokenType::ThrowRef, Opcode::ThrowRef
try, TokenType::Try, Opcode::Try
+try_table, TokenType::TryTable, Opcode::TryTable
type, TokenType::Type
unreachable, TokenType::Unreachable, Opcode::Unreachable
v128.andnot, TokenType::Binary, Opcode::V128Andnot
diff --git a/src/opcode.cc b/src/opcode.cc
index 3a62fa71..023ae0b2 100644
--- a/src/opcode.cc
+++ b/src/opcode.cc
@@ -67,6 +67,8 @@ bool Opcode::IsEnabled(const Features& features) const {
case Opcode::Catch:
case Opcode::Delegate:
case Opcode::Throw:
+ case Opcode::ThrowRef:
+ case Opcode::TryTable:
case Opcode::Rethrow:
return features.exceptions_enabled();
diff --git a/src/prebuilt/lexer-keywords.cc b/src/prebuilt/lexer-keywords.cc
index f04fc537..89f14dba 100644
--- a/src/prebuilt/lexer-keywords.cc
+++ b/src/prebuilt/lexer-keywords.cc
@@ -48,7 +48,7 @@ struct TokenInfo {
Opcode opcode;
};
};
-/* maximum key range = 2481, duplicates = 0 */
+/* maximum key range = 2193, duplicates = 0 */
class Perfect_Hash
{
@@ -63,32 +63,32 @@ Perfect_Hash::hash (const char *str, size_t len)
{
static unsigned short asso_values[] =
{
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 4, 2496, 2496, 683,
- 372, 5, 4, 4, 112, 565, 26, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 200, 4, 21, 865, 62,
- 74, 7, 722, 4, 263, 226, 10, 7, 6, 118,
- 43, 70, 510, 645, 5, 6, 15, 4, 663, 504,
- 34, 321, 59, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496, 2496,
- 2496, 2496, 2496, 2496, 2496, 2496, 2496
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 13, 2230, 2230, 426,
+ 351, 14, 17, 13, 176, 531, 32, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 183, 13, 16, 811, 21,
+ 68, 16, 326, 13, 347, 223, 20, 13, 15, 140,
+ 80, 54, 559, 611, 14, 15, 24, 13, 556, 521,
+ 125, 416, 213, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230, 2230,
+ 2230, 2230, 2230, 2230, 2230, 2230, 2230
};
unsigned int hval = len;
@@ -158,1631 +158,1607 @@ Perfect_Hash::InWordSet (const char *str, size_t len)
{
enum
{
- TOTAL_KEYWORDS = 597,
+ TOTAL_KEYWORDS = 601,
MIN_WORD_LENGTH = 2,
MAX_WORD_LENGTH = 35,
- MIN_HASH_VALUE = 15,
- MAX_HASH_VALUE = 2495
+ MIN_HASH_VALUE = 37,
+ MAX_HASH_VALUE = 2229
};
static struct TokenInfo wordlist[] =
{
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 150 "src/lexer-keywords.txt"
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""},
+#line 35 "src/lexer-keywords.txt"
+ {"br", TokenType::Br, Opcode::Br},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 152 "src/lexer-keywords.txt"
{"f64", Type::F64},
- {""}, {""}, {""}, {""}, {""},
-#line 462 "src/lexer-keywords.txt"
+ {""}, {""},
+#line 45 "src/lexer-keywords.txt"
+ {"data", TokenType::Data},
+ {""}, {""}, {""},
+#line 464 "src/lexer-keywords.txt"
{"i64", Type::I64},
-#line 120 "src/lexer-keywords.txt"
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""},
+#line 122 "src/lexer-keywords.txt"
{"f32x4", TokenType::F32X4},
- {""}, {""}, {""}, {""}, {""},
-#line 362 "src/lexer-keywords.txt"
+ {""}, {""}, {""}, {""},
+#line 586 "src/lexer-keywords.txt"
+ {"table", TokenType::Table},
+#line 48 "src/lexer-keywords.txt"
+ {"do", TokenType::Do},
+#line 364 "src/lexer-keywords.txt"
{"i32x4", TokenType::I32X4},
{""}, {""}, {""},
-#line 133 "src/lexer-keywords.txt"
+#line 135 "src/lexer-keywords.txt"
{"f64.ge", TokenType::Compare, Opcode::F64Ge},
-#line 72 "src/lexer-keywords.txt"
+#line 74 "src/lexer-keywords.txt"
{"f32.ge", TokenType::Compare, Opcode::F32Ge},
-#line 135 "src/lexer-keywords.txt"
+#line 137 "src/lexer-keywords.txt"
{"f64.le", TokenType::Compare, Opcode::F64Le},
-#line 74 "src/lexer-keywords.txt"
+#line 76 "src/lexer-keywords.txt"
{"f32.le", TokenType::Compare, Opcode::F32Le},
+ {""}, {""}, {""}, {""}, {""},
+#line 30 "src/lexer-keywords.txt"
+ {"before", TokenType::Before},
+ {""}, {""}, {""}, {""}, {""},
+#line 187 "src/lexer-keywords.txt"
+ {"func", Type::FuncRef, TokenType::Func},
+#line 136 "src/lexer-keywords.txt"
+ {"f64.gt", TokenType::Compare, Opcode::F64Gt},
+#line 75 "src/lexer-keywords.txt"
+ {"f32.gt", TokenType::Compare, Opcode::F32Gt},
+#line 139 "src/lexer-keywords.txt"
+ {"f64.lt", TokenType::Compare, Opcode::F64Lt},
+#line 78 "src/lexer-keywords.txt"
+ {"f32.lt", TokenType::Compare, Opcode::F32Lt},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""},
#line 43 "src/lexer-keywords.txt"
- {"data", TokenType::Data},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 98 "src/lexer-keywords.txt"
- {"f32x4.ge", TokenType::Compare, Opcode::F32X4Ge},
+ {"code", TokenType::Code},
+ {""}, {""}, {""},
+#line 570 "src/lexer-keywords.txt"
+ {"result", TokenType::Result},
{""},
#line 100 "src/lexer-keywords.txt"
+ {"f32x4.ge", TokenType::Compare, Opcode::F32X4Ge},
+ {""},
+#line 102 "src/lexer-keywords.txt"
{"f32x4.le", TokenType::Compare, Opcode::F32X4Le},
+ {""},
+#line 578 "src/lexer-keywords.txt"
+ {"struct", Type::Struct, TokenType::Struct},
+ {""}, {""}, {""}, {""}, {""},
+#line 555 "src/lexer-keywords.txt"
+ {"mut", TokenType::Mut},
+#line 441 "src/lexer-keywords.txt"
+ {"i64.or", TokenType::Binary, Opcode::I64Or},
+#line 298 "src/lexer-keywords.txt"
+ {"i32.or", TokenType::Binary, Opcode::I32Or},
{""}, {""},
-#line 134 "src/lexer-keywords.txt"
- {"f64.gt", TokenType::Compare, Opcode::F64Gt},
-#line 73 "src/lexer-keywords.txt"
- {"f32.gt", TokenType::Compare, Opcode::F32Gt},
-#line 137 "src/lexer-keywords.txt"
- {"f64.lt", TokenType::Compare, Opcode::F64Lt},
-#line 76 "src/lexer-keywords.txt"
- {"f32.lt", TokenType::Compare, Opcode::F32Lt},
-#line 328 "src/lexer-keywords.txt"
+#line 581 "src/lexer-keywords.txt"
+ {"table.get", TokenType::TableGet, Opcode::TableGet},
+#line 101 "src/lexer-keywords.txt"
+ {"f32x4.gt", TokenType::Compare, Opcode::F32X4Gt},
+#line 584 "src/lexer-keywords.txt"
+ {"table.set", TokenType::TableSet, Opcode::TableSet},
+#line 103 "src/lexer-keywords.txt"
+ {"f32x4.lt", TokenType::Compare, Opcode::F32X4Lt},
+#line 330 "src/lexer-keywords.txt"
{"i32x4.ge_u", TokenType::Compare, Opcode::I32X4GeU},
{""},
-#line 332 "src/lexer-keywords.txt"
+#line 334 "src/lexer-keywords.txt"
{"i32x4.le_u", TokenType::Compare, Opcode::I32X4LeU},
{""},
-#line 327 "src/lexer-keywords.txt"
+#line 329 "src/lexer-keywords.txt"
{"i32x4.ge_s", TokenType::Compare, Opcode::I32X4GeS},
- {""},
-#line 331 "src/lexer-keywords.txt"
+#line 93 "src/lexer-keywords.txt"
+ {"f32x4.ceil", TokenType::Unary, Opcode::F32X4Ceil},
+#line 333 "src/lexer-keywords.txt"
{"i32x4.le_s", TokenType::Compare, Opcode::I32X4LeS},
-#line 99 "src/lexer-keywords.txt"
- {"f32x4.gt", TokenType::Compare, Opcode::F32X4Gt},
-#line 330 "src/lexer-keywords.txt"
+ {""},
+#line 332 "src/lexer-keywords.txt"
{"i32x4.gt_u", TokenType::Compare, Opcode::I32X4GtU},
-#line 101 "src/lexer-keywords.txt"
- {"f32x4.lt", TokenType::Compare, Opcode::F32X4Lt},
-#line 340 "src/lexer-keywords.txt"
+ {""},
+#line 342 "src/lexer-keywords.txt"
{"i32x4.lt_u", TokenType::Compare, Opcode::I32X4LtU},
-#line 568 "src/lexer-keywords.txt"
- {"result", TokenType::Result},
-#line 329 "src/lexer-keywords.txt"
+ {""},
+#line 331 "src/lexer-keywords.txt"
{"i32x4.gt_s", TokenType::Compare, Opcode::I32X4GtS},
-#line 553 "src/lexer-keywords.txt"
- {"mut", TokenType::Mut},
-#line 339 "src/lexer-keywords.txt"
- {"i32x4.lt_s", TokenType::Compare, Opcode::I32X4LtS},
- {""}, {""},
-#line 35 "src/lexer-keywords.txt"
- {"br", TokenType::Br, Opcode::Br},
{""},
-#line 143 "src/lexer-keywords.txt"
+#line 341 "src/lexer-keywords.txt"
+ {"i32x4.lt_s", TokenType::Compare, Opcode::I32X4LtS},
+#line 145 "src/lexer-keywords.txt"
{"f64.ne", TokenType::Compare, Opcode::F64Ne},
-#line 82 "src/lexer-keywords.txt"
+#line 84 "src/lexer-keywords.txt"
{"f32.ne", TokenType::Compare, Opcode::F32Ne},
-#line 142 "src/lexer-keywords.txt"
- {"f64.neg", TokenType::Unary, Opcode::F64Neg},
-#line 81 "src/lexer-keywords.txt"
- {"f32.neg", TokenType::Unary, Opcode::F32Neg},
- {""},
-#line 552 "src/lexer-keywords.txt"
+ {""}, {""}, {""},
+#line 554 "src/lexer-keywords.txt"
{"module", TokenType::Module},
-#line 438 "src/lexer-keywords.txt"
+ {""},
+#line 440 "src/lexer-keywords.txt"
{"i64.ne", TokenType::Compare, Opcode::I64Ne},
-#line 295 "src/lexer-keywords.txt"
+#line 297 "src/lexer-keywords.txt"
{"i32.ne", TokenType::Compare, Opcode::I32Ne},
#line 46 "src/lexer-keywords.txt"
- {"do", TokenType::Do},
-#line 106 "src/lexer-keywords.txt"
- {"f32x4.neg", TokenType::Unary, Opcode::F32X4Neg},
- {""},
-#line 107 "src/lexer-keywords.txt"
- {"f32x4.ne", TokenType::Compare, Opcode::F32X4Ne},
-#line 566 "src/lexer-keywords.txt"
- {"ref.null", TokenType::RefNull, Opcode::RefNull},
- {""},
-#line 584 "src/lexer-keywords.txt"
- {"table", TokenType::Table},
-#line 347 "src/lexer-keywords.txt"
- {"i32x4.neg", TokenType::Unary, Opcode::I32X4Neg},
- {""},
-#line 348 "src/lexer-keywords.txt"
- {"i32x4.ne", TokenType::Compare, Opcode::I32X4Ne},
- {""}, {""},
-#line 30 "src/lexer-keywords.txt"
- {"before", TokenType::Before},
-#line 41 "src/lexer-keywords.txt"
- {"code", TokenType::Code},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 439 "src/lexer-keywords.txt"
- {"i64.or", TokenType::Binary, Opcode::I64Or},
-#line 296 "src/lexer-keywords.txt"
- {"i32.or", TokenType::Binary, Opcode::I32Or},
- {""}, {""}, {""}, {""},
-#line 105 "src/lexer-keywords.txt"
- {"f32x4.nearest", TokenType::Unary, Opcode::F32X4Nearest},
-#line 572 "src/lexer-keywords.txt"
- {"return", TokenType::Return, Opcode::Return},
-#line 91 "src/lexer-keywords.txt"
- {"f32x4.ceil", TokenType::Unary, Opcode::F32X4Ceil},
- {""}, {""}, {""},
-#line 579 "src/lexer-keywords.txt"
- {"table.get", TokenType::TableGet, Opcode::TableGet},
- {""},
-#line 582 "src/lexer-keywords.txt"
- {"table.set", TokenType::TableSet, Opcode::TableSet},
+ {"declare", TokenType::Declare},
{""},
-#line 141 "src/lexer-keywords.txt"
- {"f64.nearest", TokenType::Unary, Opcode::F64Nearest},
-#line 80 "src/lexer-keywords.txt"
- {"f32.nearest", TokenType::Unary, Opcode::F32Nearest},
+#line 144 "src/lexer-keywords.txt"
+ {"f64.neg", TokenType::Unary, Opcode::F64Neg},
+#line 83 "src/lexer-keywords.txt"
+ {"f32.neg", TokenType::Unary, Opcode::F32Neg},
{""},
-#line 576 "src/lexer-keywords.txt"
- {"struct", Type::Struct, TokenType::Struct},
-#line 147 "src/lexer-keywords.txt"
+#line 149 "src/lexer-keywords.txt"
{"f64.store", TokenType::Store, Opcode::F64Store},
-#line 85 "src/lexer-keywords.txt"
+#line 87 "src/lexer-keywords.txt"
{"f32.store", TokenType::Store, Opcode::F32Store},
-#line 445 "src/lexer-keywords.txt"
+ {""},
+#line 447 "src/lexer-keywords.txt"
{"i64.rotr", TokenType::Binary, Opcode::I64Rotr},
-#line 302 "src/lexer-keywords.txt"
+#line 304 "src/lexer-keywords.txt"
{"i32.rotr", TokenType::Binary, Opcode::I32Rotr},
-#line 444 "src/lexer-keywords.txt"
+#line 446 "src/lexer-keywords.txt"
{"i64.rotl", TokenType::Binary, Opcode::I64Rotl},
-#line 301 "src/lexer-keywords.txt"
+#line 303 "src/lexer-keywords.txt"
{"i32.rotl", TokenType::Binary, Opcode::I32Rotl},
-#line 452 "src/lexer-keywords.txt"
+#line 454 "src/lexer-keywords.txt"
{"i64.store", TokenType::Store, Opcode::I64Store},
-#line 308 "src/lexer-keywords.txt"
+#line 310 "src/lexer-keywords.txt"
{"i32.store", TokenType::Store, Opcode::I32Store},
-#line 44 "src/lexer-keywords.txt"
- {"declare", TokenType::Declare},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 494 "src/lexer-keywords.txt"
- {"i64.xor", TokenType::Binary, Opcode::I64Xor},
-#line 371 "src/lexer-keywords.txt"
- {"i32.xor", TokenType::Binary, Opcode::I32Xor},
- {""}, {""}, {""},
-#line 185 "src/lexer-keywords.txt"
- {"func", Type::FuncRef, TokenType::Func},
- {""}, {""}, {""}, {""}, {""},
-#line 149 "src/lexer-keywords.txt"
- {"f64.trunc", TokenType::Unary, Opcode::F64Trunc},
-#line 87 "src/lexer-keywords.txt"
- {"f32.trunc", TokenType::Unary, Opcode::F32Trunc},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 568 "src/lexer-keywords.txt"
+ {"ref.null", TokenType::RefNull, Opcode::RefNull},
+#line 108 "src/lexer-keywords.txt"
+ {"f32x4.neg", TokenType::Unary, Opcode::F32X4Neg},
{""},
-#line 140 "src/lexer-keywords.txt"
- {"f64.mul", TokenType::Binary, Opcode::F64Mul},
-#line 79 "src/lexer-keywords.txt"
- {"f32.mul", TokenType::Binary, Opcode::F32Mul},
+#line 109 "src/lexer-keywords.txt"
+ {"f32x4.ne", TokenType::Compare, Opcode::F32X4Ne},
+ {""}, {""}, {""}, {""},
+#line 349 "src/lexer-keywords.txt"
+ {"i32x4.neg", TokenType::Unary, Opcode::I32X4Neg},
+ {""},
+#line 350 "src/lexer-keywords.txt"
+ {"i32x4.ne", TokenType::Compare, Opcode::I32X4Ne},
{""}, {""},
-#line 118 "src/lexer-keywords.txt"
- {"f32x4.trunc", TokenType::Unary, Opcode::F32X4Trunc},
-#line 104 "src/lexer-keywords.txt"
- {"f32x4.mul", TokenType::Binary, Opcode::F32X4Mul},
-#line 437 "src/lexer-keywords.txt"
- {"i64.mul", TokenType::Binary, Opcode::I64Mul},
-#line 294 "src/lexer-keywords.txt"
- {"i32.mul", TokenType::Binary, Opcode::I32Mul},
+#line 151 "src/lexer-keywords.txt"
+ {"f64.trunc", TokenType::Unary, Opcode::F64Trunc},
+#line 89 "src/lexer-keywords.txt"
+ {"f32.trunc", TokenType::Unary, Opcode::F32Trunc},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""},
+#line 143 "src/lexer-keywords.txt"
+ {"f64.nearest", TokenType::Unary, Opcode::F64Nearest},
+#line 82 "src/lexer-keywords.txt"
+ {"f32.nearest", TokenType::Unary, Opcode::F32Nearest},
{""}, {""}, {""},
-#line 346 "src/lexer-keywords.txt"
- {"i32x4.mul", TokenType::Binary, Opcode::I32X4Mul},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 563 "src/lexer-keywords.txt"
- {"ref.extern", TokenType::RefExtern},
- {""}, {""},
-#line 451 "src/lexer-keywords.txt"
+#line 120 "src/lexer-keywords.txt"
+ {"f32x4.trunc", TokenType::Unary, Opcode::F32X4Trunc},
+#line 574 "src/lexer-keywords.txt"
+ {"return", TokenType::Return, Opcode::Return},
+ {""}, {""}, {""}, {""}, {""},
+#line 453 "src/lexer-keywords.txt"
{"i64.store8", TokenType::Store, Opcode::I64Store8},
-#line 307 "src/lexer-keywords.txt"
+#line 309 "src/lexer-keywords.txt"
{"i32.store8", TokenType::Store, Opcode::I32Store8},
- {""}, {""}, {""}, {""},
-#line 114 "src/lexer-keywords.txt"
- {"f32x4.replace_lane", TokenType::SimdLaneOp, Opcode::F32X4ReplaceLane},
- {""}, {""}, {""}, {""}, {""},
-#line 350 "src/lexer-keywords.txt"
- {"i32x4.replace_lane", TokenType::SimdLaneOp, Opcode::I32X4ReplaceLane},
- {""}, {""},
-#line 45 "src/lexer-keywords.txt"
- {"delegate", TokenType::Delegate},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 90 "src/lexer-keywords.txt"
+#line 142 "src/lexer-keywords.txt"
+ {"f64.mul", TokenType::Binary, Opcode::F64Mul},
+#line 81 "src/lexer-keywords.txt"
+ {"f32.mul", TokenType::Binary, Opcode::F32Mul},
+#line 92 "src/lexer-keywords.txt"
{"f32x4.add", TokenType::Binary, Opcode::F32X4Add},
+#line 107 "src/lexer-keywords.txt"
+ {"f32x4.nearest", TokenType::Unary, Opcode::F32X4Nearest},
{""}, {""}, {""},
-#line 102 "src/lexer-keywords.txt"
- {"f32x4.max", TokenType::Binary, Opcode::F32X4Max},
- {""},
-#line 321 "src/lexer-keywords.txt"
+#line 439 "src/lexer-keywords.txt"
+ {"i64.mul", TokenType::Binary, Opcode::I64Mul},
+#line 296 "src/lexer-keywords.txt"
+ {"i32.mul", TokenType::Binary, Opcode::I32Mul},
+#line 323 "src/lexer-keywords.txt"
{"i32x4.add", TokenType::Binary, Opcode::I32X4Add},
+ {""},
#line 38 "src/lexer-keywords.txt"
{"call", TokenType::Call, Opcode::Call},
- {""}, {""}, {""},
-#line 96 "src/lexer-keywords.txt"
- {"f32x4.extract_lane", TokenType::SimdLaneOp, Opcode::F32X4ExtractLane},
-#line 410 "src/lexer-keywords.txt"
- {"i64.clz", TokenType::Unary, Opcode::I64Clz},
-#line 272 "src/lexer-keywords.txt"
- {"i32.clz", TokenType::Unary, Opcode::I32Clz},
-#line 541 "src/lexer-keywords.txt"
- {"local", TokenType::Local},
- {""}, {""},
-#line 326 "src/lexer-keywords.txt"
- {"i32x4.extract_lane", TokenType::SimdLaneOp, Opcode::I32X4ExtractLane},
-#line 124 "src/lexer-keywords.txt"
+ {""},
+#line 126 "src/lexer-keywords.txt"
{"f64.const", TokenType::Const, Opcode::F64Const},
-#line 62 "src/lexer-keywords.txt"
+#line 64 "src/lexer-keywords.txt"
{"f32.const", TokenType::Const, Opcode::F32Const},
+ {""}, {""}, {""},
+#line 106 "src/lexer-keywords.txt"
+ {"f32x4.mul", TokenType::Binary, Opcode::F32X4Mul},
{""},
-#line 412 "src/lexer-keywords.txt"
- {"i64.ctz", TokenType::Unary, Opcode::I64Ctz},
-#line 274 "src/lexer-keywords.txt"
- {"i32.ctz", TokenType::Unary, Opcode::I32Ctz},
- {""},
-#line 411 "src/lexer-keywords.txt"
+#line 413 "src/lexer-keywords.txt"
{"i64.const", TokenType::Const, Opcode::I64Const},
-#line 273 "src/lexer-keywords.txt"
+#line 275 "src/lexer-keywords.txt"
{"i32.const", TokenType::Const, Opcode::I32Const},
{""},
-#line 138 "src/lexer-keywords.txt"
- {"f64.max", TokenType::Binary, Opcode::F64Max},
-#line 77 "src/lexer-keywords.txt"
- {"f32.max", TokenType::Binary, Opcode::F32Max},
- {""}, {""},
-#line 349 "src/lexer-keywords.txt"
- {"i32x4.relaxed_laneselect", TokenType::Ternary, Opcode::I32X4RelaxedLaneSelect},
- {""}, {""}, {""}, {""},
-#line 573 "src/lexer-keywords.txt"
+#line 575 "src/lexer-keywords.txt"
{"select", TokenType::Select, Opcode::Select},
{""},
+#line 348 "src/lexer-keywords.txt"
+ {"i32x4.mul", TokenType::Binary, Opcode::I32X4Mul},
+ {""},
+#line 543 "src/lexer-keywords.txt"
+ {"local", TokenType::Local},
+ {""}, {""}, {""},
+#line 496 "src/lexer-keywords.txt"
+ {"i64.xor", TokenType::Binary, Opcode::I64Xor},
#line 373 "src/lexer-keywords.txt"
+ {"i32.xor", TokenType::Binary, Opcode::I32Xor},
+#line 47 "src/lexer-keywords.txt"
+ {"delegate", TokenType::Delegate},
+ {""}, {""}, {""},
+#line 124 "src/lexer-keywords.txt"
+ {"f64.add", TokenType::Binary, Opcode::F64Add},
+#line 62 "src/lexer-keywords.txt"
+ {"f32.add", TokenType::Binary, Opcode::F32Add},
+#line 138 "src/lexer-keywords.txt"
+ {"f64.load", TokenType::Load, Opcode::F64Load},
+#line 77 "src/lexer-keywords.txt"
+ {"f32.load", TokenType::Load, Opcode::F32Load},
+ {""}, {""}, {""},
+#line 374 "src/lexer-keywords.txt"
+ {"i64.add", TokenType::Binary, Opcode::I64Add},
+#line 245 "src/lexer-keywords.txt"
+ {"i32.add", TokenType::Binary, Opcode::I32Add},
+#line 436 "src/lexer-keywords.txt"
+ {"i64.load", TokenType::Load, Opcode::I64Load},
+#line 293 "src/lexer-keywords.txt"
+ {"i32.load", TokenType::Load, Opcode::I32Load},
+ {""}, {""}, {""}, {""},
+#line 116 "src/lexer-keywords.txt"
+ {"f32x4.replace_lane", TokenType::SimdLaneOp, Opcode::F32X4ReplaceLane},
+ {""}, {""}, {""},
+#line 375 "src/lexer-keywords.txt"
{"i64.and", TokenType::Binary, Opcode::I64And},
-#line 244 "src/lexer-keywords.txt"
+#line 246 "src/lexer-keywords.txt"
{"i32.and", TokenType::Binary, Opcode::I32And},
- {""}, {""},
-#line 538 "src/lexer-keywords.txt"
- {"local.get", TokenType::LocalGet, Opcode::LocalGet},
{""},
-#line 539 "src/lexer-keywords.txt"
- {"local.set", TokenType::LocalSet, Opcode::LocalSet},
-#line 540 "src/lexer-keywords.txt"
- {"local.tee", TokenType::LocalTee, Opcode::LocalTee},
-#line 423 "src/lexer-keywords.txt"
+#line 352 "src/lexer-keywords.txt"
+ {"i32x4.replace_lane", TokenType::SimdLaneOp, Opcode::I32X4ReplaceLane},
+ {""}, {""}, {""},
+#line 425 "src/lexer-keywords.txt"
{"i64.ge_u", TokenType::Compare, Opcode::I64GeU},
-#line 282 "src/lexer-keywords.txt"
+#line 284 "src/lexer-keywords.txt"
{"i32.ge_u", TokenType::Compare, Opcode::I32GeU},
-#line 427 "src/lexer-keywords.txt"
+#line 429 "src/lexer-keywords.txt"
{"i64.le_u", TokenType::Compare, Opcode::I64LeU},
-#line 286 "src/lexer-keywords.txt"
+#line 288 "src/lexer-keywords.txt"
{"i32.le_u", TokenType::Compare, Opcode::I32LeU},
-#line 422 "src/lexer-keywords.txt"
+#line 424 "src/lexer-keywords.txt"
{"i64.ge_s", TokenType::Compare, Opcode::I64GeS},
-#line 281 "src/lexer-keywords.txt"
+#line 283 "src/lexer-keywords.txt"
{"i32.ge_s", TokenType::Compare, Opcode::I32GeS},
-#line 426 "src/lexer-keywords.txt"
+#line 428 "src/lexer-keywords.txt"
{"i64.le_s", TokenType::Compare, Opcode::I64LeS},
-#line 285 "src/lexer-keywords.txt"
+#line 287 "src/lexer-keywords.txt"
{"i32.le_s", TokenType::Compare, Opcode::I32LeS},
-#line 425 "src/lexer-keywords.txt"
+#line 427 "src/lexer-keywords.txt"
{"i64.gt_u", TokenType::Compare, Opcode::I64GtU},
-#line 284 "src/lexer-keywords.txt"
+#line 286 "src/lexer-keywords.txt"
{"i32.gt_u", TokenType::Compare, Opcode::I32GtU},
-#line 436 "src/lexer-keywords.txt"
+#line 438 "src/lexer-keywords.txt"
{"i64.lt_u", TokenType::Compare, Opcode::I64LtU},
-#line 293 "src/lexer-keywords.txt"
+#line 295 "src/lexer-keywords.txt"
{"i32.lt_u", TokenType::Compare, Opcode::I32LtU},
-#line 424 "src/lexer-keywords.txt"
+#line 426 "src/lexer-keywords.txt"
{"i64.gt_s", TokenType::Compare, Opcode::I64GtS},
-#line 283 "src/lexer-keywords.txt"
+#line 285 "src/lexer-keywords.txt"
{"i32.gt_s", TokenType::Compare, Opcode::I32GtS},
-#line 435 "src/lexer-keywords.txt"
+#line 437 "src/lexer-keywords.txt"
{"i64.lt_s", TokenType::Compare, Opcode::I64LtS},
-#line 292 "src/lexer-keywords.txt"
+#line 294 "src/lexer-keywords.txt"
{"i32.lt_s", TokenType::Compare, Opcode::I32LtS},
+ {""}, {""}, {""},
+#line 540 "src/lexer-keywords.txt"
+ {"local.get", TokenType::LocalGet, Opcode::LocalGet},
{""},
-#line 122 "src/lexer-keywords.txt"
- {"f64.add", TokenType::Binary, Opcode::F64Add},
-#line 60 "src/lexer-keywords.txt"
- {"f32.add", TokenType::Binary, Opcode::F32Add},
-#line 111 "src/lexer-keywords.txt"
- {"f32x4.relaxed_max", TokenType::Binary, Opcode::F32X4RelaxedMax},
-#line 136 "src/lexer-keywords.txt"
- {"f64.load", TokenType::Load, Opcode::F64Load},
-#line 75 "src/lexer-keywords.txt"
- {"f32.load", TokenType::Load, Opcode::F32Load},
- {""},
-#line 372 "src/lexer-keywords.txt"
- {"i64.add", TokenType::Binary, Opcode::I64Add},
-#line 243 "src/lexer-keywords.txt"
- {"i32.add", TokenType::Binary, Opcode::I32Add},
- {""},
-#line 434 "src/lexer-keywords.txt"
- {"i64.load", TokenType::Load, Opcode::I64Load},
-#line 291 "src/lexer-keywords.txt"
- {"i32.load", TokenType::Load, Opcode::I32Load},
- {""}, {""}, {""}, {""}, {""},
-#line 53 "src/lexer-keywords.txt"
- {"tag", TokenType::Tag},
- {""},
-#line 322 "src/lexer-keywords.txt"
- {"i32x4.all_true", TokenType::Unary, Opcode::I32X4AllTrue},
- {""},
-#line 112 "src/lexer-keywords.txt"
- {"f32x4.relaxed_min", TokenType::Binary, Opcode::F32X4RelaxedMin},
- {""}, {""}, {""}, {""},
-#line 417 "src/lexer-keywords.txt"
- {"i64.extend16_s", TokenType::Unary, Opcode::I64Extend16S},
-#line 279 "src/lexer-keywords.txt"
- {"i32.extend16_s", TokenType::Unary, Opcode::I32Extend16S},
-#line 187 "src/lexer-keywords.txt"
- {"get", TokenType::Get},
+#line 541 "src/lexer-keywords.txt"
+ {"local.set", TokenType::LocalSet, Opcode::LocalSet},
+#line 542 "src/lexer-keywords.txt"
+ {"local.tee", TokenType::LocalTee, Opcode::LocalTee},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""},
-#line 336 "src/lexer-keywords.txt"
- {"i32x4.relaxed_trunc_f64x2_u_zero", TokenType::Unary, Opcode::I32X4RelaxedTruncF64X2UZero},
{""},
-#line 335 "src/lexer-keywords.txt"
- {"i32x4.relaxed_trunc_f64x2_s_zero", TokenType::Unary, Opcode::I32X4RelaxedTruncF64X2SZero},
- {""}, {""},
-#line 446 "src/lexer-keywords.txt"
- {"i64.shl", TokenType::Binary, Opcode::I64Shl},
-#line 303 "src/lexer-keywords.txt"
- {"i32.shl", TokenType::Binary, Opcode::I32Shl},
- {""}, {""}, {""},
#line 351 "src/lexer-keywords.txt"
- {"i32x4.shl", TokenType::Binary, Opcode::I32X4Shl},
- {""},
-#line 455 "src/lexer-keywords.txt"
- {"i64.trunc_f32_u", TokenType::Convert, Opcode::I64TruncF32U},
-#line 311 "src/lexer-keywords.txt"
- {"i32.trunc_f32_u", TokenType::Convert, Opcode::I32TruncF32U},
- {""}, {""},
-#line 454 "src/lexer-keywords.txt"
- {"i64.trunc_f32_s", TokenType::Convert, Opcode::I64TruncF32S},
-#line 310 "src/lexer-keywords.txt"
- {"i32.trunc_f32_s", TokenType::Convert, Opcode::I32TruncF32S},
-#line 567 "src/lexer-keywords.txt"
- {"register", TokenType::Register},
+ {"i32x4.relaxed_laneselect", TokenType::Ternary, Opcode::I32X4RelaxedLaneSelect},
+#line 324 "src/lexer-keywords.txt"
+ {"i32x4.all_true", TokenType::Unary, Opcode::I32X4AllTrue},
{""},
-#line 429 "src/lexer-keywords.txt"
- {"i64.load16_u", TokenType::Load, Opcode::I64Load16U},
-#line 288 "src/lexer-keywords.txt"
- {"i32.load16_u", TokenType::Load, Opcode::I32Load16U},
- {""}, {""},
-#line 428 "src/lexer-keywords.txt"
- {"i64.load16_s", TokenType::Load, Opcode::I64Load16S},
-#line 287 "src/lexer-keywords.txt"
- {"i32.load16_s", TokenType::Load, Opcode::I32Load16S},
-#line 123 "src/lexer-keywords.txt"
+#line 125 "src/lexer-keywords.txt"
{"f64.ceil", TokenType::Unary, Opcode::F64Ceil},
-#line 61 "src/lexer-keywords.txt"
+#line 63 "src/lexer-keywords.txt"
{"f32.ceil", TokenType::Unary, Opcode::F32Ceil},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 583 "src/lexer-keywords.txt"
+#line 585 "src/lexer-keywords.txt"
{"table.size", TokenType::TableSize, Opcode::TableSize},
-#line 409 "src/lexer-keywords.txt"
+ {""}, {""}, {""},
+#line 104 "src/lexer-keywords.txt"
+ {"f32x4.max", TokenType::Binary, Opcode::F32X4Max},
+#line 535 "src/lexer-keywords.txt"
+ {"if", TokenType::If, Opcode::If},
+#line 411 "src/lexer-keywords.txt"
{"i64.atomic.store", TokenType::AtomicStore, Opcode::I64AtomicStore},
-#line 271 "src/lexer-keywords.txt"
+#line 273 "src/lexer-keywords.txt"
{"i32.atomic.store", TokenType::AtomicStore, Opcode::I32AtomicStore},
-#line 402 "src/lexer-keywords.txt"
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 563 "src/lexer-keywords.txt"
+ {"ref", TokenType::Ref},
+ {""}, {""},
+#line 404 "src/lexer-keywords.txt"
{"i64.atomic.rmw.or", TokenType::AtomicRmw, Opcode::I64AtomicRmwOr},
-#line 265 "src/lexer-keywords.txt"
+#line 267 "src/lexer-keywords.txt"
{"i32.atomic.rmw.or", TokenType::AtomicRmw, Opcode::I32AtomicRmwOr},
{""}, {""}, {""}, {""}, {""},
-#line 571 "src/lexer-keywords.txt"
+#line 573 "src/lexer-keywords.txt"
{"return_call", TokenType::ReturnCall, Opcode::ReturnCall},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 389 "src/lexer-keywords.txt"
- {"i64.atomic.rmw32.sub_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32SubU},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 443 "src/lexer-keywords.txt"
- {"i64.rem_u", TokenType::Binary, Opcode::I64RemU},
-#line 300 "src/lexer-keywords.txt"
- {"i32.rem_u", TokenType::Binary, Opcode::I32RemU},
-#line 442 "src/lexer-keywords.txt"
- {"i64.rem_s", TokenType::Binary, Opcode::I64RemS},
-#line 299 "src/lexer-keywords.txt"
- {"i32.rem_s", TokenType::Binary, Opcode::I32RemS},
- {""},
-#line 113 "src/lexer-keywords.txt"
- {"f32x4.relaxed_nmadd", TokenType::Ternary, Opcode::F32X4RelaxedNmadd},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 419 "src/lexer-keywords.txt"
- {"i64.extend8_s", TokenType::Unary, Opcode::I64Extend8S},
-#line 280 "src/lexer-keywords.txt"
- {"i32.extend8_s", TokenType::Unary, Opcode::I32Extend8S},
+ {""}, {""},
+#line 53 "src/lexer-keywords.txt"
+ {"else", TokenType::Else, Opcode::Else},
{""}, {""}, {""}, {""}, {""},
-#line 342 "src/lexer-keywords.txt"
- {"i32x4.max_u", TokenType::Binary, Opcode::I32X4MaxU},
+#line 55 "src/lexer-keywords.txt"
+ {"tag", TokenType::Tag},
{""},
-#line 341 "src/lexer-keywords.txt"
- {"i32x4.max_s", TokenType::Binary, Opcode::I32X4MaxS},
-#line 408 "src/lexer-keywords.txt"
- {"i64.atomic.store8", TokenType::AtomicStore, Opcode::I64AtomicStore8},
-#line 270 "src/lexer-keywords.txt"
- {"i32.atomic.store8", TokenType::AtomicStore, Opcode::I32AtomicStore8},
- {""}, {""},
-#line 88 "src/lexer-keywords.txt"
+#line 98 "src/lexer-keywords.txt"
+ {"f32x4.extract_lane", TokenType::SimdLaneOp, Opcode::F32X4ExtractLane},
+#line 565 "src/lexer-keywords.txt"
+ {"ref.extern", TokenType::RefExtern},
+#line 338 "src/lexer-keywords.txt"
+ {"i32x4.relaxed_trunc_f64x2_u_zero", TokenType::Unary, Opcode::I32X4RelaxedTruncF64X2UZero},
+#line 90 "src/lexer-keywords.txt"
{"f32", Type::F32},
- {""},
-#line 581 "src/lexer-keywords.txt"
- {"table.init", TokenType::TableInit, Opcode::TableInit},
-#line 587 "src/lexer-keywords.txt"
- {"try", TokenType::Try, Opcode::Try},
+#line 337 "src/lexer-keywords.txt"
+ {"i32x4.relaxed_trunc_f64x2_s_zero", TokenType::Unary, Opcode::I32X4RelaxedTruncF64X2SZero},
{""}, {""},
-#line 318 "src/lexer-keywords.txt"
+#line 328 "src/lexer-keywords.txt"
+ {"i32x4.extract_lane", TokenType::SimdLaneOp, Opcode::I32X4ExtractLane},
+ {""},
+#line 189 "src/lexer-keywords.txt"
+ {"get", TokenType::Get},
+#line 320 "src/lexer-keywords.txt"
{"i32", Type::I32},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 433 "src/lexer-keywords.txt"
+#line 50 "src/lexer-keywords.txt"
+ {"either", TokenType::Either},
+ {""}, {""},
+#line 391 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw32.sub_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32SubU},
+#line 435 "src/lexer-keywords.txt"
{"i64.load8_u", TokenType::Load, Opcode::I64Load8U},
-#line 290 "src/lexer-keywords.txt"
+#line 292 "src/lexer-keywords.txt"
{"i32.load8_u", TokenType::Load, Opcode::I32Load8U},
-#line 432 "src/lexer-keywords.txt"
+#line 434 "src/lexer-keywords.txt"
{"i64.load8_s", TokenType::Load, Opcode::I64Load8S},
-#line 289 "src/lexer-keywords.txt"
+#line 291 "src/lexer-keywords.txt"
{"i32.load8_s", TokenType::Load, Opcode::I32Load8S},
-#line 386 "src/lexer-keywords.txt"
- {"i64.atomic.rmw32.and_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32AndU},
- {""}, {""},
-#line 405 "src/lexer-keywords.txt"
- {"i64.atomic.rmw.xor", TokenType::AtomicRmw, Opcode::I64AtomicRmwXor},
-#line 268 "src/lexer-keywords.txt"
- {"i32.atomic.rmw.xor", TokenType::AtomicRmw, Opcode::I32AtomicRmwXor},
- {""},
-#line 158 "src/lexer-keywords.txt"
- {"f64x2.ge", TokenType::Compare, Opcode::F64X2Ge},
{""},
-#line 160 "src/lexer-keywords.txt"
- {"f64x2.le", TokenType::Compare, Opcode::F64X2Le},
-#line 103 "src/lexer-keywords.txt"
- {"f32x4.min", TokenType::Binary, Opcode::F32X4Min},
-#line 388 "src/lexer-keywords.txt"
- {"i64.atomic.rmw32.or_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32OrU},
-#line 110 "src/lexer-keywords.txt"
- {"f32x4.relaxed_madd", TokenType::Ternary, Opcode::F32X4RelaxedMadd},
+#line 410 "src/lexer-keywords.txt"
+ {"i64.atomic.store8", TokenType::AtomicStore, Opcode::I64AtomicStore8},
+#line 272 "src/lexer-keywords.txt"
+ {"i32.atomic.store8", TokenType::AtomicStore, Opcode::I32AtomicStore8},
+#line 431 "src/lexer-keywords.txt"
+ {"i64.load16_u", TokenType::Load, Opcode::I64Load16U},
+#line 290 "src/lexer-keywords.txt"
+ {"i32.load16_u", TokenType::Load, Opcode::I32Load16U},
#line 457 "src/lexer-keywords.txt"
- {"i64.trunc_f64_u", TokenType::Convert, Opcode::I64TruncF64U},
+ {"i64.trunc_f32_u", TokenType::Convert, Opcode::I64TruncF32U},
#line 313 "src/lexer-keywords.txt"
- {"i32.trunc_f64_u", TokenType::Convert, Opcode::I32TruncF64U},
- {""}, {""},
+ {"i32.trunc_f32_u", TokenType::Convert, Opcode::I32TruncF32U},
+#line 430 "src/lexer-keywords.txt"
+ {"i64.load16_s", TokenType::Load, Opcode::I64Load16S},
+#line 289 "src/lexer-keywords.txt"
+ {"i32.load16_s", TokenType::Load, Opcode::I32Load16S},
#line 456 "src/lexer-keywords.txt"
- {"i64.trunc_f64_s", TokenType::Convert, Opcode::I64TruncF64S},
+ {"i64.trunc_f32_s", TokenType::Convert, Opcode::I64TruncF32S},
#line 312 "src/lexer-keywords.txt"
- {"i32.trunc_f64_s", TokenType::Convert, Opcode::I32TruncF64S},
- {""},
-#line 473 "src/lexer-keywords.txt"
- {"i64x2.ge_s", TokenType::Binary, Opcode::I64X2GeS},
+ {"i32.trunc_f32_s", TokenType::Convert, Opcode::I32TruncF32S},
+#line 445 "src/lexer-keywords.txt"
+ {"i64.rem_u", TokenType::Binary, Opcode::I64RemU},
+#line 302 "src/lexer-keywords.txt"
+ {"i32.rem_u", TokenType::Binary, Opcode::I32RemU},
+#line 444 "src/lexer-keywords.txt"
+ {"i64.rem_s", TokenType::Binary, Opcode::I64RemS},
+#line 301 "src/lexer-keywords.txt"
+ {"i32.rem_s", TokenType::Binary, Opcode::I32RemS},
{""},
-#line 472 "src/lexer-keywords.txt"
- {"i64x2.le_s", TokenType::Binary, Opcode::I64X2LeS},
-#line 159 "src/lexer-keywords.txt"
- {"f64x2.gt", TokenType::Compare, Opcode::F64X2Gt},
+#line 54 "src/lexer-keywords.txt"
+ {"end", TokenType::End, Opcode::End},
{""},
-#line 161 "src/lexer-keywords.txt"
- {"f64x2.lt", TokenType::Compare, Opcode::F64X2Lt},
+#line 407 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw.xor", TokenType::AtomicRmw, Opcode::I64AtomicRmwXor},
+#line 270 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw.xor", TokenType::AtomicRmw, Opcode::I32AtomicRmwXor},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 587 "src/lexer-keywords.txt"
+ {"then", TokenType::Then},
+#line 583 "src/lexer-keywords.txt"
+ {"table.init", TokenType::TableInit, Opcode::TableInit},
{""}, {""},
-#line 471 "src/lexer-keywords.txt"
- {"i64x2.gt_s", TokenType::Binary, Opcode::I64X2GtS},
+#line 344 "src/lexer-keywords.txt"
+ {"i32x4.max_u", TokenType::Binary, Opcode::I32X4MaxU},
{""},
-#line 470 "src/lexer-keywords.txt"
- {"i64x2.lt_s", TokenType::Binary, Opcode::I64X2LtS},
+#line 343 "src/lexer-keywords.txt"
+ {"i32x4.max_s", TokenType::Binary, Opcode::I32X4MaxS},
{""},
-#line 385 "src/lexer-keywords.txt"
- {"i64.atomic.rmw32.add_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32AddU},
- {""}, {""}, {""}, {""}, {""},
#line 390 "src/lexer-keywords.txt"
- {"i64.atomic.rmw32.xchg_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32XchgU},
+ {"i64.atomic.rmw32.or_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32OrU},
+#line 448 "src/lexer-keywords.txt"
+ {"i64.shl", TokenType::Binary, Opcode::I64Shl},
+#line 305 "src/lexer-keywords.txt"
+ {"i32.shl", TokenType::Binary, Opcode::I32Shl},
{""}, {""},
-#line 391 "src/lexer-keywords.txt"
- {"i64.atomic.rmw32.xor_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32XorU},
-#line 139 "src/lexer-keywords.txt"
- {"f64.min", TokenType::Binary, Opcode::F64Min},
-#line 78 "src/lexer-keywords.txt"
- {"f32.min", TokenType::Binary, Opcode::F32Min},
-#line 166 "src/lexer-keywords.txt"
- {"f64x2.neg", TokenType::Unary, Opcode::F64X2Neg},
+#line 114 "src/lexer-keywords.txt"
+ {"f32x4.relaxed_min", TokenType::Binary, Opcode::F32X4RelaxedMin},
{""},
-#line 167 "src/lexer-keywords.txt"
- {"f64x2.ne", TokenType::Compare, Opcode::F64X2Ne},
- {""}, {""}, {""},
-#line 475 "src/lexer-keywords.txt"
- {"i64x2.neg", TokenType::Unary, Opcode::I64X2Neg},
+#line 115 "src/lexer-keywords.txt"
+ {"f32x4.relaxed_nmadd", TokenType::Ternary, Opcode::F32X4RelaxedNmadd},
+#line 140 "src/lexer-keywords.txt"
+ {"f64.max", TokenType::Binary, Opcode::F64Max},
+#line 79 "src/lexer-keywords.txt"
+ {"f32.max", TokenType::Binary, Opcode::F32Max},
+ {""}, {""},
+#line 160 "src/lexer-keywords.txt"
+ {"f64x2.ge", TokenType::Compare, Opcode::F64X2Ge},
{""},
-#line 469 "src/lexer-keywords.txt"
- {"i64x2.ne", TokenType::Binary, Opcode::I64X2Ne},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 398 "src/lexer-keywords.txt"
- {"i64.atomic.rmw8.xor_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8XorU},
-#line 261 "src/lexer-keywords.txt"
- {"i32.atomic.rmw8.xor_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8XorU},
+#line 162 "src/lexer-keywords.txt"
+ {"f64x2.le", TokenType::Compare, Opcode::F64X2Le},
{""}, {""},
-#line 377 "src/lexer-keywords.txt"
+#line 387 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw32.add_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32AddU},
+ {""},
+#line 353 "src/lexer-keywords.txt"
+ {"i32x4.shl", TokenType::Binary, Opcode::I32X4Shl},
+ {""}, {""},
+#line 569 "src/lexer-keywords.txt"
+ {"register", TokenType::Register},
+#line 379 "src/lexer-keywords.txt"
{"i64.atomic.load", TokenType::AtomicLoad, Opcode::I64AtomicLoad},
-#line 247 "src/lexer-keywords.txt"
+#line 249 "src/lexer-keywords.txt"
{"i32.atomic.load", TokenType::AtomicLoad, Opcode::I32AtomicLoad},
- {""}, {""},
-#line 165 "src/lexer-keywords.txt"
- {"f64x2.nearest", TokenType::Unary, Opcode::F64X2Nearest},
+ {""}, {""}, {""},
+#line 161 "src/lexer-keywords.txt"
+ {"f64x2.gt", TokenType::Compare, Opcode::F64X2Gt},
+#line 388 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw32.and_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32AndU},
+#line 163 "src/lexer-keywords.txt"
+ {"f64x2.lt", TokenType::Compare, Opcode::F64X2Lt},
{""},
-#line 153 "src/lexer-keywords.txt"
+#line 58 "src/lexer-keywords.txt"
+ {"exn", Type::ExnRef, TokenType::Exn},
+ {""}, {""},
+#line 475 "src/lexer-keywords.txt"
+ {"i64x2.ge_s", TokenType::Binary, Opcode::I64X2GeS},
+#line 155 "src/lexer-keywords.txt"
{"f64x2.ceil", TokenType::Unary, Opcode::F64X2Ceil},
-#line 506 "src/lexer-keywords.txt"
- {"i8x16.ge_u", TokenType::Compare, Opcode::I8X16GeU},
- {""},
-#line 510 "src/lexer-keywords.txt"
- {"i8x16.le_u", TokenType::Compare, Opcode::I8X16LeU},
-#line 186 "src/lexer-keywords.txt"
- {"function", TokenType::Function},
-#line 505 "src/lexer-keywords.txt"
- {"i8x16.ge_s", TokenType::Compare, Opcode::I8X16GeS},
- {""},
-#line 509 "src/lexer-keywords.txt"
- {"i8x16.le_s", TokenType::Compare, Opcode::I8X16LeS},
- {""},
-#line 508 "src/lexer-keywords.txt"
- {"i8x16.gt_u", TokenType::Compare, Opcode::I8X16GtU},
- {""},
-#line 512 "src/lexer-keywords.txt"
- {"i8x16.lt_u", TokenType::Compare, Opcode::I8X16LtU},
- {""},
-#line 507 "src/lexer-keywords.txt"
- {"i8x16.gt_s", TokenType::Compare, Opcode::I8X16GtS},
+#line 474 "src/lexer-keywords.txt"
+ {"i64x2.le_s", TokenType::Binary, Opcode::I64X2LeS},
+ {""}, {""}, {""}, {""}, {""},
+#line 473 "src/lexer-keywords.txt"
+ {"i64x2.gt_s", TokenType::Binary, Opcode::I64X2GtS},
{""},
-#line 511 "src/lexer-keywords.txt"
- {"i8x16.lt_s", TokenType::Compare, Opcode::I8X16LtS},
- {""}, {""}, {""},
-#line 393 "src/lexer-keywords.txt"
- {"i64.atomic.rmw8.and_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8AndU},
-#line 256 "src/lexer-keywords.txt"
- {"i32.atomic.rmw8.and_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8AndU},
+#line 472 "src/lexer-keywords.txt"
+ {"i64x2.lt_s", TokenType::Binary, Opcode::I64X2LtS},
+#line 99 "src/lexer-keywords.txt"
+ {"f32x4.floor", TokenType::Unary, Opcode::F32X4Floor},
{""}, {""},
-#line 450 "src/lexer-keywords.txt"
- {"i64.store32", TokenType::Store, Opcode::I64Store32},
-#line 550 "src/lexer-keywords.txt"
- {"memory.size", TokenType::MemorySize, Opcode::MemorySize},
+#line 185 "src/lexer-keywords.txt"
+ {"field", TokenType::Field},
+#line 112 "src/lexer-keywords.txt"
+ {"f32x4.relaxed_madd", TokenType::Ternary, Opcode::F32X4RelaxedMadd},
+ {""}, {""}, {""}, {""}, {""},
+#line 419 "src/lexer-keywords.txt"
+ {"i64.extend16_s", TokenType::Unary, Opcode::I64Extend16S},
+#line 281 "src/lexer-keywords.txt"
+ {"i32.extend16_s", TokenType::Unary, Opcode::I32Extend16S},
{""},
-#line 448 "src/lexer-keywords.txt"
- {"i64.shr_u", TokenType::Binary, Opcode::I64ShrU},
-#line 305 "src/lexer-keywords.txt"
- {"i32.shr_u", TokenType::Binary, Opcode::I32ShrU},
-#line 447 "src/lexer-keywords.txt"
- {"i64.shr_s", TokenType::Binary, Opcode::I64ShrS},
-#line 304 "src/lexer-keywords.txt"
- {"i32.shr_s", TokenType::Binary, Opcode::I32ShrS},
+#line 539 "src/lexer-keywords.txt"
+ {"item", TokenType::Item},
{""}, {""},
-#line 353 "src/lexer-keywords.txt"
- {"i32x4.shr_u", TokenType::Binary, Opcode::I32X4ShrU},
-#line 565 "src/lexer-keywords.txt"
- {"ref.is_null", TokenType::RefIsNull, Opcode::RefIsNull},
-#line 352 "src/lexer-keywords.txt"
- {"i32x4.shr_s", TokenType::Binary, Opcode::I32X4ShrS},
-#line 519 "src/lexer-keywords.txt"
- {"i8x16.neg", TokenType::Unary, Opcode::I8X16Neg},
+#line 421 "src/lexer-keywords.txt"
+ {"i64.extend8_s", TokenType::Unary, Opcode::I64Extend8S},
+#line 282 "src/lexer-keywords.txt"
+ {"i32.extend8_s", TokenType::Unary, Opcode::I32Extend8S},
+ {""}, {""},
+#line 566 "src/lexer-keywords.txt"
+ {"ref.func", TokenType::RefFunc, Opcode::RefFunc},
+#line 134 "src/lexer-keywords.txt"
+ {"f64.floor", TokenType::Unary, Opcode::F64Floor},
+#line 73 "src/lexer-keywords.txt"
+ {"f32.floor", TokenType::Unary, Opcode::F32Floor},
+ {""}, {""},
+#line 412 "src/lexer-keywords.txt"
+ {"i64.clz", TokenType::Unary, Opcode::I64Clz},
+#line 274 "src/lexer-keywords.txt"
+ {"i32.clz", TokenType::Unary, Opcode::I32Clz},
+ {""}, {""}, {""}, {""},
+#line 168 "src/lexer-keywords.txt"
+ {"f64x2.neg", TokenType::Unary, Opcode::F64X2Neg},
+#line 105 "src/lexer-keywords.txt"
+ {"f32x4.min", TokenType::Binary, Opcode::F32X4Min},
+#line 169 "src/lexer-keywords.txt"
+ {"f64x2.ne", TokenType::Compare, Opcode::F64X2Ne},
+#line 414 "src/lexer-keywords.txt"
+ {"i64.ctz", TokenType::Unary, Opcode::I64Ctz},
+#line 276 "src/lexer-keywords.txt"
+ {"i32.ctz", TokenType::Unary, Opcode::I32Ctz},
+ {""}, {""},
+#line 477 "src/lexer-keywords.txt"
+ {"i64x2.neg", TokenType::Unary, Opcode::I64X2Neg},
+#line 452 "src/lexer-keywords.txt"
+ {"i64.store32", TokenType::Store, Opcode::I64Store32},
+#line 471 "src/lexer-keywords.txt"
+ {"i64x2.ne", TokenType::Binary, Opcode::I64X2Ne},
{""},
-#line 521 "src/lexer-keywords.txt"
- {"i8x16.ne", TokenType::Compare, Opcode::I8X16Ne},
- {""}, {""}, {""}, {""}, {""},
-#line 400 "src/lexer-keywords.txt"
- {"i64.atomic.rmw.and", TokenType::AtomicRmw, Opcode::I64AtomicRmwAnd},
-#line 263 "src/lexer-keywords.txt"
- {"i32.atomic.rmw.and", TokenType::AtomicRmw, Opcode::I32AtomicRmwAnd},
-#line 178 "src/lexer-keywords.txt"
- {"f64x2.trunc", TokenType::Unary, Opcode::F64X2Trunc},
-#line 164 "src/lexer-keywords.txt"
- {"f64x2.mul", TokenType::Binary, Opcode::F64X2Mul},
- {""}, {""}, {""},
-#line 392 "src/lexer-keywords.txt"
+#line 56 "src/lexer-keywords.txt"
+ {"extern", Type::ExternRef, TokenType::Extern},
+#line 394 "src/lexer-keywords.txt"
{"i64.atomic.rmw8.add_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8AddU},
-#line 255 "src/lexer-keywords.txt"
+#line 257 "src/lexer-keywords.txt"
{"i32.atomic.rmw8.add_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8AddU},
-#line 467 "src/lexer-keywords.txt"
- {"i64x2.mul", TokenType::Binary, Opcode::I64X2Mul},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 562 "src/lexer-keywords.txt"
- {"quote", TokenType::Quote},
- {""}, {""}, {""}, {""},
-#line 601 "src/lexer-keywords.txt"
- {"v128", Type::V128},
- {""},
-#line 536 "src/lexer-keywords.txt"
- {"invoke", TokenType::Invoke},
- {""},
-#line 418 "src/lexer-keywords.txt"
- {"i64.extend32_s", TokenType::Unary, Opcode::I64Extend32S},
+ {""}, {""},
+#line 392 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw32.xchg_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32XchgU},
{""},
-#line 174 "src/lexer-keywords.txt"
- {"f64x2.replace_lane", TokenType::SimdLaneOp, Opcode::F64X2ReplaceLane},
- {""}, {""}, {""},
-#line 399 "src/lexer-keywords.txt"
+#line 113 "src/lexer-keywords.txt"
+ {"f32x4.relaxed_max", TokenType::Binary, Opcode::F32X4RelaxedMax},
+ {""}, {""}, {""}, {""}, {""},
+#line 395 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw8.and_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8AndU},
+#line 258 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw8.and_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8AndU},
+ {""}, {""},
+#line 188 "src/lexer-keywords.txt"
+ {"function", TokenType::Function},
+#line 401 "src/lexer-keywords.txt"
{"i64.atomic.rmw.add", TokenType::AtomicRmw, Opcode::I64AtomicRmwAdd},
-#line 262 "src/lexer-keywords.txt"
+#line 264 "src/lexer-keywords.txt"
{"i32.atomic.rmw.add", TokenType::AtomicRmw, Opcode::I32AtomicRmwAdd},
-#line 483 "src/lexer-keywords.txt"
- {"i64x2.replace_lane", TokenType::SimdLaneOp, Opcode::I64X2ReplaceLane},
+ {""},
+#line 180 "src/lexer-keywords.txt"
+ {"f64x2.trunc", TokenType::Unary, Opcode::F64X2Trunc},
{""}, {""},
-#line 558 "src/lexer-keywords.txt"
- {"output", TokenType::Output},
+#line 393 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw32.xor_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw32XorU},
{""}, {""},
#line 557 "src/lexer-keywords.txt"
- {"offset", TokenType::Offset},
+ {"nan:canonical", TokenType::NanCanonical},
{""}, {""},
-#line 532 "src/lexer-keywords.txt"
- {"i8x16", TokenType::I8X16},
- {""},
-#line 152 "src/lexer-keywords.txt"
+#line 402 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw.and", TokenType::AtomicRmw, Opcode::I64AtomicRmwAnd},
+#line 265 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw.and", TokenType::AtomicRmw, Opcode::I32AtomicRmwAnd},
+#line 154 "src/lexer-keywords.txt"
{"f64x2.add", TokenType::Binary, Opcode::F64X2Add},
+#line 167 "src/lexer-keywords.txt"
+ {"f64x2.nearest", TokenType::Unary, Opcode::F64X2Nearest},
{""}, {""}, {""},
-#line 162 "src/lexer-keywords.txt"
- {"f64x2.max", TokenType::Binary, Opcode::F64X2Max},
- {""},
-#line 463 "src/lexer-keywords.txt"
+#line 141 "src/lexer-keywords.txt"
+ {"f64.min", TokenType::Binary, Opcode::F64Min},
+#line 80 "src/lexer-keywords.txt"
+ {"f32.min", TokenType::Binary, Opcode::F32Min},
+#line 465 "src/lexer-keywords.txt"
{"i64x2.add", TokenType::Binary, Opcode::I64X2Add},
- {""}, {""}, {""}, {""},
-#line 156 "src/lexer-keywords.txt"
- {"f64x2.extract_lane", TokenType::SimdLaneOp, Opcode::F64X2ExtractLane},
- {""}, {""}, {""},
-#line 431 "src/lexer-keywords.txt"
- {"i64.load32_u", TokenType::Load, Opcode::I64Load32U},
- {""},
-#line 464 "src/lexer-keywords.txt"
- {"i64x2.extract_lane", TokenType::SimdLaneOp, Opcode::I64X2ExtractLane},
-#line 115 "src/lexer-keywords.txt"
- {"f32x4.splat", TokenType::Unary, Opcode::F32X4Splat},
-#line 430 "src/lexer-keywords.txt"
- {"i64.load32_s", TokenType::Load, Opcode::I64Load32S},
-#line 344 "src/lexer-keywords.txt"
- {"i32x4.min_u", TokenType::Binary, Opcode::I32X4MinU},
-#line 40 "src/lexer-keywords.txt"
- {"catch_all", TokenType::CatchAll, Opcode::CatchAll},
-#line 343 "src/lexer-keywords.txt"
- {"i32x4.min_s", TokenType::Binary, Opcode::I32X4MinS},
+ {""}, {""},
+#line 400 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw8.xor_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8XorU},
+#line 263 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw8.xor_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8XorU},
{""},
-#line 354 "src/lexer-keywords.txt"
- {"i32x4.splat", TokenType::Unary, Opcode::I32X4Splat},
- {""}, {""}, {""}, {""},
-#line 32 "src/lexer-keywords.txt"
- {"block", TokenType::Block, Opcode::Block},
+#line 459 "src/lexer-keywords.txt"
+ {"i64.trunc_f64_u", TokenType::Convert, Opcode::I64TruncF64U},
+#line 315 "src/lexer-keywords.txt"
+ {"i32.trunc_f64_u", TokenType::Convert, Opcode::I32TruncF64U},
{""},
-#line 482 "src/lexer-keywords.txt"
- {"i64x2.relaxed_laneselect", TokenType::Ternary, Opcode::I64X2RelaxedLaneSelect},
-#line 334 "src/lexer-keywords.txt"
- {"i32x4.relaxed_trunc_f32x4_u", TokenType::Unary, Opcode::I32X4RelaxedTruncF32X4U},
+#line 166 "src/lexer-keywords.txt"
+ {"f64x2.mul", TokenType::Binary, Opcode::F64X2Mul},
+#line 458 "src/lexer-keywords.txt"
+ {"i64.trunc_f64_s", TokenType::Convert, Opcode::I64TruncF64S},
+#line 314 "src/lexer-keywords.txt"
+ {"i32.trunc_f64_s", TokenType::Convert, Opcode::I32TruncF64S},
+#line 567 "src/lexer-keywords.txt"
+ {"ref.is_null", TokenType::RefIsNull, Opcode::RefIsNull},
+#line 605 "src/lexer-keywords.txt"
+ {"v128", Type::V128},
{""}, {""},
-#line 421 "src/lexer-keywords.txt"
- {"i64.extend_i32_u", TokenType::Convert, Opcode::I64ExtendI32U},
-#line 333 "src/lexer-keywords.txt"
- {"i32x4.relaxed_trunc_f32x4_s", TokenType::Unary, Opcode::I32X4RelaxedTruncF32X4S},
-#line 420 "src/lexer-keywords.txt"
- {"i64.extend_i32_s", TokenType::Convert, Opcode::I64ExtendI32S},
-#line 596 "src/lexer-keywords.txt"
- {"v128.or", TokenType::Binary, Opcode::V128Or},
- {""},
-#line 555 "src/lexer-keywords.txt"
- {"nan:canonical", TokenType::NanCanonical},
+#line 469 "src/lexer-keywords.txt"
+ {"i64x2.mul", TokenType::Binary, Opcode::I64X2Mul},
+#line 433 "src/lexer-keywords.txt"
+ {"i64.load32_u", TokenType::Load, Opcode::I64Load32U},
{""}, {""}, {""},
-#line 376 "src/lexer-keywords.txt"
+#line 432 "src/lexer-keywords.txt"
+ {"i64.load32_s", TokenType::Load, Opcode::I64Load32S},
+ {""}, {""}, {""}, {""},
+#line 556 "src/lexer-keywords.txt"
+ {"nan:arithmetic", TokenType::NanArithmetic},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 538 "src/lexer-keywords.txt"
+ {"invoke", TokenType::Invoke},
+ {""}, {""}, {""}, {""}, {""},
+#line 378 "src/lexer-keywords.txt"
{"i64.atomic.load8_u", TokenType::AtomicLoad, Opcode::I64AtomicLoad8U},
-#line 246 "src/lexer-keywords.txt"
+#line 248 "src/lexer-keywords.txt"
{"i32.atomic.load8_u", TokenType::AtomicLoad, Opcode::I32AtomicLoad8U},
-#line 524 "src/lexer-keywords.txt"
- {"i8x16.replace_lane", TokenType::SimdLaneOp, Opcode::I8X16ReplaceLane},
-#line 39 "src/lexer-keywords.txt"
- {"catch", TokenType::Catch, Opcode::Catch},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 554 "src/lexer-keywords.txt"
- {"nan:arithmetic", TokenType::NanArithmetic},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 498 "src/lexer-keywords.txt"
- {"i8x16.add", TokenType::Binary, Opcode::I8X16Add},
{""},
-#line 171 "src/lexer-keywords.txt"
- {"f64x2.relaxed_max", TokenType::Binary, Opcode::F64X2RelaxedMax},
-#line 600 "src/lexer-keywords.txt"
- {"v128.store", TokenType::Store, Opcode::V128Store},
+#line 176 "src/lexer-keywords.txt"
+ {"f64x2.replace_lane", TokenType::SimdLaneOp, Opcode::F64X2ReplaceLane},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 485 "src/lexer-keywords.txt"
+ {"i64x2.replace_lane", TokenType::SimdLaneOp, Opcode::I64X2ReplaceLane},
{""},
-#line 395 "src/lexer-keywords.txt"
+#line 564 "src/lexer-keywords.txt"
+ {"quote", TokenType::Quote},
+#line 32 "src/lexer-keywords.txt"
+ {"block", TokenType::Block, Opcode::Block},
+ {""}, {""},
+#line 450 "src/lexer-keywords.txt"
+ {"i64.shr_u", TokenType::Binary, Opcode::I64ShrU},
+#line 307 "src/lexer-keywords.txt"
+ {"i32.shr_u", TokenType::Binary, Opcode::I32ShrU},
+#line 449 "src/lexer-keywords.txt"
+ {"i64.shr_s", TokenType::Binary, Opcode::I64ShrS},
+#line 306 "src/lexer-keywords.txt"
+ {"i32.shr_s", TokenType::Binary, Opcode::I32ShrS},
+#line 397 "src/lexer-keywords.txt"
{"i64.atomic.rmw8.or_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8OrU},
-#line 258 "src/lexer-keywords.txt"
+#line 260 "src/lexer-keywords.txt"
{"i32.atomic.rmw8.or_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8OrU},
-#line 238 "src/lexer-keywords.txt"
+#line 240 "src/lexer-keywords.txt"
{"i16x8", TokenType::I16X8},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""},
+#line 355 "src/lexer-keywords.txt"
+ {"i32x4.shr_u", TokenType::Binary, Opcode::I32X4ShrU},
+#line 346 "src/lexer-keywords.txt"
+ {"i32x4.min_u", TokenType::Binary, Opcode::I32X4MinU},
+#line 354 "src/lexer-keywords.txt"
+ {"i32x4.shr_s", TokenType::Binary, Opcode::I32X4ShrS},
+#line 345 "src/lexer-keywords.txt"
+ {"i32x4.min_s", TokenType::Binary, Opcode::I32X4MinS},
+#line 600 "src/lexer-keywords.txt"
+ {"v128.or", TokenType::Binary, Opcode::V128Or},
{""},
-#line 203 "src/lexer-keywords.txt"
+#line 560 "src/lexer-keywords.txt"
+ {"output", TokenType::Output},
+ {""}, {""},
+#line 559 "src/lexer-keywords.txt"
+ {"offset", TokenType::Offset},
+ {""},
+#line 592 "src/lexer-keywords.txt"
+ {"type", TokenType::Type},
+#line 590 "src/lexer-keywords.txt"
+ {"try", TokenType::Try, Opcode::Try},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 580 "src/lexer-keywords.txt"
+ {"table.fill", TokenType::TableFill, Opcode::TableFill},
+ {""},
+#line 484 "src/lexer-keywords.txt"
+ {"i64x2.relaxed_laneselect", TokenType::Ternary, Opcode::I64X2RelaxedLaneSelect},
+#line 478 "src/lexer-keywords.txt"
+ {"i64x2.all_true", TokenType::Unary, Opcode::I64X2AllTrue},
+ {""}, {""}, {""}, {""}, {""},
+#line 205 "src/lexer-keywords.txt"
{"i16x8.ge_u", TokenType::Compare, Opcode::I16X8GeU},
-#line 602 "src/lexer-keywords.txt"
- {"v128.xor", TokenType::Binary, Opcode::V128Xor},
-#line 207 "src/lexer-keywords.txt"
+#line 420 "src/lexer-keywords.txt"
+ {"i64.extend32_s", TokenType::Unary, Opcode::I64Extend32S},
+#line 209 "src/lexer-keywords.txt"
{"i16x8.le_u", TokenType::Compare, Opcode::I16X8LeU},
{""},
-#line 202 "src/lexer-keywords.txt"
+#line 204 "src/lexer-keywords.txt"
{"i16x8.ge_s", TokenType::Compare, Opcode::I16X8GeS},
- {""},
-#line 206 "src/lexer-keywords.txt"
+#line 40 "src/lexer-keywords.txt"
+ {"catch_all", TokenType::CatchAll, Opcode::CatchAll},
+#line 208 "src/lexer-keywords.txt"
{"i16x8.le_s", TokenType::Compare, Opcode::I16X8LeS},
- {""},
-#line 205 "src/lexer-keywords.txt"
+#line 336 "src/lexer-keywords.txt"
+ {"i32x4.relaxed_trunc_f32x4_u", TokenType::Unary, Opcode::I32X4RelaxedTruncF32X4U},
+#line 207 "src/lexer-keywords.txt"
{"i16x8.gt_u", TokenType::Compare, Opcode::I16X8GtU},
-#line 476 "src/lexer-keywords.txt"
- {"i64x2.all_true", TokenType::Unary, Opcode::I64X2AllTrue},
-#line 211 "src/lexer-keywords.txt"
+ {""},
+#line 213 "src/lexer-keywords.txt"
{"i16x8.lt_u", TokenType::Compare, Opcode::I16X8LtU},
-#line 172 "src/lexer-keywords.txt"
- {"f64x2.relaxed_min", TokenType::Binary, Opcode::F64X2RelaxedMin},
-#line 204 "src/lexer-keywords.txt"
+#line 335 "src/lexer-keywords.txt"
+ {"i32x4.relaxed_trunc_f32x4_s", TokenType::Unary, Opcode::I32X4RelaxedTruncF32X4S},
+#line 206 "src/lexer-keywords.txt"
{"i16x8.gt_s", TokenType::Compare, Opcode::I16X8GtS},
{""},
-#line 210 "src/lexer-keywords.txt"
+#line 212 "src/lexer-keywords.txt"
{"i16x8.lt_s", TokenType::Compare, Opcode::I16X8LtS},
+ {""}, {""},
+#line 70 "src/lexer-keywords.txt"
+ {"f32.demote_f64", TokenType::Convert, Opcode::F32DemoteF64},
{""},
-#line 523 "src/lexer-keywords.txt"
- {"i8x16.relaxed_laneselect", TokenType::Ternary, Opcode::I8X16RelaxedLaneSelect},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 588 "src/lexer-keywords.txt"
- {"type", TokenType::Type},
-#line 404 "src/lexer-keywords.txt"
- {"i64.atomic.rmw.xchg", TokenType::AtomicRmw, Opcode::I64AtomicRmwXchg},
-#line 267 "src/lexer-keywords.txt"
- {"i32.atomic.rmw.xchg", TokenType::AtomicRmw, Opcode::I32AtomicRmwXchg},
+#line 164 "src/lexer-keywords.txt"
+ {"f64x2.max", TokenType::Binary, Opcode::F64X2Max},
{""},
-#line 595 "src/lexer-keywords.txt"
- {"v128.not", TokenType::Unary, Opcode::V128Not},
+#line 117 "src/lexer-keywords.txt"
+ {"f32x4.splat", TokenType::Unary, Opcode::F32X4Splat},
+#line 604 "src/lexer-keywords.txt"
+ {"v128.store", TokenType::Store, Opcode::V128Store},
+#line 537 "src/lexer-keywords.txt"
+ {"input", TokenType::Input},
{""}, {""},
-#line 614 "src/lexer-keywords.txt"
- {"v128.store64_lane", TokenType::SimdStoreLane, Opcode::V128Store64Lane},
-#line 219 "src/lexer-keywords.txt"
- {"i16x8.neg", TokenType::Unary, Opcode::I16X8Neg},
+#line 572 "src/lexer-keywords.txt"
+ {"return_call_indirect", TokenType::ReturnCallIndirect, Opcode::ReturnCallIndirect},
{""},
-#line 221 "src/lexer-keywords.txt"
- {"i16x8.ne", TokenType::Compare, Opcode::I16X8Ne},
-#line 607 "src/lexer-keywords.txt"
- {"v128.load8_lane", TokenType::SimdLoadLane, Opcode::V128Load8Lane},
-#line 466 "src/lexer-keywords.txt"
- {"v128.load32x2_u", TokenType::Load, Opcode::V128Load32X2U},
+#line 356 "src/lexer-keywords.txt"
+ {"i32x4.splat", TokenType::Unary, Opcode::I32X4Splat},
+#line 508 "src/lexer-keywords.txt"
+ {"i8x16.ge_u", TokenType::Compare, Opcode::I8X16GeU},
+#line 33 "src/lexer-keywords.txt"
+ {"br_if", TokenType::BrIf, Opcode::BrIf},
+#line 512 "src/lexer-keywords.txt"
+ {"i8x16.le_u", TokenType::Compare, Opcode::I8X16LeU},
{""},
-#line 484 "src/lexer-keywords.txt"
- {"i64x2.shl", TokenType::Binary, Opcode::I64X2Shl},
+#line 507 "src/lexer-keywords.txt"
+ {"i8x16.ge_s", TokenType::Compare, Opcode::I8X16GeS},
{""},
-#line 465 "src/lexer-keywords.txt"
- {"v128.load32x2_s", TokenType::Load, Opcode::V128Load32X2S},
- {""}, {""}, {""},
-#line 209 "src/lexer-keywords.txt"
- {"v128.load8x8_u", TokenType::Load, Opcode::V128Load8X8U},
+#line 511 "src/lexer-keywords.txt"
+ {"i8x16.le_s", TokenType::Compare, Opcode::I8X16LeS},
{""},
-#line 208 "src/lexer-keywords.txt"
- {"v128.load8x8_s", TokenType::Load, Opcode::V128Load8X8S},
-#line 42 "src/lexer-keywords.txt"
- {"data.drop", TokenType::DataDrop, Opcode::DataDrop},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 535 "src/lexer-keywords.txt"
- {"input", TokenType::Input},
- {""}, {""},
-#line 594 "src/lexer-keywords.txt"
+#line 510 "src/lexer-keywords.txt"
+ {"i8x16.gt_u", TokenType::Compare, Opcode::I8X16GtU},
+#line 536 "src/lexer-keywords.txt"
+ {"import", TokenType::Import},
+#line 514 "src/lexer-keywords.txt"
+ {"i8x16.lt_u", TokenType::Compare, Opcode::I8X16LtU},
+ {""},
+#line 509 "src/lexer-keywords.txt"
+ {"i8x16.gt_s", TokenType::Compare, Opcode::I8X16GtS},
+ {""},
+#line 513 "src/lexer-keywords.txt"
+ {"i8x16.lt_s", TokenType::Compare, Opcode::I8X16LtS},
+ {""}, {""}, {""}, {""}, {""},
+#line 598 "src/lexer-keywords.txt"
{"v128.load", TokenType::Load, Opcode::V128Load},
-#line 606 "src/lexer-keywords.txt"
- {"v128.load8_splat", TokenType::Load, Opcode::V128Load8Splat},
+#line 158 "src/lexer-keywords.txt"
+ {"f64x2.extract_lane", TokenType::SimdLaneOp, Opcode::F64X2ExtractLane},
+ {""}, {""},
+#line 221 "src/lexer-keywords.txt"
+ {"i16x8.neg", TokenType::Unary, Opcode::I16X8Neg},
{""},
-#line 534 "src/lexer-keywords.txt"
- {"import", TokenType::Import},
- {""}, {""}, {""},
-#line 499 "src/lexer-keywords.txt"
- {"i8x16.all_true", TokenType::Unary, Opcode::I8X16AllTrue},
-#line 530 "src/lexer-keywords.txt"
- {"i8x16.sub_sat_u", TokenType::Binary, Opcode::I8X16SubSatU},
-#line 146 "src/lexer-keywords.txt"
+#line 223 "src/lexer-keywords.txt"
+ {"i16x8.ne", TokenType::Compare, Opcode::I16X8Ne},
+#line 423 "src/lexer-keywords.txt"
+ {"i64.extend_i32_u", TokenType::Convert, Opcode::I64ExtendI32U},
+#line 466 "src/lexer-keywords.txt"
+ {"i64x2.extract_lane", TokenType::SimdLaneOp, Opcode::I64X2ExtractLane},
+#line 422 "src/lexer-keywords.txt"
+ {"i64.extend_i32_s", TokenType::Convert, Opcode::I64ExtendI32S},
+ {""}, {""},
+#line 148 "src/lexer-keywords.txt"
{"f64.sqrt", TokenType::Unary, Opcode::F64Sqrt},
-#line 84 "src/lexer-keywords.txt"
+#line 86 "src/lexer-keywords.txt"
{"f32.sqrt", TokenType::Unary, Opcode::F32Sqrt},
+#line 211 "src/lexer-keywords.txt"
+ {"v128.load8x8_u", TokenType::Load, Opcode::V128Load8X8U},
{""},
-#line 529 "src/lexer-keywords.txt"
- {"i8x16.sub_sat_s", TokenType::Binary, Opcode::I8X16SubSatS},
+#line 210 "src/lexer-keywords.txt"
+ {"v128.load8x8_s", TokenType::Load, Opcode::V128Load8X8S},
+#line 611 "src/lexer-keywords.txt"
+ {"v128.load8_lane", TokenType::SimdLoadLane, Opcode::V128Load8Lane},
+#line 406 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw.xchg", TokenType::AtomicRmw, Opcode::I64AtomicRmwXchg},
+#line 269 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw.xchg", TokenType::AtomicRmw, Opcode::I32AtomicRmwXchg},
+ {""}, {""}, {""},
+#line 184 "src/lexer-keywords.txt"
+ {"f64x2", TokenType::F64X2},
{""}, {""},
-#line 116 "src/lexer-keywords.txt"
+#line 610 "src/lexer-keywords.txt"
+ {"v128.load8_splat", TokenType::Load, Opcode::V128Load8Splat},
+ {""},
+#line 599 "src/lexer-keywords.txt"
+ {"v128.not", TokenType::Unary, Opcode::V128Not},
+#line 618 "src/lexer-keywords.txt"
+ {"v128.store64_lane", TokenType::SimdStoreLane, Opcode::V128Store64Lane},
+#line 495 "src/lexer-keywords.txt"
+ {"i64x2", TokenType::I64X2},
+#line 118 "src/lexer-keywords.txt"
{"f32x4.sqrt", TokenType::Unary, Opcode::F32X4Sqrt},
-#line 570 "src/lexer-keywords.txt"
- {"return_call_indirect", TokenType::ReturnCallIndirect, Opcode::ReturnCallIndirect},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 397 "src/lexer-keywords.txt"
- {"i64.atomic.rmw8.xchg_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8XchgU},
-#line 260 "src/lexer-keywords.txt"
- {"i32.atomic.rmw8.xchg_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8XchgU},
{""},
-#line 374 "src/lexer-keywords.txt"
- {"i64.atomic.load16_u", TokenType::AtomicLoad, Opcode::I64AtomicLoad16U},
-#line 245 "src/lexer-keywords.txt"
- {"i32.atomic.load16_u", TokenType::AtomicLoad, Opcode::I32AtomicLoad16U},
- {""}, {""},
-#line 108 "src/lexer-keywords.txt"
- {"f32x4.pmax", TokenType::Binary, Opcode::F32X4PMax},
- {""}, {""}, {""}, {""},
-#line 593 "src/lexer-keywords.txt"
- {"v128.const", TokenType::Const, Opcode::V128Const},
-#line 173 "src/lexer-keywords.txt"
- {"f64x2.relaxed_nmadd", TokenType::Ternary, Opcode::F64X2RelaxedNmadd},
+#line 521 "src/lexer-keywords.txt"
+ {"i8x16.neg", TokenType::Unary, Opcode::I8X16Neg},
{""},
-#line 525 "src/lexer-keywords.txt"
- {"i8x16.shl", TokenType::Binary, Opcode::I8X16Shl},
+#line 523 "src/lexer-keywords.txt"
+ {"i8x16.ne", TokenType::Compare, Opcode::I8X16Ne},
+#line 44 "src/lexer-keywords.txt"
+ {"data.drop", TokenType::DataDrop, Opcode::DataDrop},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 451 "src/lexer-keywords.txt"
+ {"i64.store16", TokenType::Store, Opcode::I64Store16},
+#line 308 "src/lexer-keywords.txt"
+ {"i32.store16", TokenType::Store, Opcode::I32Store16},
{""},
-#line 591 "src/lexer-keywords.txt"
- {"v128.and", TokenType::Binary, Opcode::V128And},
-#line 533 "src/lexer-keywords.txt"
- {"if", TokenType::If, Opcode::If},
-#line 561 "src/lexer-keywords.txt"
- {"ref", TokenType::Ref},
+#line 186 "src/lexer-keywords.txt"
+ {"funcref", Type::FuncRef},
+#line 196 "src/lexer-keywords.txt"
+ {"i16x8.add", TokenType::Binary, Opcode::I16X8Add},
{""}, {""}, {""},
-#line 551 "src/lexer-keywords.txt"
- {"memory", TokenType::Memory},
+#line 597 "src/lexer-keywords.txt"
+ {"v128.const", TokenType::Const, Opcode::V128Const},
{""},
-#line 109 "src/lexer-keywords.txt"
- {"f32x4.pmin", TokenType::Binary, Opcode::F32X4PMin},
-#line 216 "src/lexer-keywords.txt"
- {"i16x8.mul", TokenType::Binary, Opcode::I16X8Mul},
- {""}, {""}, {""}, {""},
-#line 590 "src/lexer-keywords.txt"
- {"v128.andnot", TokenType::Binary, Opcode::V128Andnot},
-#line 51 "src/lexer-keywords.txt"
- {"else", TokenType::Else, Opcode::Else},
-#line 48 "src/lexer-keywords.txt"
- {"either", TokenType::Either},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 182 "src/lexer-keywords.txt"
- {"f64x2", TokenType::F64X2},
+#line 606 "src/lexer-keywords.txt"
+ {"v128.xor", TokenType::Binary, Opcode::V128Xor},
{""}, {""}, {""}, {""}, {""},
-#line 493 "src/lexer-keywords.txt"
- {"i64x2", TokenType::I64X2},
- {""},
-#line 324 "src/lexer-keywords.txt"
- {"i32x4.relaxed_dot_i8x16_i7x16_add_s", TokenType::Ternary, Opcode::I32X4DotI8X16I7X16AddS},
-#line 224 "src/lexer-keywords.txt"
- {"i16x8.replace_lane", TokenType::SimdLaneOp, Opcode::I16X8ReplaceLane},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 585 "src/lexer-keywords.txt"
- {"then", TokenType::Then},
+#line 174 "src/lexer-keywords.txt"
+ {"f64x2.relaxed_min", TokenType::Binary, Opcode::F64X2RelaxedMin},
{""},
-#line 612 "src/lexer-keywords.txt"
- {"v128.store16_lane", TokenType::SimdStoreLane, Opcode::V128Store16Lane},
- {""}, {""}, {""}, {""},
-#line 163 "src/lexer-keywords.txt"
- {"f64x2.min", TokenType::Binary, Opcode::F64X2Min},
+#line 175 "src/lexer-keywords.txt"
+ {"f64x2.relaxed_nmadd", TokenType::Ternary, Opcode::F64X2RelaxedNmadd},
{""},
-#line 170 "src/lexer-keywords.txt"
- {"f64x2.relaxed_madd", TokenType::Ternary, Opcode::F64X2RelaxedMadd},
-#line 194 "src/lexer-keywords.txt"
- {"i16x8.add", TokenType::Binary, Opcode::I16X8Add},
+#line 218 "src/lexer-keywords.txt"
+ {"i16x8.mul", TokenType::Binary, Opcode::I16X8Mul},
{""},
-#line 31 "src/lexer-keywords.txt"
- {"binary", TokenType::Bin},
-#line 497 "src/lexer-keywords.txt"
- {"i8x16.add_sat_u", TokenType::Binary, Opcode::I8X16AddSatU},
-#line 387 "src/lexer-keywords.txt"
- {"i64.atomic.rmw32.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I64AtomicRmw32CmpxchgU},
+#line 376 "src/lexer-keywords.txt"
+ {"i64.atomic.load16_u", TokenType::AtomicLoad, Opcode::I64AtomicLoad16U},
+#line 247 "src/lexer-keywords.txt"
+ {"i32.atomic.load16_u", TokenType::AtomicLoad, Opcode::I32AtomicLoad16U},
+ {""}, {""}, {""},
+#line 39 "src/lexer-keywords.txt"
+ {"catch", TokenType::Catch, Opcode::Catch},
{""}, {""},
-#line 496 "src/lexer-keywords.txt"
- {"i8x16.add_sat_s", TokenType::Binary, Opcode::I8X16AddSatS},
-#line 416 "src/lexer-keywords.txt"
- {"i64.eqz", TokenType::Convert, Opcode::I64Eqz},
-#line 278 "src/lexer-keywords.txt"
- {"i32.eqz", TokenType::Convert, Opcode::I32Eqz},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 514 "src/lexer-keywords.txt"
- {"i8x16.max_u", TokenType::Binary, Opcode::I8X16MaxU},
+#line 486 "src/lexer-keywords.txt"
+ {"i64x2.shl", TokenType::Binary, Opcode::I64X2Shl},
+ {""}, {""},
+#line 500 "src/lexer-keywords.txt"
+ {"i8x16.add", TokenType::Binary, Opcode::I8X16Add},
{""},
-#line 513 "src/lexer-keywords.txt"
- {"i8x16.max_s", TokenType::Binary, Opcode::I8X16MaxS},
+#line 595 "src/lexer-keywords.txt"
+ {"v128.and", TokenType::Binary, Opcode::V128And},
+ {""}, {""}, {""}, {""},
+#line 534 "src/lexer-keywords.txt"
+ {"i8x16", TokenType::I8X16},
{""}, {""},
#line 52 "src/lexer-keywords.txt"
- {"end", TokenType::End, Opcode::End},
+ {"elem", TokenType::Elem},
{""},
-#line 222 "src/lexer-keywords.txt"
- {"i16x8.relaxed_laneselect", TokenType::Ternary, Opcode::I16X8RelaxedLaneSelect},
- {""}, {""}, {""},
-#line 190 "src/lexer-keywords.txt"
- {"global", TokenType::Global},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 57 "src/lexer-keywords.txt"
+ {"externref", Type::ExternRef},
+ {""}, {""},
+#line 594 "src/lexer-keywords.txt"
+ {"v128.andnot", TokenType::Binary, Opcode::V128Andnot},
+ {""}, {""},
+#line 384 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw16.sub_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16SubU},
+#line 254 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw16.sub_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16SubU},
{""},
-#line 54 "src/lexer-keywords.txt"
- {"extern", Type::ExternRef, TokenType::Extern},
- {""}, {""}, {""}, {""}, {""}, {""},
+#line 226 "src/lexer-keywords.txt"
+ {"i16x8.replace_lane", TokenType::SimdLaneOp, Opcode::I16X8ReplaceLane},
+ {""}, {""},
+#line 159 "src/lexer-keywords.txt"
+ {"f64x2.floor", TokenType::Unary, Opcode::F64X2Floor},
+ {""}, {""},
+#line 468 "src/lexer-keywords.txt"
+ {"v128.load32x2_u", TokenType::Load, Opcode::V128Load32X2U},
+#line 172 "src/lexer-keywords.txt"
+ {"f64x2.relaxed_madd", TokenType::Ternary, Opcode::F64X2RelaxedMadd},
+ {""}, {""},
+#line 467 "src/lexer-keywords.txt"
+ {"v128.load32x2_s", TokenType::Load, Opcode::V128Load32X2S},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""},
#line 36 "src/lexer-keywords.txt"
{"call_indirect", TokenType::CallIndirect, Opcode::CallIndirect},
-#line 97 "src/lexer-keywords.txt"
- {"f32x4.floor", TokenType::Unary, Opcode::F32X4Floor},
- {""}, {""}, {""},
-#line 504 "src/lexer-keywords.txt"
- {"i8x16.extract_lane_u", TokenType::SimdLaneOp, Opcode::I8X16ExtractLaneU},
- {""},
-#line 503 "src/lexer-keywords.txt"
- {"i8x16.extract_lane_s", TokenType::SimdLaneOp, Opcode::I8X16ExtractLaneS},
-#line 56 "src/lexer-keywords.txt"
- {"exn", Type::ExnRef, TokenType::Exn},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 188 "src/lexer-keywords.txt"
- {"global.get", TokenType::GlobalGet, Opcode::GlobalGet},
{""},
-#line 189 "src/lexer-keywords.txt"
- {"global.set", TokenType::GlobalSet, Opcode::GlobalSet},
- {""}, {""}, {""},
-#line 537 "src/lexer-keywords.txt"
- {"item", TokenType::Item},
- {""}, {""}, {""},
-#line 195 "src/lexer-keywords.txt"
- {"i16x8.all_true", TokenType::Unary, Opcode::I16X8AllTrue},
-#line 230 "src/lexer-keywords.txt"
- {"i16x8.sub_sat_u", TokenType::Binary, Opcode::I16X8SubSatU},
- {""},
-#line 577 "src/lexer-keywords.txt"
- {"table.copy", TokenType::TableCopy, Opcode::TableCopy},
- {""},
-#line 229 "src/lexer-keywords.txt"
- {"i16x8.sub_sat_s", TokenType::Binary, Opcode::I16X8SubSatS},
- {""},
-#line 522 "src/lexer-keywords.txt"
- {"i8x16.relaxed_swizzle", TokenType::Binary, Opcode::I8X16RelaxedSwizzle},
- {""}, {""},
-#line 604 "src/lexer-keywords.txt"
- {"v128.load32_splat", TokenType::Load, Opcode::V128Load32Splat},
+#line 526 "src/lexer-keywords.txt"
+ {"i8x16.replace_lane", TokenType::SimdLaneOp, Opcode::I8X16ReplaceLane},
{""}, {""}, {""}, {""}, {""},
-#line 486 "src/lexer-keywords.txt"
- {"i64x2.shr_u", TokenType::Binary, Opcode::I64X2ShrU},
- {""},
-#line 485 "src/lexer-keywords.txt"
- {"i64x2.shr_s", TokenType::Binary, Opcode::I64X2ShrS},
-#line 611 "src/lexer-keywords.txt"
- {"v128.store8_lane", TokenType::SimdStoreLane, Opcode::V128Store8Lane},
- {""},
-#line 183 "src/lexer-keywords.txt"
- {"field", TokenType::Field},
- {""},
-#line 609 "src/lexer-keywords.txt"
- {"v128.load32_lane", TokenType::SimdLoadLane, Opcode::V128Load32Lane},
+#line 165 "src/lexer-keywords.txt"
+ {"f64x2.min", TokenType::Binary, Opcode::F64X2Min},
+#line 383 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw16.or_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16OrU},
+#line 253 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw16.or_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16OrU},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 224 "src/lexer-keywords.txt"
+ {"i16x8.relaxed_laneselect", TokenType::Ternary, Opcode::I16X8RelaxedLaneSelect},
+#line 197 "src/lexer-keywords.txt"
+ {"i16x8.all_true", TokenType::Unary, Opcode::I16X8AllTrue},
{""}, {""},
#line 21 "src/lexer-keywords.txt"
{"after", TokenType::After},
- {""}, {""}, {""}, {""},
-#line 225 "src/lexer-keywords.txt"
- {"i16x8.shl", TokenType::Binary, Opcode::I16X8Shl},
-#line 132 "src/lexer-keywords.txt"
- {"f64.floor", TokenType::Unary, Opcode::F64Floor},
-#line 71 "src/lexer-keywords.txt"
- {"f32.floor", TokenType::Unary, Opcode::F32Floor},
-#line 560 "src/lexer-keywords.txt"
- {"param", TokenType::Param},
+#line 552 "src/lexer-keywords.txt"
+ {"memory.size", TokenType::MemorySize, Opcode::MemorySize},
+#line 173 "src/lexer-keywords.txt"
+ {"f64x2.relaxed_max", TokenType::Binary, Opcode::F64X2RelaxedMax},
+#line 380 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw16.add_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16AddU},
+#line 250 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw16.add_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16AddU},
+#line 399 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw8.xchg_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8XchgU},
+#line 262 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw8.xchg_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8XchgU},
+#line 232 "src/lexer-keywords.txt"
+ {"i16x8.sub_sat_u", TokenType::Binary, Opcode::I16X8SubSatU},
+ {""}, {""}, {""},
+#line 231 "src/lexer-keywords.txt"
+ {"i16x8.sub_sat_s", TokenType::Binary, Opcode::I16X8SubSatS},
+ {""}, {""}, {""},
+#line 381 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw16.and_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16AndU},
+#line 251 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw16.and_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16AndU},
+#line 347 "src/lexer-keywords.txt"
+ {"i32x4.dot_i16x8_s", TokenType::Binary, Opcode::I32X4DotI16X8S},
{""},
-#line 549 "src/lexer-keywords.txt"
- {"memory.init", TokenType::MemoryInit, Opcode::MemoryInit},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 117 "src/lexer-keywords.txt"
- {"f32x4.sub", TokenType::Binary, Opcode::F32X4Sub},
+#line 389 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw32.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I64AtomicRmw32CmpxchgU},
+ {""}, {""}, {""}, {""}, {""},
+#line 525 "src/lexer-keywords.txt"
+ {"i8x16.relaxed_laneselect", TokenType::Ternary, Opcode::I8X16RelaxedLaneSelect},
+#line 501 "src/lexer-keywords.txt"
+ {"i8x16.all_true", TokenType::Unary, Opcode::I8X16AllTrue},
{""}, {""}, {""}, {""},
-#line 598 "src/lexer-keywords.txt"
- {"v128.load32_zero", TokenType::Load, Opcode::V128Load32Zero},
-#line 355 "src/lexer-keywords.txt"
- {"i32x4.sub", TokenType::Binary, Opcode::I32X4Sub},
- {""}, {""}, {""},
-#line 564 "src/lexer-keywords.txt"
- {"ref.func", TokenType::RefFunc, Opcode::RefFunc},
+#line 577 "src/lexer-keywords.txt"
+ {"start", TokenType::Start},
{""},
-#line 121 "src/lexer-keywords.txt"
+#line 123 "src/lexer-keywords.txt"
{"f64.abs", TokenType::Unary, Opcode::F64Abs},
-#line 59 "src/lexer-keywords.txt"
+#line 61 "src/lexer-keywords.txt"
{"f32.abs", TokenType::Unary, Opcode::F32Abs},
-#line 575 "src/lexer-keywords.txt"
- {"start", TokenType::Start},
-#line 449 "src/lexer-keywords.txt"
- {"i64.store16", TokenType::Store, Opcode::I64Store16},
-#line 306 "src/lexer-keywords.txt"
- {"i32.store16", TokenType::Store, Opcode::I32Store16},
-#line 89 "src/lexer-keywords.txt"
- {"f32x4.abs", TokenType::Unary, Opcode::F32X4Abs},
- {""}, {""}, {""}, {""}, {""},
-#line 320 "src/lexer-keywords.txt"
- {"i32x4.abs", TokenType::Unary, Opcode::I32X4Abs},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 527 "src/lexer-keywords.txt"
- {"i8x16.shr_u", TokenType::Binary, Opcode::I8X16ShrU},
{""},
-#line 526 "src/lexer-keywords.txt"
- {"i8x16.shr_s", TokenType::Binary, Opcode::I8X16ShrS},
+#line 532 "src/lexer-keywords.txt"
+ {"i8x16.sub_sat_u", TokenType::Binary, Opcode::I8X16SubSatU},
{""}, {""}, {""},
-#line 597 "src/lexer-keywords.txt"
- {"v128.any_true", TokenType::Unary, Opcode::V128AnyTrue},
+#line 531 "src/lexer-keywords.txt"
+ {"i8x16.sub_sat_s", TokenType::Binary, Opcode::I8X16SubSatS},
+#line 616 "src/lexer-keywords.txt"
+ {"v128.store16_lane", TokenType::SimdStoreLane, Opcode::V128Store16Lane},
{""}, {""}, {""}, {""}, {""}, {""},
-#line 193 "src/lexer-keywords.txt"
- {"i16x8.add_sat_u", TokenType::Binary, Opcode::I16X8AddSatU},
+#line 119 "src/lexer-keywords.txt"
+ {"f32x4.sub", TokenType::Binary, Opcode::F32X4Sub},
{""}, {""},
-#line 175 "src/lexer-keywords.txt"
- {"f64x2.splat", TokenType::Unary, Opcode::F64X2Splat},
-#line 192 "src/lexer-keywords.txt"
- {"i16x8.add_sat_s", TokenType::Binary, Opcode::I16X8AddSatS},
- {""}, {""}, {""}, {""},
-#line 487 "src/lexer-keywords.txt"
- {"i64x2.splat", TokenType::Unary, Opcode::I64X2Splat},
- {""}, {""}, {""}, {""}, {""},
-#line 213 "src/lexer-keywords.txt"
- {"i16x8.max_u", TokenType::Binary, Opcode::I16X8MaxU},
+#line 91 "src/lexer-keywords.txt"
+ {"f32x4.abs", TokenType::Unary, Opcode::F32X4Abs},
{""},
-#line 212 "src/lexer-keywords.txt"
- {"i16x8.max_s", TokenType::Binary, Opcode::I16X8MaxS},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""},
-#line 605 "src/lexer-keywords.txt"
- {"v128.load64_splat", TokenType::Load, Opcode::V128Load64Splat},
- {""}, {""}, {""},
-#line 375 "src/lexer-keywords.txt"
- {"i64.atomic.load32_u", TokenType::AtomicLoad, Opcode::I64AtomicLoad32U},
+#line 608 "src/lexer-keywords.txt"
+ {"v128.load32_splat", TokenType::Load, Opcode::V128Load32Splat},
+#line 562 "src/lexer-keywords.txt"
+ {"param", TokenType::Param},
+#line 357 "src/lexer-keywords.txt"
+ {"i32x4.sub", TokenType::Binary, Opcode::I32X4Sub},
+#line 96 "src/lexer-keywords.txt"
+ {"f32x4.div", TokenType::Binary, Opcode::F32X4Div},
+#line 602 "src/lexer-keywords.txt"
+ {"v128.load32_zero", TokenType::Load, Opcode::V128Load32Zero},
+#line 322 "src/lexer-keywords.txt"
+ {"i32x4.abs", TokenType::Unary, Opcode::I32X4Abs},
#line 34 "src/lexer-keywords.txt"
{"br_table", TokenType::BrTable, Opcode::BrTable},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 610 "src/lexer-keywords.txt"
- {"v128.load64_lane", TokenType::SimdLoadLane, Opcode::V128Load64Lane},
-#line 94 "src/lexer-keywords.txt"
- {"f32x4.div", TokenType::Binary, Opcode::F32X4Div},
{""}, {""}, {""},
-#line 201 "src/lexer-keywords.txt"
- {"i16x8.extract_lane_u", TokenType::SimdLaneOp, Opcode::I16X8ExtractLaneU},
- {""},
-#line 200 "src/lexer-keywords.txt"
- {"i16x8.extract_lane_s", TokenType::SimdLaneOp, Opcode::I16X8ExtractLaneS},
+#line 195 "src/lexer-keywords.txt"
+ {"i16x8.add_sat_u", TokenType::Binary, Opcode::I16X8AddSatU},
+ {""}, {""}, {""},
+#line 194 "src/lexer-keywords.txt"
+ {"i16x8.add_sat_s", TokenType::Binary, Opcode::I16X8AddSatS},
{""},
-#line 401 "src/lexer-keywords.txt"
- {"i64.atomic.rmw.cmpxchg", TokenType::AtomicRmwCmpxchg, Opcode::I64AtomicRmwCmpxchg},
-#line 264 "src/lexer-keywords.txt"
- {"i32.atomic.rmw.cmpxchg", TokenType::AtomicRmwCmpxchg, Opcode::I32AtomicRmwCmpxchg},
+#line 111 "src/lexer-keywords.txt"
+ {"f32x4.pmin", TokenType::Binary, Opcode::F32X4PMin},
+#line 31 "src/lexer-keywords.txt"
+ {"binary", TokenType::Bin},
{""}, {""}, {""}, {""}, {""}, {""},
-#line 548 "src/lexer-keywords.txt"
- {"memory.grow", TokenType::MemoryGrow, Opcode::MemoryGrow},
-#line 516 "src/lexer-keywords.txt"
- {"i8x16.min_u", TokenType::Binary, Opcode::I8X16MinU},
+#line 463 "src/lexer-keywords.txt"
+ {"i64.trunc_sat_f64_u", TokenType::Convert, Opcode::I64TruncSatF64U},
+#line 319 "src/lexer-keywords.txt"
+ {"i32.trunc_sat_f64_u", TokenType::Convert, Opcode::I32TruncSatF64U},
+#line 385 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw16.xchg_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16XchgU},
+#line 255 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw16.xchg_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16XchgU},
+#line 462 "src/lexer-keywords.txt"
+ {"i64.trunc_sat_f64_s", TokenType::Convert, Opcode::I64TruncSatF64S},
+#line 318 "src/lexer-keywords.txt"
+ {"i32.trunc_sat_f64_s", TokenType::Convert, Opcode::I32TruncSatF64S},
+ {""}, {""},
+#line 613 "src/lexer-keywords.txt"
+ {"v128.load32_lane", TokenType::SimdLoadLane, Opcode::V128Load32Lane},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 499 "src/lexer-keywords.txt"
+ {"i8x16.add_sat_u", TokenType::Binary, Opcode::I8X16AddSatU},
+#line 377 "src/lexer-keywords.txt"
+ {"i64.atomic.load32_u", TokenType::AtomicLoad, Opcode::I64AtomicLoad32U},
{""},
-#line 515 "src/lexer-keywords.txt"
- {"i8x16.min_s", TokenType::Binary, Opcode::I8X16MinS},
+#line 615 "src/lexer-keywords.txt"
+ {"v128.store8_lane", TokenType::SimdStoreLane, Opcode::V128Store8Lane},
+#line 498 "src/lexer-keywords.txt"
+ {"i8x16.add_sat_s", TokenType::Binary, Opcode::I8X16AddSatS},
{""},
-#line 528 "src/lexer-keywords.txt"
- {"i8x16.splat", TokenType::Unary, Opcode::I8X16Splat},
- {""}, {""},
-#line 599 "src/lexer-keywords.txt"
- {"v128.load64_zero", TokenType::Load, Opcode::V128Load64Zero},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 586 "src/lexer-keywords.txt"
- {"throw", TokenType::Throw, Opcode::Throw},
+#line 386 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw16.xor_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16XorU},
+#line 256 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw16.xor_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16XorU},
{""},
-#line 68 "src/lexer-keywords.txt"
- {"f32.demote_f64", TokenType::Convert, Opcode::F32DemoteF64},
- {""}, {""},
-#line 382 "src/lexer-keywords.txt"
- {"i64.atomic.rmw16.sub_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16SubU},
-#line 252 "src/lexer-keywords.txt"
- {"i32.atomic.rmw16.sub_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16SubU},
+#line 192 "src/lexer-keywords.txt"
+ {"global", TokenType::Global},
+#line 215 "src/lexer-keywords.txt"
+ {"i16x8.max_u", TokenType::Binary, Opcode::I16X8MaxU},
{""},
-#line 47 "src/lexer-keywords.txt"
- {"drop", TokenType::Drop, Opcode::Drop},
- {""}, {""}, {""},
-#line 613 "src/lexer-keywords.txt"
- {"v128.store32_lane", TokenType::SimdStoreLane, Opcode::V128Store32Lane},
- {""}, {""}, {""}, {""}, {""},
-#line 574 "src/lexer-keywords.txt"
- {"shared", TokenType::Shared},
-#line 616 "src/lexer-keywords.txt"
- {"i8x16.swizzle", TokenType::Binary, Opcode::I8X16Swizzle},
+#line 214 "src/lexer-keywords.txt"
+ {"i16x8.max_s", TokenType::Binary, Opcode::I16X8MaxS},
{""}, {""}, {""}, {""},
-#line 578 "src/lexer-keywords.txt"
- {"table.fill", TokenType::TableFill, Opcode::TableFill},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 394 "src/lexer-keywords.txt"
- {"i64.atomic.rmw8.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I64AtomicRmw8CmpxchgU},
-#line 257 "src/lexer-keywords.txt"
- {"i32.atomic.rmw8.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I32AtomicRmw8CmpxchgU},
-#line 119 "src/lexer-keywords.txt"
- {"f32x4.demote_f64x2_zero", TokenType::Unary, Opcode::F32X4DemoteF64X2Zero},
+#line 488 "src/lexer-keywords.txt"
+ {"i64x2.shr_u", TokenType::Binary, Opcode::I64X2ShrU},
+ {""},
+#line 487 "src/lexer-keywords.txt"
+ {"i64x2.shr_s", TokenType::Binary, Opcode::I64X2ShrS},
+ {""},
+#line 549 "src/lexer-keywords.txt"
+ {"memory.fill", TokenType::MemoryFill, Opcode::MemoryFill},
+ {""}, {""}, {""}, {""},
+#line 326 "src/lexer-keywords.txt"
+ {"i32x4.relaxed_dot_i8x16_i7x16_add_s", TokenType::Ternary, Opcode::I32X4DotI8X16I7X16AddS},
+#line 41 "src/lexer-keywords.txt"
+ {"catch_ref", TokenType::CatchRef},
{""}, {""}, {""},
-#line 589 "src/lexer-keywords.txt"
- {"unreachable", TokenType::Unreachable, Opcode::Unreachable},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 579 "src/lexer-keywords.txt"
+ {"table.copy", TokenType::TableCopy, Opcode::TableCopy},
+ {""},
+#line 227 "src/lexer-keywords.txt"
+ {"i16x8.shl", TokenType::Binary, Opcode::I16X8Shl},
{""}, {""}, {""}, {""}, {""},
-#line 176 "src/lexer-keywords.txt"
- {"f64x2.sqrt", TokenType::Unary, Opcode::F64X2Sqrt},
- {""}, {""},
-#line 407 "src/lexer-keywords.txt"
- {"i64.atomic.store32", TokenType::AtomicStore, Opcode::I64AtomicStore32},
+#line 516 "src/lexer-keywords.txt"
+ {"i8x16.max_u", TokenType::Binary, Opcode::I8X16MaxU},
{""},
-#line 128 "src/lexer-keywords.txt"
+#line 515 "src/lexer-keywords.txt"
+ {"i8x16.max_s", TokenType::Binary, Opcode::I8X16MaxS},
+ {""}, {""},
+#line 576 "src/lexer-keywords.txt"
+ {"shared", TokenType::Shared},
+#line 130 "src/lexer-keywords.txt"
{"f64.convert_i64_u", TokenType::Convert, Opcode::F64ConvertI64U},
-#line 66 "src/lexer-keywords.txt"
+#line 68 "src/lexer-keywords.txt"
{"f32.convert_i64_u", TokenType::Convert, Opcode::F32ConvertI64U},
-#line 379 "src/lexer-keywords.txt"
- {"i64.atomic.rmw16.and_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16AndU},
-#line 249 "src/lexer-keywords.txt"
- {"i32.atomic.rmw16.and_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16AndU},
-#line 127 "src/lexer-keywords.txt"
+ {""}, {""},
+#line 129 "src/lexer-keywords.txt"
{"f64.convert_i64_s", TokenType::Convert, Opcode::F64ConvertI64S},
-#line 65 "src/lexer-keywords.txt"
+#line 67 "src/lexer-keywords.txt"
{"f32.convert_i64_s", TokenType::Convert, Opcode::F32ConvertI64S},
- {""}, {""}, {""},
-#line 227 "src/lexer-keywords.txt"
- {"i16x8.shr_u", TokenType::Binary, Opcode::I16X8ShrU},
-#line 168 "src/lexer-keywords.txt"
- {"f64x2.pmax", TokenType::Binary, Opcode::F64X2PMax},
-#line 226 "src/lexer-keywords.txt"
- {"i16x8.shr_s", TokenType::Binary, Opcode::I16X8ShrS},
-#line 381 "src/lexer-keywords.txt"
- {"i64.atomic.rmw16.or_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16OrU},
-#line 251 "src/lexer-keywords.txt"
- {"i32.atomic.rmw16.or_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16OrU},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 569 "src/lexer-keywords.txt"
- {"rethrow", TokenType::Rethrow, Opcode::Rethrow},
- {""}, {""}, {""},
-#line 580 "src/lexer-keywords.txt"
- {"table.grow", TokenType::TableGrow, Opcode::TableGrow},
-#line 345 "src/lexer-keywords.txt"
- {"i32x4.dot_i16x8_s", TokenType::Binary, Opcode::I32X4DotI16X8S},
- {""}, {""},
-#line 169 "src/lexer-keywords.txt"
- {"f64x2.pmin", TokenType::Binary, Opcode::F64X2PMin},
- {""}, {""}, {""}, {""},
-#line 378 "src/lexer-keywords.txt"
- {"i64.atomic.rmw16.add_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16AddU},
-#line 248 "src/lexer-keywords.txt"
- {"i32.atomic.rmw16.add_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16AddU},
-#line 366 "src/lexer-keywords.txt"
- {"i32x4.extend_high_i16x8_u", TokenType::Unary, Opcode::I32X4ExtendHighI16X8U},
+ {""}, {""}, {""}, {""}, {""},
+#line 60 "src/lexer-keywords.txt"
+ {"export", TokenType::Export},
+ {""}, {""}, {""}, {""}, {""},
+#line 527 "src/lexer-keywords.txt"
+ {"i8x16.shl", TokenType::Binary, Opcode::I8X16Shl},
+#line 553 "src/lexer-keywords.txt"
+ {"memory", TokenType::Memory},
+#line 593 "src/lexer-keywords.txt"
+ {"unreachable", TokenType::Unreachable, Opcode::Unreachable},
{""},
-#line 365 "src/lexer-keywords.txt"
- {"i32x4.extend_high_i16x8_s", TokenType::Unary, Opcode::I32X4ExtendHighI16X8S},
+#line 177 "src/lexer-keywords.txt"
+ {"f64x2.splat", TokenType::Unary, Opcode::F64X2Splat},
+#line 110 "src/lexer-keywords.txt"
+ {"f32x4.pmax", TokenType::Binary, Opcode::F32X4PMax},
+#line 372 "src/lexer-keywords.txt"
+ {"i32x4.trunc_sat_f64x2_u_zero", TokenType::Unary, Opcode::I32X4TruncSatF64X2UZero},
{""},
-#line 383 "src/lexer-keywords.txt"
- {"i64.atomic.rmw16.xchg_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16XchgU},
-#line 253 "src/lexer-keywords.txt"
- {"i32.atomic.rmw16.xchg_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16XchgU},
+#line 371 "src/lexer-keywords.txt"
+ {"i32x4.trunc_sat_f64x2_s_zero", TokenType::Unary, Opcode::I32X4TruncSatF64X2SZero},
{""},
-#line 384 "src/lexer-keywords.txt"
- {"i64.atomic.rmw16.xor_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw16XorU},
-#line 254 "src/lexer-keywords.txt"
- {"i32.atomic.rmw16.xor_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw16XorU},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 520 "src/lexer-keywords.txt"
- {"i8x16.popcnt", TokenType::Unary, Opcode::I8X16Popcnt},
+#line 190 "src/lexer-keywords.txt"
+ {"global.get", TokenType::GlobalGet, Opcode::GlobalGet},
+#line 489 "src/lexer-keywords.txt"
+ {"i64x2.splat", TokenType::Unary, Opcode::I64X2Splat},
+#line 191 "src/lexer-keywords.txt"
+ {"global.set", TokenType::GlobalSet, Opcode::GlobalSet},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""},
-#line 542 "src/lexer-keywords.txt"
- {"loop", TokenType::Loop, Opcode::Loop},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""},
-#line 500 "src/lexer-keywords.txt"
- {"i8x16.avgr_u", TokenType::Binary, Opcode::I8X16AvgrU},
- {""},
-#line 361 "src/lexer-keywords.txt"
- {"i32x4.extmul_high_i16x8_u", TokenType::Binary, Opcode::I32X4ExtmulHighI16X8U},
- {""},
-#line 359 "src/lexer-keywords.txt"
- {"i32x4.extmul_high_i16x8_s", TokenType::Binary, Opcode::I32X4ExtmulHighI16X8S},
-#line 547 "src/lexer-keywords.txt"
- {"memory.fill", TokenType::MemoryFill, Opcode::MemoryFill},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 409 "src/lexer-keywords.txt"
+ {"i64.atomic.store32", TokenType::AtomicStore, Opcode::I64AtomicStore32},
{""}, {""},
-#line 215 "src/lexer-keywords.txt"
- {"i16x8.min_u", TokenType::Binary, Opcode::I16X8MinU},
- {""},
-#line 214 "src/lexer-keywords.txt"
- {"i16x8.min_s", TokenType::Binary, Opcode::I16X8MinS},
- {""},
-#line 228 "src/lexer-keywords.txt"
- {"i16x8.splat", TokenType::Unary, Opcode::I16X8Splat},
+#line 59 "src/lexer-keywords.txt"
+ {"exnref", Type::ExnRef},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""},
-#line 26 "src/lexer-keywords.txt"
- {"assert_return", TokenType::AssertReturn},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 609 "src/lexer-keywords.txt"
+ {"v128.load64_splat", TokenType::Load, Opcode::V128Load64Splat},
+#line 617 "src/lexer-keywords.txt"
+ {"v128.store32_lane", TokenType::SimdStoreLane, Opcode::V128Store32Lane},
+#line 178 "src/lexer-keywords.txt"
+ {"f64x2.sqrt", TokenType::Unary, Opcode::F64X2Sqrt},
+#line 588 "src/lexer-keywords.txt"
+ {"throw", TokenType::Throw, Opcode::Throw},
+#line 603 "src/lexer-keywords.txt"
+ {"v128.load64_zero", TokenType::Load, Opcode::V128Load64Zero},
{""}, {""}, {""}, {""},
-#line 145 "src/lexer-keywords.txt"
- {"f64.reinterpret_i64", TokenType::Convert, Opcode::F64ReinterpretI64},
- {""}, {""}, {""},
-#line 414 "src/lexer-keywords.txt"
+#line 37 "src/lexer-keywords.txt"
+ {"call_ref", TokenType::CallRef, Opcode::CallRef},
+ {""}, {""},
+#line 551 "src/lexer-keywords.txt"
+ {"memory.init", TokenType::MemoryInit, Opcode::MemoryInit},
+#line 416 "src/lexer-keywords.txt"
{"i64.div_u", TokenType::Binary, Opcode::I64DivU},
-#line 276 "src/lexer-keywords.txt"
+#line 278 "src/lexer-keywords.txt"
{"i32.div_u", TokenType::Binary, Opcode::I32DivU},
-#line 413 "src/lexer-keywords.txt"
+#line 415 "src/lexer-keywords.txt"
{"i64.div_s", TokenType::Binary, Opcode::I64DivS},
-#line 275 "src/lexer-keywords.txt"
+#line 277 "src/lexer-keywords.txt"
{"i32.div_s", TokenType::Binary, Opcode::I32DivS},
{""}, {""}, {""}, {""},
-#line 157 "src/lexer-keywords.txt"
- {"f64x2.floor", TokenType::Unary, Opcode::F64X2Floor},
+#line 418 "src/lexer-keywords.txt"
+ {"i64.eqz", TokenType::Convert, Opcode::I64Eqz},
+#line 280 "src/lexer-keywords.txt"
+ {"i32.eqz", TokenType::Convert, Opcode::I32Eqz},
+ {""}, {""},
+#line 589 "src/lexer-keywords.txt"
+ {"throw_ref", TokenType::ThrowRef, Opcode::ThrowRef},
{""},
-#line 357 "src/lexer-keywords.txt"
- {"i32x4.extadd_pairwise_i16x8_u", TokenType::Unary, Opcode::I32X4ExtaddPairwiseI16X8U},
+#line 203 "src/lexer-keywords.txt"
+ {"i16x8.extract_lane_u", TokenType::SimdLaneOp, Opcode::I16X8ExtractLaneU},
{""},
-#line 356 "src/lexer-keywords.txt"
- {"i32x4.extadd_pairwise_i16x8_s", TokenType::Unary, Opcode::I32X4ExtaddPairwiseI16X8S},
- {""}, {""}, {""},
-#line 440 "src/lexer-keywords.txt"
- {"i64.popcnt", TokenType::Unary, Opcode::I64Popcnt},
-#line 297 "src/lexer-keywords.txt"
- {"i32.popcnt", TokenType::Unary, Opcode::I32Popcnt},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""},
-#line 559 "src/lexer-keywords.txt"
- {"pagesize", TokenType::PageSize},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 556 "src/lexer-keywords.txt"
- {"nop", TokenType::Nop, Opcode::Nop},
+#line 202 "src/lexer-keywords.txt"
+ {"i16x8.extract_lane_s", TokenType::SimdLaneOp, Opcode::I16X8ExtractLaneS},
{""}, {""},
+#line 614 "src/lexer-keywords.txt"
+ {"v128.load64_lane", TokenType::SimdLoadLane, Opcode::V128Load64Lane},
#line 396 "src/lexer-keywords.txt"
- {"i64.atomic.rmw8.sub_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8SubU},
+ {"i64.atomic.rmw8.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I64AtomicRmw8CmpxchgU},
#line 259 "src/lexer-keywords.txt"
- {"i32.atomic.rmw8.sub_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8SubU},
- {""}, {""}, {""},
-#line 406 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw8.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I32AtomicRmw8CmpxchgU},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 408 "src/lexer-keywords.txt"
{"i64.atomic.store16", TokenType::AtomicStore, Opcode::I64AtomicStore16},
-#line 269 "src/lexer-keywords.txt"
+#line 271 "src/lexer-keywords.txt"
{"i32.atomic.store16", TokenType::AtomicStore, Opcode::I32AtomicStore16},
- {""}, {""}, {""},
-#line 480 "src/lexer-keywords.txt"
- {"i64x2.extend_low_i32x4_u", TokenType::Unary, Opcode::I64X2ExtendLowI32X4U},
- {""},
-#line 478 "src/lexer-keywords.txt"
- {"i64x2.extend_low_i32x4_s", TokenType::Unary, Opcode::I64X2ExtendLowI32X4S},
{""}, {""},
-#line 370 "src/lexer-keywords.txt"
- {"i32x4.trunc_sat_f64x2_u_zero", TokenType::Unary, Opcode::I32X4TruncSatF64X2UZero},
+#line 591 "src/lexer-keywords.txt"
+ {"try_table", TokenType::TryTable, Opcode::TryTable},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 601 "src/lexer-keywords.txt"
+ {"v128.any_true", TokenType::Unary, Opcode::V128AnyTrue},
{""},
-#line 369 "src/lexer-keywords.txt"
- {"i32x4.trunc_sat_f64x2_s_zero", TokenType::Unary, Opcode::I32X4TruncSatF64X2SZero},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 461 "src/lexer-keywords.txt"
- {"i64.trunc_sat_f64_u", TokenType::Convert, Opcode::I64TruncSatF64U},
-#line 317 "src/lexer-keywords.txt"
- {"i32.trunc_sat_f64_u", TokenType::Convert, Opcode::I32TruncSatF64U},
+#line 506 "src/lexer-keywords.txt"
+ {"i8x16.extract_lane_u", TokenType::SimdLaneOp, Opcode::I8X16ExtractLaneU},
+#line 366 "src/lexer-keywords.txt"
+ {"i32x4.trunc_sat_f32x4_u", TokenType::Unary, Opcode::I32X4TruncSatF32X4U},
+#line 505 "src/lexer-keywords.txt"
+ {"i8x16.extract_lane_s", TokenType::SimdLaneOp, Opcode::I8X16ExtractLaneS},
+ {""}, {""},
+#line 365 "src/lexer-keywords.txt"
+ {"i32x4.trunc_sat_f32x4_s", TokenType::Unary, Opcode::I32X4TruncSatF32X4S},
+ {""}, {""}, {""}, {""},
+#line 49 "src/lexer-keywords.txt"
+ {"drop", TokenType::Drop, Opcode::Drop},
+ {""}, {""}, {""},
+#line 582 "src/lexer-keywords.txt"
+ {"table.grow", TokenType::TableGrow, Opcode::TableGrow},
+ {""}, {""},
+#line 571 "src/lexer-keywords.txt"
+ {"rethrow", TokenType::Rethrow, Opcode::Rethrow},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""},
-#line 323 "src/lexer-keywords.txt"
- {"i32x4.bitmask", TokenType::Unary, Opcode::I32X4Bitmask},
-#line 460 "src/lexer-keywords.txt"
- {"i64.trunc_sat_f64_s", TokenType::Convert, Opcode::I64TruncSatF64S},
-#line 316 "src/lexer-keywords.txt"
- {"i32.trunc_sat_f64_s", TokenType::Convert, Opcode::I32TruncSatF64S},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 177 "src/lexer-keywords.txt"
- {"f64x2.sub", TokenType::Binary, Opcode::F64X2Sub},
+#line 229 "src/lexer-keywords.txt"
+ {"i16x8.shr_u", TokenType::Binary, Opcode::I16X8ShrU},
+#line 217 "src/lexer-keywords.txt"
+ {"i16x8.min_u", TokenType::Binary, Opcode::I16X8MinU},
+#line 228 "src/lexer-keywords.txt"
+ {"i16x8.shr_s", TokenType::Binary, Opcode::I16X8ShrS},
+#line 216 "src/lexer-keywords.txt"
+ {"i16x8.min_s", TokenType::Binary, Opcode::I16X8MinS},
{""}, {""}, {""}, {""}, {""},
-#line 488 "src/lexer-keywords.txt"
- {"i64x2.sub", TokenType::Binary, Opcode::I64X2Sub},
+#line 403 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw.cmpxchg", TokenType::AtomicRmwCmpxchg, Opcode::I64AtomicRmwCmpxchg},
+#line 266 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw.cmpxchg", TokenType::AtomicRmwCmpxchg, Opcode::I32AtomicRmwCmpxchg},
+ {""},
+#line 121 "src/lexer-keywords.txt"
+ {"f32x4.demote_f64x2_zero", TokenType::Unary, Opcode::F32X4DemoteF64X2Zero},
+ {""}, {""},
+#line 42 "src/lexer-keywords.txt"
+ {"catch_all_ref", TokenType::CatchAllRef},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 491 "src/lexer-keywords.txt"
- {"i64x2.extmul_low_i32x4_u", TokenType::Binary, Opcode::I64X2ExtmulLowI32X4U},
-#line 151 "src/lexer-keywords.txt"
- {"f64x2.abs", TokenType::Unary, Opcode::F64X2Abs},
-#line 489 "src/lexer-keywords.txt"
- {"i64x2.extmul_low_i32x4_s", TokenType::Binary, Opcode::I64X2ExtmulLowI32X4S},
{""}, {""}, {""}, {""},
-#line 474 "src/lexer-keywords.txt"
- {"i64x2.abs", TokenType::Unary, Opcode::I64X2Abs},
+#line 529 "src/lexer-keywords.txt"
+ {"i8x16.shr_u", TokenType::Binary, Opcode::I8X16ShrU},
+#line 518 "src/lexer-keywords.txt"
+ {"i8x16.min_u", TokenType::Binary, Opcode::I8X16MinU},
+#line 528 "src/lexer-keywords.txt"
+ {"i8x16.shr_s", TokenType::Binary, Opcode::I8X16ShrS},
+#line 517 "src/lexer-keywords.txt"
+ {"i8x16.min_s", TokenType::Binary, Opcode::I8X16MinS},
{""}, {""}, {""},
-#line 129 "src/lexer-keywords.txt"
- {"f64.copysign", TokenType::Binary, Opcode::F64Copysign},
-#line 67 "src/lexer-keywords.txt"
- {"f32.copysign", TokenType::Binary, Opcode::F32Copysign},
+#line 26 "src/lexer-keywords.txt"
+ {"assert_return", TokenType::AssertReturn},
+#line 550 "src/lexer-keywords.txt"
+ {"memory.grow", TokenType::MemoryGrow, Opcode::MemoryGrow},
{""}, {""}, {""}, {""},
-#line 319 "src/lexer-keywords.txt"
- {"i32.wrap_i64", TokenType::Convert, Opcode::I32WrapI64},
+#line 398 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw8.sub_u", TokenType::AtomicRmw, Opcode::I64AtomicRmw8SubU},
+#line 261 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw8.sub_u", TokenType::AtomicRmw, Opcode::I32AtomicRmw8SubU},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 131 "src/lexer-keywords.txt"
- {"f64.eq", TokenType::Compare, Opcode::F64Eq},
-#line 70 "src/lexer-keywords.txt"
- {"f32.eq", TokenType::Compare, Opcode::F32Eq},
- {""},
-#line 196 "src/lexer-keywords.txt"
- {"i16x8.avgr_u", TokenType::Binary, Opcode::I16X8AvgrU},
{""}, {""},
-#line 415 "src/lexer-keywords.txt"
- {"i64.eq", TokenType::Compare, Opcode::I64Eq},
-#line 277 "src/lexer-keywords.txt"
- {"i32.eq", TokenType::Compare, Opcode::I32Eq},
+#line 198 "src/lexer-keywords.txt"
+ {"i16x8.avgr_u", TokenType::Binary, Opcode::I16X8AvgrU},
+#line 230 "src/lexer-keywords.txt"
+ {"i16x8.splat", TokenType::Unary, Opcode::I16X8Splat},
+ {""}, {""}, {""},
+#line 340 "src/lexer-keywords.txt"
+ {"v128.load16x4_u", TokenType::Load, Opcode::V128Load16X4U},
{""},
-#line 546 "src/lexer-keywords.txt"
- {"memory.copy", TokenType::MemoryCopy, Opcode::MemoryCopy},
+#line 558 "src/lexer-keywords.txt"
+ {"nop", TokenType::Nop, Opcode::Nop},
{""},
-#line 95 "src/lexer-keywords.txt"
- {"f32x4.eq", TokenType::Compare, Opcode::F32X4Eq},
- {""}, {""}, {""}, {""}, {""},
-#line 325 "src/lexer-keywords.txt"
- {"i32x4.eq", TokenType::Compare, Opcode::I32X4Eq},
- {""}, {""},
-#line 531 "src/lexer-keywords.txt"
- {"i8x16.sub", TokenType::Binary, Opcode::I8X16Sub},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 339 "src/lexer-keywords.txt"
+ {"v128.load16x4_s", TokenType::Load, Opcode::V128Load16X4S},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 179 "src/lexer-keywords.txt"
+ {"f64x2.sub", TokenType::Binary, Opcode::F64X2Sub},
{""}, {""},
-#line 198 "src/lexer-keywords.txt"
- {"i16x8.relaxed_dot_i8x16_i7x16_s", TokenType::Binary, Opcode::I16X8DotI8X16I7X16S},
- {""}, {""}, {""}, {""},
-#line 495 "src/lexer-keywords.txt"
- {"i8x16.abs", TokenType::Unary, Opcode::I8X16Abs},
- {""},
-#line 338 "src/lexer-keywords.txt"
- {"v128.load16x4_u", TokenType::Load, Opcode::V128Load16X4U},
+#line 153 "src/lexer-keywords.txt"
+ {"f64x2.abs", TokenType::Unary, Opcode::F64X2Abs},
{""}, {""}, {""},
-#line 337 "src/lexer-keywords.txt"
- {"v128.load16x4_s", TokenType::Load, Opcode::V128Load16X4S},
- {""},
-#line 154 "src/lexer-keywords.txt"
+#line 490 "src/lexer-keywords.txt"
+ {"i64x2.sub", TokenType::Binary, Opcode::I64X2Sub},
+#line 156 "src/lexer-keywords.txt"
{"f64x2.div", TokenType::Binary, Opcode::F64X2Div},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 25 "src/lexer-keywords.txt"
- {"assert_malformed", TokenType::AssertMalformed},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 58 "src/lexer-keywords.txt"
- {"export", TokenType::Export},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""},
-#line 364 "src/lexer-keywords.txt"
- {"i32x4.trunc_sat_f32x4_u", TokenType::Unary, Opcode::I32X4TruncSatF32X4U},
+ {""},
+#line 476 "src/lexer-keywords.txt"
+ {"i64x2.abs", TokenType::Unary, Opcode::I64X2Abs},
+#line 502 "src/lexer-keywords.txt"
+ {"i8x16.avgr_u", TokenType::Binary, Opcode::I8X16AvgrU},
+#line 530 "src/lexer-keywords.txt"
+ {"i8x16.splat", TokenType::Unary, Opcode::I8X16Splat},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 171 "src/lexer-keywords.txt"
+ {"f64x2.pmin", TokenType::Binary, Opcode::F64X2PMin},
+ {""}, {""},
+#line 544 "src/lexer-keywords.txt"
+ {"loop", TokenType::Loop, Opcode::Loop},
+ {""}, {""}, {""}, {""}, {""},
+#line 461 "src/lexer-keywords.txt"
+ {"i64.trunc_sat_f32_u", TokenType::Convert, Opcode::I64TruncSatF32U},
+#line 317 "src/lexer-keywords.txt"
+ {"i32.trunc_sat_f32_u", TokenType::Convert, Opcode::I32TruncSatF32U},
+#line 133 "src/lexer-keywords.txt"
+ {"f64.eq", TokenType::Compare, Opcode::F64Eq},
+#line 72 "src/lexer-keywords.txt"
+ {"f32.eq", TokenType::Compare, Opcode::F32Eq},
+#line 460 "src/lexer-keywords.txt"
+ {"i64.trunc_sat_f32_s", TokenType::Convert, Opcode::I64TruncSatF32S},
+#line 316 "src/lexer-keywords.txt"
+ {"i32.trunc_sat_f32_s", TokenType::Convert, Opcode::I32TruncSatF32S},
{""}, {""}, {""},
-#line 363 "src/lexer-keywords.txt"
- {"i32x4.trunc_sat_f32x4_s", TokenType::Unary, Opcode::I32X4TruncSatF32X4S},
+#line 417 "src/lexer-keywords.txt"
+ {"i64.eq", TokenType::Compare, Opcode::I64Eq},
+#line 279 "src/lexer-keywords.txt"
+ {"i32.eq", TokenType::Compare, Opcode::I32Eq},
+#line 325 "src/lexer-keywords.txt"
+ {"i32x4.bitmask", TokenType::Unary, Opcode::I32X4Bitmask},
+ {""}, {""}, {""}, {""},
+#line 442 "src/lexer-keywords.txt"
+ {"i64.popcnt", TokenType::Unary, Opcode::I64Popcnt},
+#line 299 "src/lexer-keywords.txt"
+ {"i32.popcnt", TokenType::Unary, Opcode::I32Popcnt},
+ {""}, {""},
+#line 382 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw16.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I64AtomicRmw16CmpxchgU},
+#line 252 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw16.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I32AtomicRmw16CmpxchgU},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 218 "src/lexer-keywords.txt"
- {"i16x8.narrow_i32x4_u", TokenType::Binary, Opcode::I16X8NarrowI32X4U},
+ {""}, {""}, {""}, {""},
+#line 97 "src/lexer-keywords.txt"
+ {"f32x4.eq", TokenType::Compare, Opcode::F32X4Eq},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 327 "src/lexer-keywords.txt"
+ {"i32x4.eq", TokenType::Compare, Opcode::I32X4Eq},
+ {""}, {""}, {""}, {""}, {""},
+#line 482 "src/lexer-keywords.txt"
+ {"i64x2.extend_low_i32x4_u", TokenType::Unary, Opcode::I64X2ExtendLowI32X4U},
{""},
-#line 217 "src/lexer-keywords.txt"
- {"i16x8.narrow_i32x4_s", TokenType::Binary, Opcode::I16X8NarrowI32X4S},
-#line 126 "src/lexer-keywords.txt"
+#line 480 "src/lexer-keywords.txt"
+ {"i64x2.extend_low_i32x4_s", TokenType::Unary, Opcode::I64X2ExtendLowI32X4S},
+#line 522 "src/lexer-keywords.txt"
+ {"i8x16.popcnt", TokenType::Unary, Opcode::I8X16Popcnt},
+ {""}, {""},
+#line 607 "src/lexer-keywords.txt"
+ {"v128.load16_splat", TokenType::Load, Opcode::V128Load16Splat},
+ {""}, {""}, {""}, {""}, {""},
+#line 128 "src/lexer-keywords.txt"
{"f64.convert_i32_u", TokenType::Convert, Opcode::F64ConvertI32U},
-#line 64 "src/lexer-keywords.txt"
+#line 66 "src/lexer-keywords.txt"
{"f32.convert_i32_u", TokenType::Convert, Opcode::F32ConvertI32U},
- {""},
-#line 223 "src/lexer-keywords.txt"
- {"i16x8.relaxed_q15mulr_s", TokenType::Binary, Opcode::I16X8RelaxedQ15mulrS},
-#line 125 "src/lexer-keywords.txt"
+ {""}, {""},
+#line 127 "src/lexer-keywords.txt"
{"f64.convert_i32_s", TokenType::Convert, Opcode::F64ConvertI32S},
-#line 63 "src/lexer-keywords.txt"
+#line 65 "src/lexer-keywords.txt"
{"f32.convert_i32_s", TokenType::Convert, Opcode::F32ConvertI32S},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 481 "src/lexer-keywords.txt"
- {"i64x2.extend_high_i32x4_u", TokenType::Unary, Opcode::I64X2ExtendHighI32X4U},
- {""},
-#line 479 "src/lexer-keywords.txt"
- {"i64x2.extend_high_i32x4_s", TokenType::Unary, Opcode::I64X2ExtendHighI32X4S},
{""},
-#line 615 "src/lexer-keywords.txt"
- {"i8x16.shuffle", TokenType::SimdShuffleOp, Opcode::I8X16Shuffle},
-#line 380 "src/lexer-keywords.txt"
- {"i64.atomic.rmw16.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I64AtomicRmw16CmpxchgU},
-#line 250 "src/lexer-keywords.txt"
- {"i32.atomic.rmw16.cmpxchg_u", TokenType::AtomicRmwCmpxchg, Opcode::I32AtomicRmw16CmpxchgU},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 368 "src/lexer-keywords.txt"
+ {"i32x4.extend_high_i16x8_u", TokenType::Unary, Opcode::I32X4ExtendHighI16X8U},
{""},
-#line 242 "src/lexer-keywords.txt"
- {"i16x8.extend_low_i8x16_u", TokenType::Unary, Opcode::I16X8ExtendLowI8X16U},
-#line 93 "src/lexer-keywords.txt"
- {"f32x4.convert_i32x4_u", TokenType::Unary, Opcode::F32X4ConvertI32X4U},
-#line 241 "src/lexer-keywords.txt"
- {"i16x8.extend_low_i8x16_s", TokenType::Unary, Opcode::I16X8ExtendLowI8X16S},
-#line 92 "src/lexer-keywords.txt"
- {"f32x4.convert_i32x4_s", TokenType::Unary, Opcode::F32X4ConvertI32X4S},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 231 "src/lexer-keywords.txt"
- {"i16x8.sub", TokenType::Binary, Opcode::I16X8Sub},
+#line 367 "src/lexer-keywords.txt"
+ {"i32x4.extend_high_i16x8_s", TokenType::Unary, Opcode::I32X4ExtendHighI16X8S},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""},
+#line 170 "src/lexer-keywords.txt"
+ {"f64x2.pmax", TokenType::Binary, Opcode::F64X2PMax},
{""}, {""}, {""}, {""},
-#line 492 "src/lexer-keywords.txt"
- {"i64x2.extmul_high_i32x4_u", TokenType::Binary, Opcode::I64X2ExtmulHighI32X4U},
- {""},
-#line 490 "src/lexer-keywords.txt"
- {"i64x2.extmul_high_i32x4_s", TokenType::Binary, Opcode::I64X2ExtmulHighI32X4S},
-#line 191 "src/lexer-keywords.txt"
- {"i16x8.abs", TokenType::Unary, Opcode::I16X8Abs},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 33 "src/lexer-keywords.txt"
- {"br_if", TokenType::BrIf, Opcode::BrIf},
- {""},
-#line 55 "src/lexer-keywords.txt"
- {"externref", Type::ExternRef},
-#line 20 "src/lexer-keywords.txt"
- {"array", Type::Array, TokenType::Array},
- {""},
-#line 236 "src/lexer-keywords.txt"
- {"i16x8.extmul_low_i8x16_u", TokenType::Binary, Opcode::I16X8ExtmulLowI8X16U},
+#line 612 "src/lexer-keywords.txt"
+ {"v128.load16_lane", TokenType::SimdLoadLane, Opcode::V128Load16Lane},
+ {""}, {""},
+#line 619 "src/lexer-keywords.txt"
+ {"i8x16.shuffle", TokenType::SimdShuffleOp, Opcode::I8X16Shuffle},
+ {""}, {""},
+#line 359 "src/lexer-keywords.txt"
+ {"i32x4.extadd_pairwise_i16x8_u", TokenType::Unary, Opcode::I32X4ExtaddPairwiseI16X8U},
{""},
-#line 234 "src/lexer-keywords.txt"
- {"i16x8.extmul_low_i8x16_s", TokenType::Binary, Opcode::I16X8ExtmulLowI8X16S},
+#line 358 "src/lexer-keywords.txt"
+ {"i32x4.extadd_pairwise_i16x8_s", TokenType::Unary, Opcode::I32X4ExtaddPairwiseI16X8S},
+ {""}, {""},
+#line 25 "src/lexer-keywords.txt"
+ {"assert_malformed", TokenType::AssertMalformed},
+ {""}, {""}, {""},
+#line 51 "src/lexer-keywords.txt"
+ {"elem.drop", TokenType::ElemDrop, Opcode::ElemDrop},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""},
-#line 184 "src/lexer-keywords.txt"
- {"funcref", Type::FuncRef},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 603 "src/lexer-keywords.txt"
- {"v128.load16_splat", TokenType::Load, Opcode::V128Load16Splat},
+#line 493 "src/lexer-keywords.txt"
+ {"i64x2.extmul_low_i32x4_u", TokenType::Binary, Opcode::I64X2ExtmulLowI32X4U},
+#line 524 "src/lexer-keywords.txt"
+ {"i8x16.relaxed_swizzle", TokenType::Binary, Opcode::I8X16RelaxedSwizzle},
+#line 491 "src/lexer-keywords.txt"
+ {"i64x2.extmul_low_i32x4_s", TokenType::Binary, Opcode::I64X2ExtmulLowI32X4S},
{""}, {""}, {""}, {""}, {""},
-#line 368 "src/lexer-keywords.txt"
+#line 370 "src/lexer-keywords.txt"
{"i32x4.extend_low_i16x8_u", TokenType::Unary, Opcode::I32X4ExtendLowI16X8U},
{""},
-#line 367 "src/lexer-keywords.txt"
+#line 369 "src/lexer-keywords.txt"
{"i32x4.extend_low_i16x8_s", TokenType::Unary, Opcode::I32X4ExtendLowI16X8S},
- {""}, {""}, {""}, {""},
-#line 608 "src/lexer-keywords.txt"
- {"v128.load16_lane", TokenType::SimdLoadLane, Opcode::V128Load16Lane},
- {""}, {""}, {""}, {""}, {""}, {""},
-#line 50 "src/lexer-keywords.txt"
- {"elem", TokenType::Elem},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 363 "src/lexer-keywords.txt"
+ {"i32x4.extmul_high_i16x8_u", TokenType::Binary, Opcode::I32X4ExtmulHighI16X8U},
{""},
-#line 360 "src/lexer-keywords.txt"
- {"i32x4.extmul_low_i16x8_u", TokenType::Binary, Opcode::I32X4ExtmulLowI16X8U},
+#line 361 "src/lexer-keywords.txt"
+ {"i32x4.extmul_high_i16x8_s", TokenType::Binary, Opcode::I32X4ExtmulHighI16X8S},
{""},
-#line 358 "src/lexer-keywords.txt"
- {"i32x4.extmul_low_i16x8_s", TokenType::Binary, Opcode::I32X4ExtmulLowI16X8S},
+#line 147 "src/lexer-keywords.txt"
+ {"f64.reinterpret_i64", TokenType::Convert, Opcode::F64ReinterpretI64},
+ {""}, {""},
+#line 321 "src/lexer-keywords.txt"
+ {"i32.wrap_i64", TokenType::Convert, Opcode::I32WrapI64},
+ {""}, {""}, {""}, {""},
+#line 620 "src/lexer-keywords.txt"
+ {"i8x16.swizzle", TokenType::Binary, Opcode::I8X16Swizzle},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 545 "src/lexer-keywords.txt"
- {"memory.atomic.wait64", TokenType::AtomicWait, Opcode::MemoryAtomicWait64},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 459 "src/lexer-keywords.txt"
- {"i64.trunc_sat_f32_u", TokenType::Convert, Opcode::I64TruncSatF32U},
-#line 315 "src/lexer-keywords.txt"
- {"i32.trunc_sat_f32_u", TokenType::Convert, Opcode::I32TruncSatF32U},
-#line 477 "src/lexer-keywords.txt"
- {"i64x2.bitmask", TokenType::Unary, Opcode::I64X2Bitmask},
- {""},
-#line 458 "src/lexer-keywords.txt"
- {"i64.trunc_sat_f32_s", TokenType::Convert, Opcode::I64TruncSatF32S},
-#line 314 "src/lexer-keywords.txt"
- {"i32.trunc_sat_f32_s", TokenType::Convert, Opcode::I32TruncSatF32S},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""},
-#line 130 "src/lexer-keywords.txt"
+#line 132 "src/lexer-keywords.txt"
{"f64.div", TokenType::Binary, Opcode::F64Div},
-#line 69 "src/lexer-keywords.txt"
+#line 71 "src/lexer-keywords.txt"
{"f32.div", TokenType::Binary, Opcode::F32Div},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 233 "src/lexer-keywords.txt"
+ {"i16x8.sub", TokenType::Binary, Opcode::I16X8Sub},
+ {""}, {""},
+#line 193 "src/lexer-keywords.txt"
+ {"i16x8.abs", TokenType::Unary, Opcode::I16X8Abs},
+ {""},
+#line 561 "src/lexer-keywords.txt"
+ {"pagesize", TokenType::PageSize},
+ {""}, {""},
+#line 95 "src/lexer-keywords.txt"
+ {"f32x4.convert_i32x4_u", TokenType::Unary, Opcode::F32X4ConvertI32X4U},
+ {""},
+#line 94 "src/lexer-keywords.txt"
+ {"f32x4.convert_i32x4_s", TokenType::Unary, Opcode::F32X4ConvertI32X4S},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""},
-#line 27 "src/lexer-keywords.txt"
- {"assert_trap", TokenType::AssertTrap},
- {""}, {""}, {""}, {""},
-#line 592 "src/lexer-keywords.txt"
- {"v128.bitselect", TokenType::Ternary, Opcode::V128BitSelect},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""},
+#line 362 "src/lexer-keywords.txt"
+ {"i32x4.extmul_low_i16x8_u", TokenType::Binary, Opcode::I32X4ExtmulLowI16X8U},
{""},
-#line 501 "src/lexer-keywords.txt"
- {"i8x16.bitmask", TokenType::Unary, Opcode::I8X16Bitmask},
+#line 360 "src/lexer-keywords.txt"
+ {"i32x4.extmul_low_i16x8_s", TokenType::Binary, Opcode::I32X4ExtmulLowI16X8S},
{""}, {""},
-#line 144 "src/lexer-keywords.txt"
- {"f64.promote_f32", TokenType::Convert, Opcode::F64PromoteF32},
+#line 131 "src/lexer-keywords.txt"
+ {"f64.copysign", TokenType::Binary, Opcode::F64Copysign},
+#line 69 "src/lexer-keywords.txt"
+ {"f32.copysign", TokenType::Binary, Opcode::F32Copysign},
+#line 533 "src/lexer-keywords.txt"
+ {"i8x16.sub", TokenType::Binary, Opcode::I8X16Sub},
{""}, {""},
-#line 441 "src/lexer-keywords.txt"
- {"i64.reinterpret_f64", TokenType::Convert, Opcode::I64ReinterpretF64},
-#line 155 "src/lexer-keywords.txt"
- {"f64x2.eq", TokenType::Compare, Opcode::F64X2Eq},
+#line 497 "src/lexer-keywords.txt"
+ {"i8x16.abs", TokenType::Unary, Opcode::I8X16Abs},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""},
+#line 225 "src/lexer-keywords.txt"
+ {"i16x8.relaxed_q15mulr_s", TokenType::Binary, Opcode::I16X8RelaxedQ15mulrS},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""},
-#line 468 "src/lexer-keywords.txt"
- {"i64x2.eq", TokenType::Binary, Opcode::I64X2Eq},
+#line 200 "src/lexer-keywords.txt"
+ {"i16x8.relaxed_dot_i8x16_i7x16_s", TokenType::Binary, Opcode::I16X8DotI8X16I7X16S},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 23 "src/lexer-keywords.txt"
- {"assert_exhaustion", TokenType::AssertExhaustion},
+#line 443 "src/lexer-keywords.txt"
+ {"i64.reinterpret_f64", TokenType::Convert, Opcode::I64ReinterpretF64},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""},
+#line 244 "src/lexer-keywords.txt"
+ {"i16x8.extend_low_i8x16_u", TokenType::Unary, Opcode::I16X8ExtendLowI8X16U},
+ {""},
+#line 243 "src/lexer-keywords.txt"
+ {"i16x8.extend_low_i8x16_s", TokenType::Unary, Opcode::I16X8ExtendLowI8X16S},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""},
-#line 502 "src/lexer-keywords.txt"
- {"i8x16.eq", TokenType::Compare, Opcode::I8X16Eq},
- {""}, {""},
-#line 148 "src/lexer-keywords.txt"
- {"f64.sub", TokenType::Binary, Opcode::F64Sub},
-#line 86 "src/lexer-keywords.txt"
- {"f32.sub", TokenType::Binary, Opcode::F32Sub},
- {""}, {""}, {""}, {""},
-#line 453 "src/lexer-keywords.txt"
- {"i64.sub", TokenType::Binary, Opcode::I64Sub},
-#line 309 "src/lexer-keywords.txt"
- {"i32.sub", TokenType::Binary, Opcode::I32Sub},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 220 "src/lexer-keywords.txt"
+ {"i16x8.narrow_i32x4_u", TokenType::Binary, Opcode::I16X8NarrowI32X4U},
+ {""},
+#line 219 "src/lexer-keywords.txt"
+ {"i16x8.narrow_i32x4_s", TokenType::Binary, Opcode::I16X8NarrowI32X4S},
{""}, {""},
-#line 240 "src/lexer-keywords.txt"
- {"i16x8.extend_high_i8x16_u", TokenType::Unary, Opcode::I16X8ExtendHighI8X16U},
+#line 238 "src/lexer-keywords.txt"
+ {"i16x8.extmul_low_i8x16_u", TokenType::Binary, Opcode::I16X8ExtmulLowI8X16U},
{""},
-#line 239 "src/lexer-keywords.txt"
- {"i16x8.extend_high_i8x16_s", TokenType::Unary, Opcode::I16X8ExtendHighI8X16S},
+#line 236 "src/lexer-keywords.txt"
+ {"i16x8.extmul_low_i8x16_s", TokenType::Binary, Opcode::I16X8ExtmulLowI8X16S},
+ {""}, {""}, {""},
+#line 548 "src/lexer-keywords.txt"
+ {"memory.copy", TokenType::MemoryCopy, Opcode::MemoryCopy},
+ {""},
+#line 479 "src/lexer-keywords.txt"
+ {"i64x2.bitmask", TokenType::Unary, Opcode::I64X2Bitmask},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""},
-#line 22 "src/lexer-keywords.txt"
- {"assert_exception", TokenType::AssertException},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 83 "src/lexer-keywords.txt"
- {"f32.reinterpret_i32", TokenType::Convert, Opcode::F32ReinterpretI32},
+ {""}, {""}, {""}, {""}, {""},
+#line 157 "src/lexer-keywords.txt"
+ {"f64x2.eq", TokenType::Compare, Opcode::F64X2Eq},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 470 "src/lexer-keywords.txt"
+ {"i64x2.eq", TokenType::Binary, Opcode::I64X2Eq},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 237 "src/lexer-keywords.txt"
- {"i16x8.extmul_high_i8x16_u", TokenType::Binary, Opcode::I16X8ExtmulHighI8X16U},
+#line 483 "src/lexer-keywords.txt"
+ {"i64x2.extend_high_i32x4_u", TokenType::Unary, Opcode::I64X2ExtendHighI32X4U},
{""},
-#line 235 "src/lexer-keywords.txt"
- {"i16x8.extmul_high_i8x16_s", TokenType::Binary, Opcode::I16X8ExtmulHighI8X16S},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 481 "src/lexer-keywords.txt"
+ {"i64x2.extend_high_i32x4_s", TokenType::Unary, Opcode::I64X2ExtendHighI32X4S},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 20 "src/lexer-keywords.txt"
+ {"array", Type::Array, TokenType::Array},
{""}, {""},
-#line 197 "src/lexer-keywords.txt"
- {"i16x8.bitmask", TokenType::Unary, Opcode::I16X8Bitmask},
+#line 27 "src/lexer-keywords.txt"
+ {"assert_trap", TokenType::AssertTrap},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 596 "src/lexer-keywords.txt"
+ {"v128.bitselect", TokenType::Ternary, Opcode::V128BitSelect},
{""}, {""}, {""}, {""}, {""}, {""},
-#line 37 "src/lexer-keywords.txt"
- {"call_ref", TokenType::CallRef, Opcode::CallRef},
+#line 150 "src/lexer-keywords.txt"
+ {"f64.sub", TokenType::Binary, Opcode::F64Sub},
+#line 88 "src/lexer-keywords.txt"
+ {"f32.sub", TokenType::Binary, Opcode::F32Sub},
+ {""}, {""}, {""}, {""}, {""},
+#line 455 "src/lexer-keywords.txt"
+ {"i64.sub", TokenType::Binary, Opcode::I64Sub},
+#line 311 "src/lexer-keywords.txt"
+ {"i32.sub", TokenType::Binary, Opcode::I32Sub},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""},
-#line 233 "src/lexer-keywords.txt"
- {"i16x8.extadd_pairwise_i8x16_u", TokenType::Unary, Opcode::I16X8ExtaddPairwiseI8X16U},
- {""},
-#line 232 "src/lexer-keywords.txt"
- {"i16x8.extadd_pairwise_i8x16_s", TokenType::Unary, Opcode::I16X8ExtaddPairwiseI8X16S},
- {""}, {""}, {""}, {""},
-#line 544 "src/lexer-keywords.txt"
- {"memory.atomic.wait32", TokenType::AtomicWait, Opcode::MemoryAtomicWait32},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 146 "src/lexer-keywords.txt"
+ {"f64.promote_f32", TokenType::Convert, Opcode::F64PromoteF32},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 494 "src/lexer-keywords.txt"
+ {"i64x2.extmul_high_i32x4_u", TokenType::Binary, Opcode::I64X2ExtmulHighI32X4U},
+ {""},
+#line 492 "src/lexer-keywords.txt"
+ {"i64x2.extmul_high_i32x4_s", TokenType::Binary, Opcode::I64X2ExtmulHighI32X4S},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 199 "src/lexer-keywords.txt"
- {"i16x8.eq", TokenType::Compare, Opcode::I16X8Eq},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""},
+#line 22 "src/lexer-keywords.txt"
+ {"assert_exception", TokenType::AssertException},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 199 "src/lexer-keywords.txt"
+ {"i16x8.bitmask", TokenType::Unary, Opcode::I16X8Bitmask},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""},
-#line 518 "src/lexer-keywords.txt"
- {"i8x16.narrow_i16x8_u", TokenType::Binary, Opcode::I8X16NarrowI16X8U},
+ {""}, {""},
+#line 23 "src/lexer-keywords.txt"
+ {"assert_exhaustion", TokenType::AssertExhaustion},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 503 "src/lexer-keywords.txt"
+ {"i8x16.bitmask", TokenType::Unary, Opcode::I8X16Bitmask},
{""},
-#line 517 "src/lexer-keywords.txt"
- {"i8x16.narrow_i16x8_s", TokenType::Binary, Opcode::I8X16NarrowI16X8S},
+#line 201 "src/lexer-keywords.txt"
+ {"i16x8.eq", TokenType::Compare, Opcode::I16X8Eq},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""},
+#line 504 "src/lexer-keywords.txt"
+ {"i8x16.eq", TokenType::Compare, Opcode::I8X16Eq},
+ {""}, {""}, {""}, {""}, {""},
+#line 547 "src/lexer-keywords.txt"
+ {"memory.atomic.wait64", TokenType::AtomicWait, Opcode::MemoryAtomicWait64},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""},
-#line 28 "src/lexer-keywords.txt"
- {"assert_unlinkable", TokenType::AssertUnlinkable},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""},
-#line 403 "src/lexer-keywords.txt"
- {"i64.atomic.rmw.sub", TokenType::AtomicRmw, Opcode::I64AtomicRmwSub},
-#line 266 "src/lexer-keywords.txt"
- {"i32.atomic.rmw.sub", TokenType::AtomicRmw, Opcode::I32AtomicRmwSub},
+ {""}, {""}, {""},
+#line 85 "src/lexer-keywords.txt"
+ {"f32.reinterpret_i32", TokenType::Convert, Opcode::F32ReinterpretI32},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 543 "src/lexer-keywords.txt"
- {"memory.atomic.notify", TokenType::AtomicNotify, Opcode::MemoryAtomicNotify},
- {""}, {""},
+ {""}, {""}, {""}, {""}, {""},
#line 24 "src/lexer-keywords.txt"
{"assert_invalid", TokenType::AssertInvalid},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""},
-#line 49 "src/lexer-keywords.txt"
- {"elem.drop", TokenType::ElemDrop, Opcode::ElemDrop},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 405 "src/lexer-keywords.txt"
+ {"i64.atomic.rmw.sub", TokenType::AtomicRmw, Opcode::I64AtomicRmwSub},
+#line 268 "src/lexer-keywords.txt"
+ {"i32.atomic.rmw.sub", TokenType::AtomicRmw, Opcode::I32AtomicRmwSub},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""},
+#line 545 "src/lexer-keywords.txt"
+ {"memory.atomic.notify", TokenType::AtomicNotify, Opcode::MemoryAtomicNotify},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 242 "src/lexer-keywords.txt"
+ {"i16x8.extend_high_i8x16_u", TokenType::Unary, Opcode::I16X8ExtendHighI8X16U},
+ {""},
+#line 241 "src/lexer-keywords.txt"
+ {"i16x8.extend_high_i8x16_s", TokenType::Unary, Opcode::I16X8ExtendHighI8X16S},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 180 "src/lexer-keywords.txt"
+ {""},
+#line 28 "src/lexer-keywords.txt"
+ {"assert_unlinkable", TokenType::AssertUnlinkable},
+ {""}, {""},
+#line 300 "src/lexer-keywords.txt"
+ {"i32.reinterpret_f32", TokenType::Convert, Opcode::I32ReinterpretF32},
+ {""}, {""}, {""}, {""},
+#line 182 "src/lexer-keywords.txt"
{"f64x2.convert_low_i32x4_u", TokenType::Unary, Opcode::F64X2ConvertLowI32X4U},
{""},
-#line 179 "src/lexer-keywords.txt"
+#line 181 "src/lexer-keywords.txt"
{"f64x2.convert_low_i32x4_s", TokenType::Unary, Opcode::F64X2ConvertLowI32X4S},
+ {""},
+#line 235 "src/lexer-keywords.txt"
+ {"i16x8.extadd_pairwise_i8x16_u", TokenType::Unary, Opcode::I16X8ExtaddPairwiseI8X16U},
+ {""},
+#line 234 "src/lexer-keywords.txt"
+ {"i16x8.extadd_pairwise_i8x16_s", TokenType::Unary, Opcode::I16X8ExtaddPairwiseI8X16S},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""},
-#line 57 "src/lexer-keywords.txt"
- {"exnref", Type::ExnRef},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""},
+#line 546 "src/lexer-keywords.txt"
+ {"memory.atomic.wait32", TokenType::AtomicWait, Opcode::MemoryAtomicWait32},
{""}, {""}, {""}, {""}, {""},
-#line 220 "src/lexer-keywords.txt"
+#line 520 "src/lexer-keywords.txt"
+ {"i8x16.narrow_i16x8_u", TokenType::Binary, Opcode::I8X16NarrowI16X8U},
+ {""},
+#line 519 "src/lexer-keywords.txt"
+ {"i8x16.narrow_i16x8_s", TokenType::Binary, Opcode::I8X16NarrowI16X8S},
+ {""},
+#line 222 "src/lexer-keywords.txt"
{"i16x8.q15mulr_sat_s", TokenType::Binary, Opcode::I16X8Q15mulrSatS},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 298 "src/lexer-keywords.txt"
- {"i32.reinterpret_f32", TokenType::Convert, Opcode::I32ReinterpretF32},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+ {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
+#line 29 "src/lexer-keywords.txt"
+ {"atomic.fence", TokenType::AtomicFence, Opcode::AtomicFence},
+ {""}, {""}, {""}, {""},
+#line 239 "src/lexer-keywords.txt"
+ {"i16x8.extmul_high_i8x16_u", TokenType::Binary, Opcode::I16X8ExtmulHighI8X16U},
+ {""},
+#line 237 "src/lexer-keywords.txt"
+ {"i16x8.extmul_high_i8x16_s", TokenType::Binary, Opcode::I16X8ExtmulHighI8X16S},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
@@ -1795,14 +1771,11 @@ Perfect_Hash::InWordSet (const char *str, size_t len)
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
- {""}, {""}, {""}, {""},
-#line 29 "src/lexer-keywords.txt"
- {"atomic.fence", TokenType::AtomicFence, Opcode::AtomicFence},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
{""}, {""}, {""}, {""}, {""}, {""}, {""}, {""}, {""},
-#line 181 "src/lexer-keywords.txt"
+#line 183 "src/lexer-keywords.txt"
{"f64x2.promote_low_f32x4", TokenType::Unary, Opcode::F64X2PromoteLowF32X4}
};
diff --git a/src/resolve-names.cc b/src/resolve-names.cc
index 9fc8e443..67fc44e9 100644
--- a/src/resolve-names.cc
+++ b/src/resolve-names.cc
@@ -75,6 +75,8 @@ class NameResolver : public ExprVisitor::DelegateNop {
Result OnStoreExpr(StoreExpr*) override;
Result BeginTryExpr(TryExpr*) override;
Result EndTryExpr(TryExpr*) override;
+ Result BeginTryTableExpr(TryTableExpr*) override;
+ Result EndTryTableExpr(TryTableExpr*) override;
Result OnThrowExpr(ThrowExpr*) override;
Result OnRethrowExpr(RethrowExpr*) override;
Result OnSimdLoadLaneExpr(SimdLoadLaneExpr*) override;
@@ -442,6 +444,23 @@ Result NameResolver::EndTryExpr(TryExpr*) {
return Result::Ok;
}
+Result NameResolver::BeginTryTableExpr(TryTableExpr* expr) {
+ for (TableCatch& catch_ : expr->catches) {
+ if (!catch_.IsCatchAll()) {
+ ResolveTagVar(&catch_.tag);
+ }
+ ResolveLabelVar(&catch_.target);
+ }
+ PushLabel(expr->block.label);
+ ResolveBlockDeclarationVar(&expr->block.decl);
+ return Result::Ok;
+}
+
+Result NameResolver::EndTryTableExpr(TryTableExpr*) {
+ PopLabel();
+ return Result::Ok;
+}
+
Result NameResolver::OnCatchExpr(TryExpr*, Catch* catch_) {
if (!catch_->IsCatchAll()) {
ResolveTagVar(&catch_->var);
diff --git a/src/shared-validator.cc b/src/shared-validator.cc
index 6492cbeb..bdf6eb71 100644
--- a/src/shared-validator.cc
+++ b/src/shared-validator.cc
@@ -1219,6 +1219,12 @@ Result SharedValidator::OnThrow(const Location& loc, Var tag_var) {
return result;
}
+Result SharedValidator::OnThrowRef(const Location& loc) {
+ Result result = CheckInstr(Opcode::ThrowRef, loc);
+ result |= typechecker_.OnThrowRef();
+ return result;
+}
+
Result SharedValidator::OnTry(const Location& loc, Type sig_type) {
Result result = CheckInstr(Opcode::Try, loc);
TypeVector param_types, result_types;
@@ -1228,6 +1234,40 @@ Result SharedValidator::OnTry(const Location& loc, Type sig_type) {
return result;
}
+Result SharedValidator::BeginTryTable(const Location& loc, Type sig_type) {
+ Result result = CheckInstr(Opcode::TryTable, loc);
+ TypeVector param_types, result_types;
+ result |= CheckBlockSignature(loc, Opcode::TryTable, sig_type, &param_types,
+ &result_types);
+ result |= typechecker_.BeginTryTable(param_types);
+ return result;
+}
+
+Result SharedValidator::OnTryTableCatch(const Location& loc,
+ const TableCatch& catch_) {
+ Result result = Result::Ok;
+ TagType tag_type;
+ expr_loc_ = loc;
+ if (!catch_.IsCatchAll()) {
+ result |= CheckTagIndex(catch_.tag, &tag_type);
+ }
+ if (catch_.IsRef()) {
+ tag_type.params.push_back(Type::ExnRef);
+ }
+ result |=
+ typechecker_.OnTryTableCatch(tag_type.params, catch_.target.index());
+ return result;
+}
+
+Result SharedValidator::EndTryTable(const Location& loc, Type sig_type) {
+ Result result = CheckInstr(Opcode::TryTable, loc);
+ TypeVector param_types, result_types;
+ result |= CheckBlockSignature(loc, Opcode::TryTable, sig_type, &param_types,
+ &result_types);
+ result |= typechecker_.EndTryTable(param_types, result_types);
+ return result;
+}
+
Result SharedValidator::OnUnary(const Location& loc, Opcode opcode) {
Result result = CheckInstr(opcode, loc);
result |= typechecker_.OnUnary(opcode);
diff --git a/src/type-checker.cc b/src/type-checker.cc
index 8d6c3a11..96e4153c 100644
--- a/src/type-checker.cc
+++ b/src/type-checker.cc
@@ -644,7 +644,8 @@ Result TypeChecker::OnEnd() {
Result result = Result::Ok;
static const char* s_label_type_name[] = {
"function", "initializer expression", "block", "loop",
- "if", "`if false` branch", "try", "try catch"};
+ "if", "`if false` branch", "try", "try table",
+ "try catch"};
WABT_STATIC_ASSERT(WABT_ARRAY_SIZE(s_label_type_name) == kLabelTypeCount);
Label* label;
CHECK_RESULT(TopLabel(&label));
@@ -835,6 +836,13 @@ Result TypeChecker::OnThrow(const TypeVector& sig) {
return result;
}
+Result TypeChecker::OnThrowRef() {
+ Result result = Result::Ok;
+ result |= PopAndCheck1Type(Type::ExnRef, "throw_ref");
+ CHECK_RESULT(SetUnreachable());
+ return result;
+}
+
Result TypeChecker::OnReturn() {
Result result = Result::Ok;
Label* func_label;
@@ -882,6 +890,31 @@ Result TypeChecker::OnTry(const TypeVector& param_types,
return result;
}
+Result TypeChecker::BeginTryTable(const TypeVector& param_types) {
+ Result result = PopAndCheckSignature(param_types, "try_table");
+ return result;
+}
+
+Result TypeChecker::OnTryTableCatch(const TypeVector& sig, Index depth) {
+ Result result = Result::Ok;
+ Label* label;
+ CHECK_RESULT(GetLabel(depth, &label));
+ TypeVector& label_sig = label->br_types();
+ result |= CheckTypes(label_sig, sig);
+ if (Failed(result)) {
+ PrintError("catch signature doesn't match target: expected %s, got %s",
+ TypesToString(sig).c_str(), TypesToString(label_sig).c_str());
+ }
+ return result;
+}
+
+Result TypeChecker::EndTryTable(const TypeVector& param_types,
+ const TypeVector& result_types) {
+ PushLabel(LabelType::TryTable, param_types, result_types);
+ PushTypes(param_types);
+ return Result::Ok;
+}
+
Result TypeChecker::OnUnary(Opcode opcode) {
return CheckOpcode1(opcode);
}
diff --git a/src/validator.cc b/src/validator.cc
index 71c78411..8ccfa407 100644
--- a/src/validator.cc
+++ b/src/validator.cc
@@ -147,7 +147,10 @@ class Validator : public ExprVisitor::Delegate {
Result OnCatchExpr(TryExpr*, Catch*) override;
Result OnDelegateExpr(TryExpr*) override;
Result EndTryExpr(TryExpr*) override;
+ Result BeginTryTableExpr(TryTableExpr*) override;
+ Result EndTryTableExpr(TryTableExpr*) override;
Result OnThrowExpr(ThrowExpr*) override;
+ Result OnThrowRefExpr(ThrowRefExpr*) override;
Result OnRethrowExpr(RethrowExpr*) override;
Result OnAtomicWaitExpr(AtomicWaitExpr*) override;
Result OnAtomicFenceExpr(AtomicFenceExpr*) override;
@@ -564,11 +567,32 @@ Result Validator::EndTryExpr(TryExpr* expr) {
return Result::Ok;
}
+Result Validator::BeginTryTableExpr(TryTableExpr* expr) {
+ result_ |=
+ validator_.BeginTryTable(expr->loc, GetDeclarationType(expr->block.decl));
+ for (const TableCatch& catch_ : expr->catches) {
+ result_ |= validator_.OnTryTableCatch(expr->loc, catch_);
+ }
+ result_ |=
+ validator_.EndTryTable(expr->loc, GetDeclarationType(expr->block.decl));
+ return Result::Ok;
+}
+
+Result Validator::EndTryTableExpr(TryTableExpr* expr) {
+ result_ |= validator_.OnEnd(expr->block.end_loc);
+ return Result::Ok;
+}
+
Result Validator::OnThrowExpr(ThrowExpr* expr) {
result_ |= validator_.OnThrow(expr->loc, expr->var);
return Result::Ok;
}
+Result Validator::OnThrowRefExpr(ThrowRefExpr* expr) {
+ result_ |= validator_.OnThrowRef(expr->loc);
+ return Result::Ok;
+}
+
Result Validator::OnRethrowExpr(RethrowExpr* expr) {
result_ |= validator_.OnRethrow(expr->loc, expr->var);
return Result::Ok;
diff --git a/src/wast-parser.cc b/src/wast-parser.cc
index 0868a217..a1dc32f3 100644
--- a/src/wast-parser.cc
+++ b/src/wast-parser.cc
@@ -191,6 +191,7 @@ bool IsPlainInstr(TokenType token_type) {
case TokenType::TableSize:
case TokenType::TableFill:
case TokenType::Throw:
+ case TokenType::ThrowRef:
case TokenType::Rethrow:
case TokenType::RefFunc:
case TokenType::RefNull:
@@ -219,6 +220,7 @@ bool IsBlockInstr(TokenType token_type) {
case TokenType::Loop:
case TokenType::If:
case TokenType::Try:
+ case TokenType::TryTable:
return true;
default:
return false;
@@ -245,6 +247,12 @@ bool IsCatch(TokenType token_type) {
return token_type == TokenType::Catch || token_type == TokenType::CatchAll;
}
+bool IsTryTableCatch(TokenTypePair pair) {
+ return pair[0] == TokenType::Lpar &&
+ (pair[1] == TokenType::Catch || pair[1] == TokenType::CatchAll ||
+ pair[1] == TokenType::CatchRef || pair[1] == TokenType::CatchAllRef);
+}
+
bool IsModuleField(TokenTypePair pair) {
if (pair[0] != TokenType::Lpar) {
return false;
@@ -913,7 +921,7 @@ Result WastParser::ParseValueType(Var* out_type) {
if (!is_value_type && !is_ref_type) {
return ErrorExpected(
- {"i32", "i64", "f32", "f64", "v128", "externref", "funcref"});
+ {"i32", "i64", "f32", "f64", "v128", "externref", "exnref", "funcref"});
}
if (is_ref_type) {
@@ -1001,7 +1009,7 @@ Result WastParser::ParseRefKind(Type* out_type) {
Result WastParser::ParseRefType(Type* out_type) {
WABT_TRACE(ParseRefType);
if (!PeekMatch(TokenType::ValueType)) {
- return ErrorExpected({"funcref", "externref"});
+ return ErrorExpected({"funcref", "externref", "exnref"});
}
Token token = Consume();
@@ -2513,6 +2521,11 @@ Result WastParser::ParsePlainInstr(std::unique_ptr<Expr>* out_expr) {
CHECK_RESULT(ParsePlainInstrVar<ThrowExpr>(loc, out_expr));
break;
+ case TokenType::ThrowRef:
+ ErrorUnlessOpcodeEnabled(Consume());
+ out_expr->reset(new ThrowRefExpr(loc));
+ break;
+
case TokenType::Rethrow:
ErrorUnlessOpcodeEnabled(Consume());
CHECK_RESULT(ParsePlainInstrVar<RethrowExpr>(loc, out_expr));
@@ -3035,6 +3048,19 @@ Result WastParser::ParseBlockInstr(std::unique_ptr<Expr>* out_expr) {
break;
}
+ case TokenType::TryTable: {
+ ErrorUnlessOpcodeEnabled(Consume());
+ auto expr = std::make_unique<TryTableExpr>(loc);
+ CHECK_RESULT(ParseLabelOpt(&expr->block.label));
+ CHECK_RESULT(ParseBlockDeclaration(&expr->block.decl));
+ CHECK_RESULT(ParseTryTableCatches(&expr->catches));
+ CHECK_RESULT(ParseInstrList(&expr->block.exprs));
+ EXPECT(End);
+ CHECK_RESULT(ParseEndLabelOpt(expr->block.label));
+ *out_expr = std::move(expr);
+ break;
+ }
+
default:
assert(
!"ParseBlockInstr should only be called when IsBlockInstr() is true");
@@ -3212,6 +3238,19 @@ Result WastParser::ParseExpr(ExprList* exprs) {
break;
}
+ case TokenType::TryTable: {
+ Consume();
+ ErrorUnlessOpcodeEnabled(Consume());
+ auto expr = std::make_unique<TryTableExpr>(loc);
+ CHECK_RESULT(ParseLabelOpt(&expr->block.label));
+ CHECK_RESULT(ParseBlockDeclaration(&expr->block.decl));
+ CHECK_RESULT(ParseTryTableCatches(&expr->catches));
+ CHECK_RESULT(ParseInstrList(&expr->block.exprs));
+ expr->block.end_loc = GetLocation();
+ exprs->push_back(std::move(expr));
+ break;
+ }
+
default:
assert(!"ParseExpr should only be called when IsExpr() is true");
return Result::Error;
@@ -3279,6 +3318,40 @@ Result WastParser::ParseCatchExprList(CatchVector* catches) {
return Result::Ok;
}
+Result WastParser::ParseTryTableCatches(TryTableVector* catches) {
+ WABT_TRACE(ParseTryTableCatches);
+
+ while (IsTryTableCatch(PeekPair())) {
+ Consume();
+ TableCatch catch_(GetLocation());
+ auto token = Consume();
+ switch (token.token_type()) {
+ case TokenType::Catch:
+ catch_.kind = CatchKind::Catch;
+ break;
+ case TokenType::CatchRef:
+ catch_.kind = CatchKind::CatchRef;
+ break;
+ case TokenType::CatchAll:
+ catch_.kind = CatchKind::CatchAll;
+ break;
+ case TokenType::CatchAllRef:
+ catch_.kind = CatchKind::CatchAllRef;
+ break;
+ default:
+ WABT_UNREACHABLE;
+ }
+ if (catch_.kind == CatchKind::Catch || catch_.kind == CatchKind::CatchRef) {
+ CHECK_RESULT(ParseVar(&catch_.tag));
+ }
+ CHECK_RESULT(ParseVar(&catch_.target));
+ EXPECT(Rpar);
+ catches->push_back(std::move(catch_));
+ }
+
+ return Result::Ok;
+}
+
Result WastParser::ParseGlobalType(Global* global) {
WABT_TRACE(ParseGlobalType);
if (MatchLpar(TokenType::Mut)) {
diff --git a/src/wat-writer.cc b/src/wat-writer.cc
index a013717a..f19e3c3c 100644
--- a/src/wat-writer.cc
+++ b/src/wat-writer.cc
@@ -600,10 +600,13 @@ class WatWriter::ExprVisitorDelegate : public ExprVisitor::Delegate {
Result OnUnaryExpr(UnaryExpr*) override;
Result OnUnreachableExpr(UnreachableExpr*) override;
Result BeginTryExpr(TryExpr*) override;
+ Result BeginTryTableExpr(TryTableExpr*) override;
+ Result EndTryTableExpr(TryTableExpr*) override;
Result OnCatchExpr(TryExpr*, Catch*) override;
Result OnDelegateExpr(TryExpr*) override;
Result EndTryExpr(TryExpr*) override;
Result OnThrowExpr(ThrowExpr*) override;
+ Result OnThrowRefExpr(ThrowRefExpr*) override;
Result OnRethrowExpr(RethrowExpr*) override;
Result OnAtomicWaitExpr(AtomicWaitExpr*) override;
Result OnAtomicFenceExpr(AtomicFenceExpr*) override;
@@ -950,6 +953,52 @@ Result WatWriter::ExprVisitorDelegate::OnUnreachableExpr(
return Result::Ok;
}
+Result WatWriter::ExprVisitorDelegate::BeginTryTableExpr(TryTableExpr* expr) {
+ // copied from WriteBeginBlock, try_table needs to push label *after*
+ // writing catches
+ writer_->WritePutsSpace(Opcode::TryTable_Opcode.GetName());
+ bool has_label = !expr->block.label.empty();
+ if (has_label) {
+ writer_->WriteString(expr->block.label, NextChar::Space);
+ }
+ writer_->WriteTypes(expr->block.decl.sig.param_types, "param");
+ writer_->WriteTypes(expr->block.decl.sig.result_types, "result");
+ if (!has_label) {
+ writer_->Writef(" ;; label = @%" PRIindex, writer_->GetLabelStackSize());
+ }
+ writer_->WriteNewline(FORCE_NEWLINE);
+ writer_->Indent();
+ for (const auto& catch_ : expr->catches) {
+ writer_->WritePuts("(", NextChar::None);
+ switch (catch_.kind) {
+ case CatchKind::Catch:
+ writer_->WritePutsSpace("catch");
+ break;
+ case CatchKind::CatchRef:
+ writer_->WritePutsSpace("catch_ref");
+ break;
+ case CatchKind::CatchAll:
+ writer_->WritePutsSpace("catch_all");
+ break;
+ case CatchKind::CatchAllRef:
+ writer_->WritePutsSpace("catch_all_ref");
+ break;
+ }
+ if (catch_.kind == CatchKind::Catch || catch_.kind == CatchKind::CatchRef) {
+ writer_->WriteVar(catch_.tag, NextChar::Space);
+ }
+ writer_->WriteBrVar(catch_.target, NextChar::None);
+ writer_->WritePuts(")", NextChar::Newline);
+ }
+ writer_->BeginBlock(LabelType::TryTable, expr->block);
+ return Result::Ok;
+}
+
+Result WatWriter::ExprVisitorDelegate::EndTryTableExpr(TryTableExpr* expr) {
+ writer_->WriteEndBlock();
+ return Result::Ok;
+}
+
Result WatWriter::ExprVisitorDelegate::BeginTryExpr(TryExpr* expr) {
writer_->WriteBeginBlock(LabelType::Try, expr->block,
Opcode::Try_Opcode.GetName());
@@ -989,6 +1038,11 @@ Result WatWriter::ExprVisitorDelegate::OnThrowExpr(ThrowExpr* expr) {
return Result::Ok;
}
+Result WatWriter::ExprVisitorDelegate::OnThrowRefExpr(ThrowRefExpr* expr) {
+ writer_->WritePutsNewline(Opcode::ThrowRef_Opcode.GetName());
+ return Result::Ok;
+}
+
Result WatWriter::ExprVisitorDelegate::OnRethrowExpr(RethrowExpr* expr) {
writer_->WritePutsSpace(Opcode::Rethrow_Opcode.GetName());
writer_->WriteBrVar(expr->var, NextChar::Newline);
@@ -1260,6 +1314,58 @@ void WatWriter::FlushExprTree(const ExprTree& expr_tree) {
break;
}
+ case ExprType::TryTable: {
+ auto try_table_expr = cast<TryTableExpr>(expr_tree.expr);
+
+ WritePuts("(", NextChar::None);
+ // copied from WriteBeginBlock, try_table needs to push label *after*
+ // writing catches
+ WritePutsSpace(Opcode::TryTable_Opcode.GetName());
+ bool has_label = !try_table_expr->block.label.empty();
+ if (has_label) {
+ WriteString(try_table_expr->block.label, NextChar::Space);
+ }
+ WriteTypes(try_table_expr->block.decl.sig.param_types, "param");
+ WriteTypes(try_table_expr->block.decl.sig.result_types, "result");
+ if (!has_label) {
+ Writef(" ;; label = @%" PRIindex, GetLabelStackSize());
+ }
+ WriteNewline(FORCE_NEWLINE);
+ Indent();
+
+ for (const auto& catch_ : try_table_expr->catches) {
+ WritePuts("(", NextChar::None);
+ switch (catch_.kind) {
+ case CatchKind::Catch:
+ WritePutsSpace("catch");
+ break;
+ case CatchKind::CatchRef:
+ WritePutsSpace("catch_ref");
+ break;
+ case CatchKind::CatchAll:
+ WritePutsSpace("catch_all");
+ break;
+ case CatchKind::CatchAllRef:
+ WritePutsSpace("catch_all_ref");
+ break;
+ }
+ if (catch_.kind == CatchKind::Catch ||
+ catch_.kind == CatchKind::CatchRef) {
+ WriteVar(catch_.tag, NextChar::Space);
+ }
+ WriteBrVar(catch_.target, NextChar::None);
+ WritePuts(")", NextChar::Newline);
+ }
+
+ BeginBlock(LabelType::TryTable, try_table_expr->block);
+
+ WriteFoldedExprList(try_table_expr->block.exprs);
+ FlushExprTreeStack();
+ WriteCloseNewline();
+ EndBlock();
+ break;
+ }
+
default: {
WritePuts("(", NextChar::None);
WriteExpr(expr_tree.expr);
diff --git a/test/parse/expr/try-table.txt b/test/parse/expr/try-table.txt
new file mode 100644
index 00000000..ee5b4b2c
--- /dev/null
+++ b/test/parse/expr/try-table.txt
@@ -0,0 +1,21 @@
+;;; TOOL: wat2wasm
+;;; ARGS: --enable-exceptions
+(module
+ (tag $e1 (param i32))
+ (tag $e2 (param i32 i32))
+
+ (func $func
+ block $a
+ block $b (result i32)
+ block $c (result i32 i32)
+ try_table (catch $e1 $b) (catch $e2 $c) (catch_all $a)
+ nop
+ end
+ i32.const 0
+ i32.const 0
+ end
+ drop
+ end
+ drop
+ end)
+)
diff --git a/test/parse/func/bad-local-binding-no-type.txt b/test/parse/func/bad-local-binding-no-type.txt
index 599a20cd..611833ec 100644
--- a/test/parse/func/bad-local-binding-no-type.txt
+++ b/test/parse/func/bad-local-binding-no-type.txt
@@ -2,7 +2,7 @@
;;; ERROR: 1
(module (func (local $n)))
(;; STDERR ;;;
-out/test/parse/func/bad-local-binding-no-type.txt:3:24: error: unexpected token ")", expected i32, i64, f32, f64, v128, externref or funcref.
+out/test/parse/func/bad-local-binding-no-type.txt:3:24: error: unexpected token ")", expected i32, i64, f32, f64, v128, externref, exnref or funcref.
(module (func (local $n)))
^
;;; STDERR ;;)
diff --git a/test/parse/func/bad-local-binding.txt b/test/parse/func/bad-local-binding.txt
index 8e99be47..3f6dc6d4 100644
--- a/test/parse/func/bad-local-binding.txt
+++ b/test/parse/func/bad-local-binding.txt
@@ -2,7 +2,7 @@
;;; ERROR: 1
(module (func (local $foo $bar)))
(;; STDERR ;;;
-out/test/parse/func/bad-local-binding.txt:3:27: error: unexpected token "$bar", expected i32, i64, f32, f64, v128, externref or funcref.
+out/test/parse/func/bad-local-binding.txt:3:27: error: unexpected token "$bar", expected i32, i64, f32, f64, v128, externref, exnref or funcref.
(module (func (local $foo $bar)))
^^^^
;;; STDERR ;;)
diff --git a/test/parse/func/bad-param-binding.txt b/test/parse/func/bad-param-binding.txt
index f4d830e2..db1613a8 100644
--- a/test/parse/func/bad-param-binding.txt
+++ b/test/parse/func/bad-param-binding.txt
@@ -2,7 +2,7 @@
;;; ERROR: 1
(module (func (param $bar $baz)))
(;; STDERR ;;;
-out/test/parse/func/bad-param-binding.txt:3:27: error: unexpected token "$baz", expected i32, i64, f32, f64, v128, externref or funcref.
+out/test/parse/func/bad-param-binding.txt:3:27: error: unexpected token "$baz", expected i32, i64, f32, f64, v128, externref, exnref or funcref.
(module (func (param $bar $baz)))
^^^^
;;; STDERR ;;)
diff --git a/test/parse/module/bad-array-no-fields.txt b/test/parse/module/bad-array-no-fields.txt
index 90a5f222..8b60fd7b 100644
--- a/test/parse/module/bad-array-no-fields.txt
+++ b/test/parse/module/bad-array-no-fields.txt
@@ -3,7 +3,7 @@
;;; ERROR: 1
(type (array))
(;; STDERR ;;;
-out/test/parse/module/bad-array-no-fields.txt:4:13: error: unexpected token ")", expected i32, i64, f32, f64, v128, externref or funcref.
+out/test/parse/module/bad-array-no-fields.txt:4:13: error: unexpected token ")", expected i32, i64, f32, f64, v128, externref, exnref or funcref.
(type (array))
^
;;; STDERR ;;)
diff --git a/test/roundtrip/fold-try-table.txt b/test/roundtrip/fold-try-table.txt
new file mode 100644
index 00000000..9b15234b
--- /dev/null
+++ b/test/roundtrip/fold-try-table.txt
@@ -0,0 +1,35 @@
+;;; TOOL: run-roundtrip
+;;; ARGS: --stdout --fold-exprs --enable-exceptions --debug-names
+(module
+ (func (result i32)
+ try_table (result i32)
+ i32.const 6
+ end
+ drop
+ block
+ try_table (result i32) (catch_all 0)
+ nop
+ i32.const 7
+ br 2
+ end
+ drop
+ end
+ i32.const 8
+ )
+)
+(;; STDOUT ;;;
+(module
+ (type (;0;) (func (result i32)))
+ (func (;0;) (type 0) (result i32)
+ (drop
+ (try_table (result i32) ;; label = @1
+ (i32.const 6)))
+ (block ;; label = @1
+ (drop
+ (try_table (result i32) ;; label = @2
+ (catch_all 0 (;@1;))
+ (nop)
+ (br 2 (;@0;)
+ (i32.const 7)))))
+ (i32.const 8)))
+;;; STDOUT ;;)
diff --git a/test/roundtrip/fold-unreachable.txt b/test/roundtrip/fold-unreachable.txt
index 69988f1f..3ed77bcd 100644
--- a/test/roundtrip/fold-unreachable.txt
+++ b/test/roundtrip/fold-unreachable.txt
@@ -1,5 +1,5 @@
;;; TOOL: run-roundtrip
-;;; ARGS: --stdout --fold-exprs
+;;; ARGS: --stdout --enable-exceptions --fold-exprs
(module
(func (result i32)
i32.const 1
@@ -26,7 +26,13 @@
(func (result i32)
i32.const 0
return
- i32.eqz))
+ i32.eqz)
+
+ (func
+ ref.null exn
+ throw_ref
+ drop
+ ))
(;; STDOUT ;;;
(module
(type (;0;) (func (result i32)))
@@ -50,5 +56,9 @@
(func (;3;) (type 0) (result i32)
(i32.eqz
(return
- (i32.const 0)))))
+ (i32.const 0))))
+ (func (;4;) (type 1)
+ (drop
+ (throw_ref
+ (ref.null exn)))))
;;; STDOUT ;;)
diff --git a/test/roundtrip/try-table.txt b/test/roundtrip/try-table.txt
new file mode 100644
index 00000000..62e09866
--- /dev/null
+++ b/test/roundtrip/try-table.txt
@@ -0,0 +1,38 @@
+;;; TOOL: run-roundtrip
+;;; ARGS: --stdout --enable-exceptions --debug-names
+(module
+ (func (result i32)
+ try_table (result i32)
+ i32.const 6
+ end
+ drop
+ block
+ try_table (result i32) (catch_all 0)
+ nop
+ i32.const 7
+ br 2
+ end
+ drop
+ end
+ i32.const 8
+ )
+)
+(;; STDOUT ;;;
+(module
+ (type (;0;) (func (result i32)))
+ (func (;0;) (type 0) (result i32)
+ try_table (result i32) ;; label = @1
+ i32.const 6
+ end
+ drop
+ block ;; label = @1
+ try_table (result i32) ;; label = @2
+ (catch_all 0 (;@1;))
+ nop
+ i32.const 7
+ br 2 (;@0;)
+ end
+ drop
+ end
+ i32.const 8))
+;;; STDOUT ;;)
diff --git a/test/spec/obsolete-keywords.txt b/test/spec/obsolete-keywords.txt
index e102ff46..a536a505 100644
--- a/test/spec/obsolete-keywords.txt
+++ b/test/spec/obsolete-keywords.txt
@@ -28,7 +28,7 @@ out/test/spec/obsolete-keywords.wast:34: assert_malformed passed:
(func (local $i i32) (drop (tee_local $i (i32.const 0))))
^
out/test/spec/obsolete-keywords.wast:41: assert_malformed passed:
- out/test/spec/obsolete-keywords/obsolete-keywords.5.wat:1:12: error: unexpected token "anyfunc", expected i32, i64, f32, f64, v128, externref or funcref.
+ out/test/spec/obsolete-keywords/obsolete-keywords.5.wat:1:12: error: unexpected token "anyfunc", expected i32, i64, f32, f64, v128, externref, exnref or funcref.
(global $g anyfunc (ref.null func))
^^^^^^^
out/test/spec/obsolete-keywords.wast:48: assert_malformed passed:
diff --git a/test/update-spec-tests.py b/test/update-spec-tests.py
index 0a600c6c..f33cff08 100755
--- a/test/update-spec-tests.py
+++ b/test/update-spec-tests.py
@@ -106,7 +106,6 @@ def main(args):
'function-references',
'threads',
'annotations',
- 'exception-handling',
])
# sanity check to verify that all flags are valid