summaryrefslogtreecommitdiff
path: root/src/wasm/wasm-binary.cpp
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2022-07-12 12:41:58 -0700
committerGitHub <noreply@github.com>2022-07-12 12:41:58 -0700
commit65875f3fdbf09c46aa63f54337662d404e4f1c40 (patch)
tree9af8ac774845862fba89635bbebdeafd1870af58 /src/wasm/wasm-binary.cpp
parentf6a2a71a8b7ec52e3e4a9b7fdb4d2231a0129149 (diff)
downloadbinaryen-65875f3fdbf09c46aa63f54337662d404e4f1c40.tar.gz
binaryen-65875f3fdbf09c46aa63f54337662d404e4f1c40.tar.bz2
binaryen-65875f3fdbf09c46aa63f54337662d404e4f1c40.zip
[Strings] string.as (#4797)
Diffstat (limited to 'src/wasm/wasm-binary.cpp')
-rw-r--r--src/wasm/wasm-binary.cpp19
1 files changed, 19 insertions, 0 deletions
diff --git a/src/wasm/wasm-binary.cpp b/src/wasm/wasm-binary.cpp
index 0ae17f47c..ee1f4929b 100644
--- a/src/wasm/wasm-binary.cpp
+++ b/src/wasm/wasm-binary.cpp
@@ -3936,6 +3936,9 @@ BinaryConsts::ASTNodes WasmBinaryBuilder::readExpression(Expression*& curr) {
if (maybeVisitStringEq(curr, opcode)) {
break;
}
+ if (maybeVisitStringAs(curr, opcode)) {
+ break;
+ }
if (opcode == BinaryConsts::RefIsFunc ||
opcode == BinaryConsts::RefIsData ||
opcode == BinaryConsts::RefIsI31) {
@@ -7249,6 +7252,22 @@ bool WasmBinaryBuilder::maybeVisitStringEq(Expression*& out, uint32_t code) {
return true;
}
+bool WasmBinaryBuilder::maybeVisitStringAs(Expression*& out, uint32_t code) {
+ StringAsOp op;
+ if (code == BinaryConsts::StringAsWTF8) {
+ op = StringAsWTF8;
+ } else if (code == BinaryConsts::StringAsWTF16) {
+ op = StringAsWTF16;
+ } else if (code == BinaryConsts::StringAsIter) {
+ op = StringAsIter;
+ } else {
+ return false;
+ }
+ auto* ref = popNonVoidExpression();
+ out = Builder(wasm).makeStringAs(op, ref);
+ return true;
+}
+
void WasmBinaryBuilder::visitRefAs(RefAs* curr, uint8_t code) {
BYN_TRACE("zz node: RefAs\n");
switch (code) {