mirror of
https://github.com/RGBCube/serenity
synced 2025-05-14 09:34:59 +00:00
Userland+AK: Stop using getopt() for ArgsParser
This commit moves the implementation of getopt into AK, and converts its API to understand and use StringView instead of char*. Everything else is caught in the crossfire of making Option::accept_value() take a StringView instead of a char const*. With this, we must now pass a Span<StringView> to ArgsParser::parse(), applications using LibMain are unaffected, but anything not using that or taking its own argc/argv has to construct a Vector<StringView> for this method.
This commit is contained in:
parent
b2b851b361
commit
db886fe18b
43 changed files with 673 additions and 584 deletions
|
@ -31,15 +31,15 @@ ErrorOr<int> serenity_main(Main::Arguments arguments)
|
|||
"preserve",
|
||||
'p',
|
||||
"attributes",
|
||||
[&preserve](char const* s) {
|
||||
if (!s) {
|
||||
[&preserve](StringView s) {
|
||||
if (s.is_empty()) {
|
||||
preserve = Core::DeprecatedFile::PreserveMode::Permissions | Core::DeprecatedFile::PreserveMode::Ownership | Core::DeprecatedFile::PreserveMode::Timestamps;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool values_ok = true;
|
||||
|
||||
StringView { s, strlen(s) }.for_each_split_view(',', SplitBehavior::Nothing, [&](StringView value) {
|
||||
s.for_each_split_view(',', SplitBehavior::Nothing, [&](StringView value) {
|
||||
if (value == "mode"sv) {
|
||||
preserve |= Core::DeprecatedFile::PreserveMode::Permissions;
|
||||
} else if (value == "ownership"sv) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue