diff options
Diffstat (limited to 'src/wasm/wasm-binary.cpp')
-rw-r--r-- | src/wasm/wasm-binary.cpp | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/src/wasm/wasm-binary.cpp b/src/wasm/wasm-binary.cpp index 12aa5f214..35bc468b1 100644 --- a/src/wasm/wasm-binary.cpp +++ b/src/wasm/wasm-binary.cpp @@ -3377,6 +3377,9 @@ BinaryConsts::ASTNodes WasmBinaryBuilder::readExpression(Expression*& curr) { case BinaryConsts::BrOnNull: maybeVisitBrOn(curr, code); break; + case BinaryConsts::BrOnNonNull: + maybeVisitBrOn(curr, code); + break; case BinaryConsts::Try: visitTryOrTryInBlock(curr); break; @@ -6333,24 +6336,39 @@ bool WasmBinaryBuilder::maybeVisitBrOn(Expression*& out, uint32_t code) { case BinaryConsts::BrOnNull: op = BrOnNull; break; + case BinaryConsts::BrOnNonNull: + op = BrOnNonNull; + break; case BinaryConsts::BrOnCast: op = BrOnCast; break; + case BinaryConsts::BrOnCastFail: + op = BrOnCastFail; + break; case BinaryConsts::BrOnFunc: op = BrOnFunc; break; + case BinaryConsts::BrOnNonFunc: + op = BrOnNonFunc; + break; case BinaryConsts::BrOnData: op = BrOnData; break; + case BinaryConsts::BrOnNonData: + op = BrOnNonData; + break; case BinaryConsts::BrOnI31: op = BrOnI31; break; + case BinaryConsts::BrOnNonI31: + op = BrOnNonI31; + break; default: return false; } auto name = getBreakTarget(getU32LEB()).name; Expression* rtt = nullptr; - if (op == BrOnCast) { + if (op == BrOnCast || op == BrOnCastFail) { rtt = popNonVoidExpression(); } auto* ref = popNonVoidExpression(); |