X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;ds=sidebyside;f=src%2Fsystemctl%2Fsystemctl.c;h=6ab92cebf0fd34b5ac60766358c34b08666462ee;hb=c147dc42f8b3383a3ced69aaa75e21df4fe75a96;hp=a9681798dd55baef54e0ca1087c5fcfedd8180c3;hpb=6d97280899a766ad7b4a6b07cc803709a08b364b;p=elogind.git diff --git a/src/systemctl/systemctl.c b/src/systemctl/systemctl.c index a9681798d..6ab92cebf 100644 --- a/src/systemctl/systemctl.c +++ b/src/systemctl/systemctl.c @@ -65,6 +65,7 @@ #include "path-util.h" static const char *arg_type = NULL; +static const char *arg_load_state = NULL; static char **arg_property = NULL; static bool arg_all = false; static const char *arg_job_mode = "replace"; @@ -337,7 +338,9 @@ static bool output_show_unit(const struct unit_info *u) { return (!arg_type || ((dot = strrchr(u->id, '.')) && streq(dot+1, arg_type))) && - (arg_all || !(streq(u->active_state, "inactive") || u->following[0]) || u->job_id > 0); + (!arg_load_state || streq(u->load_state, arg_load_state)) && + (arg_all || !(streq(u->active_state, "inactive") + || u->following[0]) || u->job_id > 0); } static void output_units_list(const struct unit_info *unit_infos, unsigned c) { @@ -4650,13 +4653,17 @@ static int systemctl_parse_argv(int argc, char *argv[]) { return 0; case 't': - if (unit_type_from_string(optarg) < 0) { - log_error("Invalid unit type '%s'.", optarg); - return -EINVAL; + if (unit_type_from_string(optarg) >= 0) { + arg_type = optarg; + break; } - arg_type = optarg; - break; - + if (unit_load_state_from_string(optarg) >= 0) { + arg_load_state = optarg; + break; + } + log_error("Unkown unit type or load state '%s'.", + optarg); + return -EINVAL; case 'p': { char **l;