]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
rpm: check argument counts for systemd macros
authorJan Engelhardt <jengelh@inai.de>
Wed, 20 Mar 2019 13:48:47 +0000 (14:48 +0100)
committerJan Engelhardt <jengelh@inai.de>
Thu, 21 Mar 2019 18:01:33 +0000 (19:01 +0100)
Invoking %systemd_tmpfiles (in %post) without any arguments, while
possible, will cause systemd-tmpfiles to process the entire system
configuration, rather than just the newly installed configuration
files. In https://github.com/systemd/systemd/pull/12048, it was
established that processing everything constitutes unusual practice,
and should be flagged as a mistake at build time.

Furthermore, invoking %systemd_post without any arguments will cause
the underlying `systemctl preset` to outright return an error ("Too
few arguments") when run. This can be flagged during build time in
the same manner.

As I have found no ways to successfully nest %if clauses inside a
macro[1], I am helping myself by reusing the recursive variable
expansion technique pioneered in [2].

Now, when %systemd_post or %systemd_tmpfiles is incorrectly used,
rpm gives accurate line number reporting, too:

error: This macro requires some arguments
error: line 11: %{systemd_post}

error: This macro requires two arguments
error: line 13: %{tmpfiles_create_package meh more more}

[1] what has been tried: %{expand:%%if "%#" == 0 \\\
    %%{error:you have given me %# args} \\\
    %%endif}

[2] http://git.savannah.gnu.org/cgit/automake.git/commit/?id=e0bd4af16da88e4c2c61bde42675660eff7dff51

src/core/macros.systemd.in

index d9e7f573ba2612436711e11397849cf18273419f..a5b7f67e3688d25db9674f5028483e4a6bd0f92b 100644 (file)
@@ -40,7 +40,11 @@ OrderWithRequires(preun): systemd \
 OrderWithRequires(postun): systemd \
 %{nil}
 
+%__systemd_someargs_0() %{error:This macro requires some arguments}
+%__systemd_twoargs_2() %{nil}
+
 %systemd_post() \
+%{expand:%%{?__systemd_someargs_%#}} \
 if [ $1 -eq 1 ] ; then \
         # Initial installation \
         systemctl --no-reload preset %{?*} >/dev/null 2>&1 || : \
@@ -50,6 +54,7 @@ fi \
 %systemd_user_post() %{expand:%systemd_post \\--global %%{?*}}
 
 %systemd_preun() \
+%{expand:%%{?__systemd_someargs_%#}} \
 if [ $1 -eq 0 ] ; then \
         # Package removal, not upgrade \
         systemctl --no-reload disable --now %{?*} >/dev/null 2>&1 || : \
@@ -57,24 +62,26 @@ fi \
 %{nil}
 
 %systemd_user_preun() \
+%{expand:%%{?__systemd_someargs_%#}} \
 if [ $1 -eq 0 ] ; then \
         # Package removal, not upgrade \
         systemctl --global disable %{?*} >/dev/null 2>&1 || : \
 fi \
 %{nil}
 
-%systemd_postun() %{nil}
+%systemd_postun() %{expand:%%{?__systemd_someargs_%#}}%{nil}
 
-%systemd_user_postun() %{nil}
+%systemd_user_postun() %{expand:%%{?__systemd_someargs_%#}}%{nil}
 
 %systemd_postun_with_restart() \
+%{expand:%%{?__systemd_someargs_%#}} \
 if [ $1 -ge 1 ] ; then \
         # Package upgrade, not uninstall \
         systemctl try-restart %{?*} >/dev/null 2>&1 || : \
 fi \
 %{nil}
 
-%systemd_user_postun_with_restart() %{nil}
+%systemd_user_postun_with_restart() %{expand:%%{?__systemd_someargs_%#}}%{nil}
 
 %udev_hwdb_update() %{nil}
 
@@ -84,11 +91,13 @@ fi \
 
 # Deprecated. Use %tmpfiles_create_package instead
 %tmpfiles_create() \
+%{expand:%%{?__systemd_someargs_%#}} \
 systemd-tmpfiles --create %{?*} >/dev/null 2>&1 || : \
 %{nil}
 
 # Deprecated. Use %sysusers_create_package instead
 %sysusers_create() \
+%{expand:%%{?__systemd_someargs_%#}} \
 systemd-sysusers %{?*} >/dev/null 2>&1 || : \
 %{nil}
 
@@ -112,6 +121,7 @@ SYSTEMD_INLINE_EOF \
 #   %files
 #   %{_sysusersdir}/%{name}.conf
 %sysusers_create_package() \
+%{expand:%%{?!__systemd_twoargs_%#:%%{error:This macro requires two arguments}}} \
 systemd-sysusers --replace=%_sysusersdir/%1.conf - <<SYSTEMD_INLINE_EOF >/dev/null 2>&1 || : \
 %(cat %2) \
 SYSTEMD_INLINE_EOF \
@@ -131,15 +141,18 @@ SYSTEMD_INLINE_EOF \
 #   %files
 #   %{_tmpfilesdir}/%{name}.conf
 %tmpfiles_create_package() \
+%{expand:%%{?!__systemd_twoargs_%#:%%{error:This macro requires two arguments}}} \
 systemd-tmpfiles --replace=%_tmpfilesdir/%1.conf --create - <<SYSTEMD_INLINE_EOF >/dev/null 2>&1 || : \
 %(cat %2) \
 SYSTEMD_INLINE_EOF \
 %{nil}
 
 %sysctl_apply() \
+%{expand:%%{?__systemd_someargs_%#}} \
 @rootlibexecdir@/systemd-sysctl %{?*} >/dev/null 2>&1 || : \
 %{nil}
 
 %binfmt_apply() \
+%{expand:%%{?__systemd_someargs_%#}} \
 @rootlibexecdir@/systemd-binfmt %{?*} >/dev/null 2>&1 || : \
 %{nil}