diff options
author | Alon Zakai <alonzakai@gmail.com> | 2016-04-07 21:28:26 -0700 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2016-04-07 21:28:26 -0700 |
commit | d30b98d47697daa167333db66ac0fe3d8a693eae (patch) | |
tree | 75ad13773b0422d8f42b184ab8544d69384ef7da /src/passes/Vacuum.cpp | |
parent | c0f0be986d9009a05a3bbaf42c841b863d9b83c1 (diff) | |
parent | 540056ededd811b859e0cf4db9782d8cb7711215 (diff) | |
download | binaryen-d30b98d47697daa167333db66ac0fe3d8a693eae.tar.gz binaryen-d30b98d47697daa167333db66ac0fe3d8a693eae.tar.bz2 binaryen-d30b98d47697daa167333db66ac0fe3d8a693eae.zip |
Merge pull request #319 from WebAssembly/traversal
Refactor traversal into its own header
Diffstat (limited to 'src/passes/Vacuum.cpp')
-rw-r--r-- | src/passes/Vacuum.cpp | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/src/passes/Vacuum.cpp b/src/passes/Vacuum.cpp new file mode 100644 index 000000000..f9704ed8d --- /dev/null +++ b/src/passes/Vacuum.cpp @@ -0,0 +1,48 @@ +/* + * Copyright 2016 WebAssembly Community Group participants + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +// +// Removes obviously unneeded code +// + +#include <wasm.h> +#include <pass.h> + +namespace wasm { + +struct Vacuum : public WalkerPass<WasmWalker<Vacuum>> { + void visitBlock(Block *curr) { + // compress out nops + int skip = 0; + auto& list = curr->list; + size_t size = list.size(); + for (size_t z = 0; z < size; z++) { + if (list[z]->is<Nop>()) { + skip++; + } else if (skip > 0) { + list[z - skip] = list[z]; + } + } + if (skip > 0) { + list.resize(size - skip); + } + } +}; + +static RegisterPass<Vacuum> registerPass("vacuum", "removes obviously unneeded code"); + +} // namespace wasm + |