pkill: Add -x option to only select exact matches

This commit is contained in:
Tim Ledbetter 2023-06-04 11:40:30 +01:00 committed by Andreas Kling
parent a253be6abf
commit 69b6c6f62c
Notes: sideshowbarker 2024-07-17 08:34:29 +09:00

View file

@ -28,6 +28,7 @@ ErrorOr<int> serenity_main(Main::Arguments args)
bool display_number_of_matches;
bool case_insensitive = false;
bool echo = false;
bool exact_match = false;
StringView pattern;
HashTable<uid_t> uids_to_filter_by;
int signal = SIGTERM;
@ -61,6 +62,7 @@ ErrorOr<int> serenity_main(Main::Arguments args)
return true;
},
});
args_parser.add_option(exact_match, "Select only processes whose names match the given pattern exactly", "exact", 'x');
args_parser.add_positional_argument(pattern, "Process name to search for", "process-name");
args_parser.parse(args);
@ -71,6 +73,12 @@ ErrorOr<int> serenity_main(Main::Arguments args)
options |= PosixFlags::Insensitive;
}
StringBuilder exact_pattern_builder;
if (exact_match) {
exact_pattern_builder.appendff("^({})$", pattern);
pattern = exact_pattern_builder.string_view();
}
Regex<PosixExtended> re(pattern, options);
if (re.parser_result.error != regex::Error::NoError) {
return 1;