diff options
author | Alon Zakai <alonzakai@gmail.com> | 2016-08-07 12:04:25 -0700 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2016-09-07 09:54:56 -0700 |
commit | abb498167e4c8178a5cb6cd22dcf106959eaa7d4 (patch) | |
tree | 21d5eeac3123a81da0f3804e8630fd0a0648d0aa /src/asm2wasm.h | |
parent | e9d057d097f3875be50bba44d874e66ad71e40f2 (diff) | |
download | binaryen-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/asm2wasm.h')
-rw-r--r-- | src/asm2wasm.h | 4 |
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(); |