summaryrefslogtreecommitdiff
path: root/src/passes/FuncCastEmulation.cpp
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2019-07-19 16:01:15 -0700
committerGitHub <noreply@github.com>2019-07-19 16:01:15 -0700
commit88ef839433ac0cf58c2a29f369d0268a22b5ae0e (patch)
tree13488bb2eda5657d7cb440cacacab4369b7fda1e /src/passes/FuncCastEmulation.cpp
parent7bc5f1891f77e53f5a4e6905e02e80c680c728c3 (diff)
downloadbinaryen-88ef839433ac0cf58c2a29f369d0268a22b5ae0e.tar.gz
binaryen-88ef839433ac0cf58c2a29f369d0268a22b5ae0e.tar.bz2
binaryen-88ef839433ac0cf58c2a29f369d0268a22b5ae0e.zip
Simpify PassRunner.add() and automatically parallelize parallel functions (#2242)
Main change here is in pass.h, everything else is changes to work with the new API. The add("name") remains as before, while the weird variadic add(..) which constructed the pass now just gets a std::unique_ptr of a pass. This also makes the memory management internally fully automatic. And it makes it trivial to parallelize WalkerPass::run on parallel passes. As a benefit, this allows removing a lot of code since in many cases there is no need to create a new pass runner, and running a pass can be just a single line.
Diffstat (limited to 'src/passes/FuncCastEmulation.cpp')
-rw-r--r--src/passes/FuncCastEmulation.cpp5
1 files changed, 1 insertions, 4 deletions
diff --git a/src/passes/FuncCastEmulation.cpp b/src/passes/FuncCastEmulation.cpp
index b4e600b31..9d6923703 100644
--- a/src/passes/FuncCastEmulation.cpp
+++ b/src/passes/FuncCastEmulation.cpp
@@ -185,10 +185,7 @@ struct FuncCastEmulation : public Pass {
}
}
// update call_indirects
- PassRunner subRunner(module, runner->options);
- subRunner.setIsNested(true);
- subRunner.add<ParallelFuncCastEmulation>(ABIType);
- subRunner.run();
+ ParallelFuncCastEmulation(ABIType).run(runner, module);
}
private: