serenity/Userland/Utilities/kill.cpp
Shannon Booth e2e7c4d574 Everywhere: Use to_number<T> instead of to_{int,uint,float,double}
In a bunch of cases, this actually ends up simplifying the code as
to_number will handle something such as:

```
Optional<I> opt;
if constexpr (IsSigned<I>)
    opt = view.to_int<I>();
else
    opt = view.to_uint<I>();
```

For us.

The main goal here however is to have a single generic number conversion
API between all of the String classes.
2023-12-23 20:41:07 +01:00

81 lines
2.1 KiB
C++

/*
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <AK/CharacterTypes.h>
#include <AK/Optional.h>
#include <LibCore/System.h>
#include <LibMain/Main.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
static void print_usage_and_exit()
{
warnln("usage: kill [-signal] <PID>");
exit(1);
}
ErrorOr<int> serenity_main(Main::Arguments arguments)
{
TRY(Core::System::pledge("stdio proc"));
int argc = arguments.argc;
auto strings = arguments.strings;
if (argc == 2 && strings[1] == "-l") {
size_t valid_signal_count = 0;
for (size_t i = 1; i < NSIG; ++i) {
if (valid_signal_count && valid_signal_count % 5 == 0)
outln("");
auto const* signal_name = getsignalname(i);
// This excludes SIGCANCEL, which is intended for internal use only
if (!signal_name)
continue;
valid_signal_count++;
out("{:2}) {:10}", i, signal_name);
}
outln("");
return 0;
}
if (argc != 2 && argc != 3)
print_usage_and_exit();
unsigned signum = SIGTERM;
int pid_argi = 1;
if (argc == 3) {
pid_argi = 2;
if (strings[1][0] != '-')
print_usage_and_exit();
Optional<unsigned> number;
if (is_ascii_alpha(strings[1][1])) {
int value = getsignalbyname(&strings[1][1]);
if (value > 0 && value < NSIG)
number = value;
}
if (!number.has_value())
number = strings[1].substring_view(1).to_number<unsigned>();
if (!number.has_value()) {
warnln("'{}' is not a valid signal name or number", &strings[1][1]);
return 2;
}
signum = number.value();
}
auto pid_opt = strings[pid_argi].to_number<pid_t>();
if (!pid_opt.has_value()) {
warnln("'{}' is not a valid PID", strings[pid_argi]);
return 3;
}
pid_t pid = pid_opt.value();
TRY(Core::System::kill(pid, signum));
return 0;
}