X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=man%2Fdaemon.xml;h=f592e7d6e26531538b57ae6b8562affae5c6be91;hp=fdc6a64eeaa15f05dfd42b8772fff7b86ce64f8b;hb=9a60da2834074d970ca063c210fe9d2f05c70532;hpb=20604ebc04ce5d3b7d7d63e79f94cf0febf851c5 diff --git a/man/daemon.xml b/man/daemon.xml index fdc6a64ee..f592e7d6e 100644 --- a/man/daemon.xml +++ b/man/daemon.xml @@ -760,8 +760,8 @@ --variable=systemdsystemunitdir (for system services), resp. pkg-config systemd - --variable=systemdsessionunitdir - (for session services). This will make the + --variable=systemduserunitdir + (for user services). This will make the services available in the system on explicit request but not activate them automatically during boot. Optionally, during package @@ -785,15 +785,17 @@ AC_ARG_WITH([systemdsystemunitdir], AS_HELP_STRING([--with-systemdsystemunitdir=DIR], [Directory for systemd service files]), [], [with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd)]) -AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir]) -AM_CONDITIONAL(HAVE_SYSTEMD, [test -n "$with_systemdsystemunitdir"]) +if test "x$with_systemdsystemunitdir" != xno; then + AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir]) +fi +AM_CONDITIONAL(HAVE_SYSTEMD, [test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ]) This snippet allows automatic installation of the unit files on systemd machines, and optionally allows their installation even on machines lacking systemd. (Modification of this snippet for the - session unit directory is left as excercise to the + user unit directory is left as excercise to the reader.) Additionally, to ensure that @@ -826,26 +828,29 @@ endif %post if [ $1 -eq 1 ]; then - # Enable (but don't start) the units by default + # On install (not upgrade), enable (but don't start) the + # units by default /bin/systemctl enable foobar.service foobar.socket >/dev/null 2>&1 || : - # Alternatively, just call /bin/systemctl daemon-reload here, - # if the daemon should not be enabled by default on package + # Alternatively, just call + # /bin/systemctl daemon-reload >/dev/null 2>&1 || : + # here, if the daemon should not be enabled by default on # installation fi %preun if [ $1 -eq 0 ]; then - # Disable and stop the units + # On uninstall (not upgrade), disable and stop the units /bin/systemctl disable foobar.service foobar.socket >/dev/null 2>&1 || : /bin/systemctl stop foobar.service foobar.socket >/dev/null 2>&1 || : fi %postun +# Reload init system configuration, to make systemd honour changed +# or deleted unit files +/bin/systemctl daemon-reload >/dev/null 2>&1 || : if [ $1 -ge 1 ] ; then - # On upgrade, reload init system configuration if we changed unit files - /bin/systemctl daemon-reload >/dev/null 2>&1 || : - # On upgrade, restart the daemon + # On upgrade (not uninstall), optionally, restart the daemon /bin/systemctl try-restart foobar.service >/dev/null 2>&1 || : fi @@ -863,7 +868,7 @@ fi script and a native systemd service file, use a fragment like the following: - %triggerin -- foobar < 0.47.11-1 + %triggerun -- foobar < 0.47.11-1 if /sbin/chkconfig foobar ; then /bin/systemctl enable foobar.service foobar.socket >/dev/null 2>&1 || : fi