summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2016-09-06 14:45:32 -0700
committerAlon Zakai <alonzakai@gmail.com>2016-09-07 18:41:22 -0700
commit92ec03790fb9c6a5c72002eb739e017178eabf3e (patch)
tree058887745a8553ff10c4cbb01d5e51e3dfcee044 /src
parent8f0726cc87494f6721baab55ec035fa3facae0e3 (diff)
downloadbinaryen-92ec03790fb9c6a5c72002eb739e017178eabf3e.tar.gz
binaryen-92ec03790fb9c6a5c72002eb739e017178eabf3e.tar.bz2
binaryen-92ec03790fb9c6a5c72002eb739e017178eabf3e.zip
add option to remove duplicate funcs by name
Diffstat (limited to 'src')
-rw-r--r--src/passes/DuplicateFunctionElimination.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/passes/DuplicateFunctionElimination.cpp b/src/passes/DuplicateFunctionElimination.cpp
index 2b8e69b54..cfe2d8565 100644
--- a/src/passes/DuplicateFunctionElimination.cpp
+++ b/src/passes/DuplicateFunctionElimination.cpp
@@ -102,7 +102,17 @@ struct DuplicateFunctionElimination : public Pass {
auto& group = pair.second;
if (group.size() == 1) continue;
// pick a base for each group, and try to replace everyone else to it. TODO: multiple bases per hash group, for collisions
+#if 0
+ // for comparison purposes, pick in a deterministic way based on the names
+ Function* base = nullptr;
+ for (auto* func : group) {
+ if (!base || strcmp(func->name.str, base->name.str) < 0) {
+ base = func;
+ }
+ }
+#else
Function* base = group[0];
+#endif
for (auto* func : group) {
if (func != base && equal(func, base)) {
replacements[func->name] = base->name;