diff options
author | Alon Zakai <azakai@google.com> | 2022-12-15 14:02:53 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-12-15 22:02:53 +0000 |
commit | a9ebf0dd842dc5b239a233177cfc9ccbd675fba7 (patch) | |
tree | aadf98032ac8c13bc1d466492072961907bb3ab9 /src/tools/wasm-opt.cpp | |
parent | bead42c46d48e4c5584f035f7a805911dc59ae35 (diff) | |
download | binaryen-a9ebf0dd842dc5b239a233177cfc9ccbd675fba7.tar.gz binaryen-a9ebf0dd842dc5b239a233177cfc9ccbd675fba7.tar.bz2 binaryen-a9ebf0dd842dc5b239a233177cfc9ccbd675fba7.zip |
In --debug mode, print partial wasm data that was read (#5356)
If wasm-opt or wasm-dis are given an invalid binary, after the error
message we can also print out the wasm we did manage to read. That
includes global stuff like imports and also all the functions up until
there. This can help debugging in some situations.
Only do this when --debug is passed as it can be very verbose and
in general users might not want it.
This is technically easy to do, it turns out, since we already use a
thrown exception on an error in parsing, and we fill up the wasm as
we go, so it just contains what we've read so far, and we can just
print it.
Fixes #5344
Also switch an existing test's comments to ;; from # which was
noticed here.
Diffstat (limited to 'src/tools/wasm-opt.cpp')
-rw-r--r-- | src/tools/wasm-opt.cpp | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/tools/wasm-opt.cpp b/src/tools/wasm-opt.cpp index effd085bc..8f958f164 100644 --- a/src/tools/wasm-opt.cpp +++ b/src/tools/wasm-opt.cpp @@ -279,7 +279,12 @@ int main(int argc, const char* argv[]) { } catch (ParseException& p) { p.dump(std::cerr); std::cerr << '\n'; - Fatal() << "error parsing wasm"; + if (options.debug) { + Fatal() << "error parsing wasm. here is what we read up to the error:\n" + << wasm; + } else { + Fatal() << "error parsing wasm (try --debug for more info)"; + } } catch (MapParseException& p) { p.dump(std::cerr); std::cerr << '\n'; |