1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-25 02:17:35 +00:00

pgrep: Add -x option to only select exact matches

This commit is contained in:
Tim Ledbetter 2023-05-30 17:51:30 +01:00 committed by Andreas Kling
parent 821bf5e071
commit f5da6d61b4
2 changed files with 10 additions and 2 deletions

View file

@ -27,6 +27,7 @@ ErrorOr<int> serenity_main(Main::Arguments args)
bool case_insensitive = false;
bool list_process_name = false;
bool invert_match = false;
bool exact_match = false;
HashTable<uid_t> uids_to_filter_by;
StringView pattern;
@ -60,6 +61,7 @@ ErrorOr<int> serenity_main(Main::Arguments args)
},
});
args_parser.add_option(invert_match, "Select non-matching lines", "invert-match", 'v');
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);
@ -67,6 +69,12 @@ ErrorOr<int> serenity_main(Main::Arguments args)
if (case_insensitive)
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;