1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-05-28 17:15:09 +00:00

errno: Port to LibMain

This commit is contained in:
Kenneth Myhra 2021-12-21 19:08:23 +01:00 committed by Andreas Kling
parent 2e0f53c25d
commit 8aafe6cd1f
2 changed files with 8 additions and 6 deletions

View file

@ -88,6 +88,7 @@ target_link_libraries(dmesg LibMain)
target_link_libraries(du LibMain) target_link_libraries(du LibMain)
target_link_libraries(echo LibMain) target_link_libraries(echo LibMain)
target_link_libraries(env LibMain) target_link_libraries(env LibMain)
target_link_libraries(errno LibMain)
target_link_libraries(expr LibRegex LibMain) target_link_libraries(expr LibRegex LibMain)
target_link_libraries(fdtdump LibDeviceTree LibMain) target_link_libraries(fdtdump LibDeviceTree LibMain)
target_link_libraries(file LibGfx LibIPC LibCompress LibMain) target_link_libraries(file LibGfx LibIPC LibCompress LibMain)

View file

@ -5,19 +5,20 @@
*/ */
#include <LibCore/ArgsParser.h> #include <LibCore/ArgsParser.h>
#include <LibMain/Main.h>
#include <string.h> #include <string.h>
int main(int argc, char** argv) ErrorOr<int> serenity_main(Main::Arguments arguments)
{ {
bool list = false; bool list = false;
bool search = false; bool search = false;
const char* keyword = nullptr; StringView keyword;
Core::ArgsParser args_parser; Core::ArgsParser args_parser;
args_parser.add_positional_argument(keyword, "Error number or string to search", "keyword", Core::ArgsParser::Required::No); args_parser.add_positional_argument(keyword, "Error number or string to search", "keyword", Core::ArgsParser::Required::No);
args_parser.add_option(list, "List all errno values", "list", 'l'); args_parser.add_option(list, "List all errno values", "list", 'l');
args_parser.add_option(search, "Search for error descriptions containing keyword", "search", 's'); args_parser.add_option(search, "Search for error descriptions containing keyword", "search", 's');
args_parser.parse(argc, argv); args_parser.parse(arguments);
if (list) { if (list) {
for (int i = 0; i < sys_nerr; i++) { for (int i = 0; i < sys_nerr; i++) {
@ -26,7 +27,7 @@ int main(int argc, char** argv)
return 0; return 0;
} }
if (keyword == nullptr) if (keyword.is_empty())
return 0; return 0;
if (search) { if (search) {
@ -39,14 +40,14 @@ int main(int argc, char** argv)
return 0; return 0;
} }
auto maybe_errno = StringView { keyword }.to_int(); auto maybe_errno = keyword.to_int();
if (!maybe_errno.has_value()) { if (!maybe_errno.has_value()) {
warnln("ERROR: Not understood: {}", keyword); warnln("ERROR: Not understood: {}", keyword);
return 1; return 1;
} }
auto error = String::formatted("{}", strerror(maybe_errno.value())); auto error = String::formatted("{}", strerror(maybe_errno.value()));
if (error == "Unknown error") { if (error == "Unknown error"sv) {
warnln("ERROR: Unknown errno: {}", keyword); warnln("ERROR: Unknown errno: {}", keyword);
return 1; return 1;
} }