summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/tools/wasm-strip.cc44
1 files changed, 26 insertions, 18 deletions
diff --git a/src/tools/wasm-strip.cc b/src/tools/wasm-strip.cc
index d80251f9..f7abd5ff 100644
--- a/src/tools/wasm-strip.cc
+++ b/src/tools/wasm-strip.cc
@@ -25,6 +25,7 @@
using namespace wabt;
static std::string s_filename;
+static std::string s_outfile;
static const char s_description[] =
R"( Remove sections of a WebAssembly binary file.
@@ -42,6 +43,8 @@ static void ParseOptions(int argc, char** argv) {
s_filename = argument;
ConvertBackslashToSlash(&s_filename);
});
+ parser.AddOption('o', "output", "FILE", "output wasm binary file",
+ [](const char* argument) { s_outfile = argument; });
parser.Parse(argc, argv);
}
@@ -86,25 +89,30 @@ int ProgramMain(int argc, char** argv) {
std::vector<uint8_t> file_data;
result = ReadFile(s_filename.c_str(), &file_data);
- if (Succeeded(result)) {
- Errors errors;
- Features features;
- features.EnableAll();
- const bool kReadDebugNames = false;
- const bool kStopOnFirstError = true;
- const bool kFailOnCustomSectionError = false;
- ReadBinaryOptions options(features, nullptr, kReadDebugNames,
- kStopOnFirstError, kFailOnCustomSectionError);
-
- BinaryReaderStrip reader(&errors);
- result = ReadBinary(file_data.data(), file_data.size(), &reader, options);
- FormatErrorsToFile(errors, Location::Type::Binary);
-
- if (Succeeded(result)) {
- result = reader.WriteToFile(s_filename);
- }
+ if (Failed(result)) {
+ return Result::Error;
+ }
+
+ Errors errors;
+ Features features;
+ features.EnableAll();
+ const bool kReadDebugNames = false;
+ const bool kStopOnFirstError = true;
+ const bool kFailOnCustomSectionError = false;
+ ReadBinaryOptions options(features, nullptr, kReadDebugNames,
+ kStopOnFirstError, kFailOnCustomSectionError);
+
+ BinaryReaderStrip reader(&errors);
+ result = ReadBinary(file_data.data(), file_data.size(), &reader, options);
+ FormatErrorsToFile(errors, Location::Type::Binary);
+ if (Failed(result)) {
+ return Result::Error;
+ }
+
+ if (s_outfile.empty()) {
+ s_outfile = s_filename;
}
- return result != Result::Ok;
+ return reader.WriteToFile(s_outfile);
}
int main(int argc, char** argv) {