]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
systemctl: allow --marker with start/stop too 40709/head
authorLuca Boccassi <luca.boccassi@gmail.com>
Thu, 19 Feb 2026 16:32:49 +0000 (16:32 +0000)
committerLuca Boccassi <luca.boccassi@gmail.com>
Mon, 23 Feb 2026 13:05:23 +0000 (13:05 +0000)
man/systemctl.xml
src/systemctl/systemctl-main.c
src/systemctl/systemctl.c

index 63454505dcb78d1dec10f1195a566ad8ea0a49c5..619805891c129275308cc483324ac3fdf94bbd80 100644 (file)
@@ -2855,10 +2855,10 @@ Jan 12 10:46:45 example.com bluetoothd[8900]: gatt-time-server: Input/output err
       <varlistentry>
         <term><option>--marked</option></term>
 
-        <listitem><para>Only allowed with <command>reload-or-restart</command>. Enqueues restart jobs for all
-        units that have the <literal>needs-restart</literal> mark, and reload jobs for units that have the
-        <literal>needs-reload</literal> mark. When a unit marked for reload does not support reload, restart
-        will be queued. Those properties can be set using <command>set-property Markers=…</command>.</para>
+        <listitem><para>Only allowed with <command>reload-or-restart</command>, <command>start</command>, or
+        <command>stop</command>. Enqueues jobs for all units that are marked. When a unit marked for reload
+        does not support reload, restart will be queued. Those properties can be set using
+        <command>set-property Markers=…</command>.</para>
 
         <para>Unless <option>--no-block</option> is used, <command>systemctl</command> will wait for the
         queued jobs to finish.</para>
index c0596cfb861d3f30fdef5695837daad7e645c720..b23bc4e6fff870bc2bad87843114b434bf2fc555 100644 (file)
@@ -59,8 +59,8 @@ static int systemctl_main(int argc, char *argv[]) {
                 { "list-machines",         VERB_ANY, VERB_ANY, VERB_ONLINE_ONLY, verb_list_machines           },
                 { "clear-jobs",            VERB_ANY, 1,        VERB_ONLINE_ONLY, verb_trivial_method          },
                 { "cancel",                VERB_ANY, VERB_ANY, VERB_ONLINE_ONLY, verb_cancel                  },
-                { "start",                 2,        VERB_ANY, VERB_ONLINE_ONLY, verb_start                   },
-                { "stop",                  2,        VERB_ANY, VERB_ONLINE_ONLY, verb_start                   },
+                { "start",                 VERB_ANY, VERB_ANY, VERB_ONLINE_ONLY, verb_start                   },
+                { "stop",                  VERB_ANY, VERB_ANY, VERB_ONLINE_ONLY, verb_start                   },
                 { "condstop",              2,        VERB_ANY, VERB_ONLINE_ONLY, verb_start                   }, /* For compatibility with ALTLinux */
                 { "reload",                2,        VERB_ANY, VERB_ONLINE_ONLY, verb_start                   },
                 { "restart",               2,        VERB_ANY, VERB_ONLINE_ONLY, verb_start                   },
index 382a50e312322cd08d9c222caece3693f3475d1b..fef1cb7a77b8b82417fe0d38c76dd2a1ba68f832 100644 (file)
@@ -1069,14 +1069,13 @@ static int systemctl_parse_argv(int argc, char *argv[]) {
                 return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
                                        "--wait may not be combined with --no-block.");
 
-        bool do_reload_or_restart = streq_ptr(argv[optind], "reload-or-restart");
         if (arg_marked) {
-                if (!do_reload_or_restart)
+                if (!STRPTR_IN_SET(argv[optind], "reload-or-restart", "start", "stop"))
                         return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
-                                               "--marked may only be used with 'reload-or-restart'.");
+                                               "--marked may only be used with 'reload-or-restart', 'start', or 'stop'.");
                 if (optind + 1 < argc)
                         return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
-                                               "No additional arguments allowed with 'reload-or-restart --marked'.");
+                                               "No additional arguments allowed with '%s --marked'.", strna(argv[optind]));
                 if (arg_wait)
                         return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
                                                "--marked --wait is not supported.");
@@ -1084,10 +1083,10 @@ static int systemctl_parse_argv(int argc, char *argv[]) {
                         return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
                                                "--marked --show-transaction is not supported.");
 
-        } else if (do_reload_or_restart) {
+        } else if (STRPTR_IN_SET(argv[optind], "reload-or-restart", "start", "stop")) {
                 if (optind + 1 >= argc)
                         return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
-                                               "List of units to restart/reload is required.");
+                                               "List of units to %s is required.", strna(argv[optind]));
         }
 
         if (arg_image && arg_root)