summaryrefslogtreecommitdiff
path: root/src/passes/Print.cpp
diff options
context:
space:
mode:
authorDaniel Wirtz <dcode@dcode.io>2020-09-24 12:02:09 +0200
committerGitHub <noreply@github.com>2020-09-24 12:02:09 +0200
commite9e1b2ff00aeb05aaeb57af3811add267dc25323 (patch)
tree4e19032813858b2e650f0cda46fe9fa227aa0a7f /src/passes/Print.cpp
parenta42423fafa8cf731c69303ddc0acbe80c890e0ab (diff)
downloadbinaryen-e9e1b2ff00aeb05aaeb57af3811add267dc25323.tar.gz
binaryen-e9e1b2ff00aeb05aaeb57af3811add267dc25323.tar.bz2
binaryen-e9e1b2ff00aeb05aaeb57af3811add267dc25323.zip
GC: Add i31 instructions (#3154)
Adds the `i31.new` and `i31.get_s/u` instructions for creating and working with `i31ref` typed values. Does not include fuzzer integration just yet because the fuzzer expects that trivial values it creates are suitable in global initializers, which is not the case for trivial `i31ref` expressions.
Diffstat (limited to 'src/passes/Print.cpp')
-rw-r--r--src/passes/Print.cpp18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/passes/Print.cpp b/src/passes/Print.cpp
index 27c3e327c..ac115edc3 100644
--- a/src/passes/Print.cpp
+++ b/src/passes/Print.cpp
@@ -1474,6 +1474,10 @@ struct PrintExpressionContents
printMedium(o, "tuple.extract ");
o << curr->index;
}
+ void visitI31New(I31New* curr) { printMedium(o, "i31.new"); }
+ void visitI31Get(I31Get* curr) {
+ printMedium(o, curr->signed_ ? "i31.get_s" : "i31.get_u");
+ }
};
// Prints an expression in s-expr format, including both the
@@ -2063,6 +2067,20 @@ struct PrintSExpression : public OverriddenVisitor<PrintSExpression> {
printFullLine(curr->tuple);
decIndent();
}
+ void visitI31New(I31New* curr) {
+ o << '(';
+ PrintExpressionContents(currFunction, o).visit(curr);
+ incIndent();
+ printFullLine(curr->value);
+ decIndent();
+ }
+ void visitI31Get(I31Get* curr) {
+ o << '(';
+ PrintExpressionContents(currFunction, o).visit(curr);
+ incIndent();
+ printFullLine(curr->i31);
+ decIndent();
+ }
// Module-level visitors
void handleSignature(Signature curr, Name* funcName = nullptr) {
o << "(func";