From 937cdc37a73d9e8c2f59c7689ff6041751847048 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Mangano?= Date: Sun, 17 Jan 2021 12:36:22 +0100 Subject: [PATCH] Exit with 2 on CLI arguments error --- src/opustags.cc | 4 ++-- src/opustags.h | 2 +- t/opustags.t | 8 ++++---- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/src/opustags.cc b/src/opustags.cc index 960bc47..79c86d2 100644 --- a/src/opustags.cc +++ b/src/opustags.cc @@ -19,10 +19,10 @@ int main(int argc, char** argv) { setlocale(LC_ALL, ""); ot::options opt = ot::parse_options(argc, argv, stdin); ot::run(opt); - return EXIT_SUCCESS; + return 0; } catch (const ot::status& rc) { if (!rc.message.empty()) fprintf(stderr, "error: %s\n", rc.message.c_str()); - return EXIT_FAILURE; + return rc == ot::st::bad_arguments ? 2 : 1; } } diff --git a/src/opustags.h b/src/opustags.h index 900eaa1..eff5f31 100644 --- a/src/opustags.h +++ b/src/opustags.h @@ -96,7 +96,7 @@ enum class st { struct status { status(st code = st::ok) : code(code) {} template status(st code, T&& message) : code(code), message(message) {} - operator st() { return code; } + operator st() const { return code; } st code; std::string message; }; diff --git a/t/opustags.t b/t/opustags.t index d2cae46..6a15f53 100755 --- a/t/opustags.t +++ b/t/opustags.t @@ -44,7 +44,7 @@ sub opustags { # Tests related to the overall opustags executable, like the help message. # No Opus file is manipulated here. -is_deeply(opustags(), ['', <