diff options
author | Alon Zakai <alonzakai@gmail.com> | 2016-09-06 14:45:32 -0700 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2016-09-07 18:41:22 -0700 |
commit | 92ec03790fb9c6a5c72002eb739e017178eabf3e (patch) | |
tree | 058887745a8553ff10c4cbb01d5e51e3dfcee044 /src | |
parent | 8f0726cc87494f6721baab55ec035fa3facae0e3 (diff) | |
download | binaryen-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.cpp | 10 |
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; |