summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2016-08-07 12:04:25 -0700
committerAlon Zakai <alonzakai@gmail.com>2016-09-07 09:54:56 -0700
commitabb498167e4c8178a5cb6cd22dcf106959eaa7d4 (patch)
tree21d5eeac3123a81da0f3804e8630fd0a0648d0aa /src
parente9d057d097f3875be50bba44d874e66ad71e40f2 (diff)
downloadbinaryen-abb498167e4c8178a5cb6cd22dcf106959eaa7d4.tar.gz
binaryen-abb498167e4c8178a5cb6cd22dcf106959eaa7d4.tar.bz2
binaryen-abb498167e4c8178a5cb6cd22dcf106959eaa7d4.zip
don't depend on order of operations in calls, it varies by compiler
Diffstat (limited to 'src')
-rw-r--r--src/asm2wasm.h4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/asm2wasm.h b/src/asm2wasm.h
index 2d0d1300e..4d2ddb0cd 100644
--- a/src/asm2wasm.h
+++ b/src/asm2wasm.h
@@ -1277,7 +1277,9 @@ Function* Asm2WasmBuilder::processFunction(Ref ast) {
}
abort_on("bad unary", ast);
} else if (what == IF) {
- return builder.makeIf(process(ast[1]), process(ast[2]), !!ast[3] ? process(ast[3]) : nullptr);
+ auto* condition = process(ast[1]);
+ auto* ifTrue = process(ast[2]);
+ return builder.makeIf(condition, ifTrue, !!ast[3] ? process(ast[3]) : nullptr);
} else if (what == CALL) {
if (ast[1][0] == NAME) {
IString name = ast[1][1]->getIString();