summaryrefslogtreecommitdiff
path: root/src/wasm-builder.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/wasm-builder.h')
-rw-r--r--src/wasm-builder.h10
1 files changed, 4 insertions, 6 deletions
diff --git a/src/wasm-builder.h b/src/wasm-builder.h
index bb739af89..fabaac22a 100644
--- a/src/wasm-builder.h
+++ b/src/wasm-builder.h
@@ -1040,9 +1040,8 @@ public:
iff->condition = makeUnary(EqZInt32, iff->condition);
}
- // returns a replacement with the precise same type, and with
- // minimal contents. as a replacement, this may reuse the
- // input node
+ // Returns a replacement with the precise same type, and with minimal contents
+ // as best we can. As a replacement, this may reuse the input node.
template<typename T> Expression* replaceWithIdenticalType(T* curr) {
if (curr->type.isTuple()) {
return makeConstantExpression(Literal::makeZeros(curr->type));
@@ -1050,13 +1049,12 @@ public:
if (curr->type.isNullable()) {
return ExpressionManipulator::refNull(curr, curr->type);
}
- if (curr->type.isFunction()) {
+ if (curr->type.isFunction() || !curr->type.isBasic()) {
// We can't do any better, keep the original.
return curr;
}
Literal value;
// TODO: reuse node conditionally when possible for literals
- TODO_SINGLE_COMPOUND(curr->type);
switch (curr->type.getBasic()) {
case Type::i32:
value = Literal(int32_t(0));
@@ -1085,7 +1083,7 @@ public:
case Type::i31ref:
return makeI31New(makeConst(0));
case Type::dataref:
- WASM_UNREACHABLE("TODO: dataref");
+ return curr;
case Type::none:
return ExpressionManipulator::nop(curr);
case Type::unreachable: