diff options
author | Michał Masłowski <mtjm@mtjm.eu> | 2012-06-08 10:51:38 +0200 |
---|---|---|
committer | Michał Masłowski <mtjm@mtjm.eu> | 2012-06-08 10:51:38 +0200 |
commit | 86c07f860ec2bad836bce1eaf59b923aa5c3a5cc (patch) | |
tree | ee11bae8aa26c33b36cbdbcedb78e0d685fa4a52 /core/systemd/systemd.install | |
parent | 3187d2ae8f540fd5f918eecc4d63b6f305bba632 (diff) | |
parent | 7d11e9346ebd0f9c378952caee0c82d6ca815f4e (diff) |
Merge branch 'master' of ssh://parabolagnulinux.org:1863/home/parabola/abslibre-pre-mips64el
Conflicts:
community/chmsee/PKGBUILD
community/haveged/PKGBUILD
core/pinentry/PKGBUILD
extra/vim/PKGBUILD
Diffstat (limited to 'core/systemd/systemd.install')
-rw-r--r-- | core/systemd/systemd.install | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/core/systemd/systemd.install b/core/systemd/systemd.install new file mode 100644 index 000000000..0b10f9537 --- /dev/null +++ b/core/systemd/systemd.install @@ -0,0 +1,51 @@ +#!/bin/sh + +sd_booted() { + [ -e sys/fs/cgroup/systemd ] +} + +post_install() { + if [ ! -f etc/machine-id ]; then + systemd-machine-id-setup + fi + + # enable getty@tty1 by default, but don't track the file + systemctl enable getty@.service + + echo ":: Append 'init=/bin/systemd' to your kernel command line in your" + echo " bootloader to replace sysvinit with systemd" +} + +post_upgrade() { + if [ ! -f etc/machine-id ]; then + systemd-machine-id-setup + fi + + if sd_booted; then + # we moved the binary in 44-2 to /usr, so a reexec leads to a + # coredump. refuse this reexec and warn the user that they should + # reboot instead. + if [ "$(vercmp 44-2 "$2")" -eq 1 ]; then + echo "warning: refusing to reexec systemd. the system should be rebooted." + else + systemctl daemon-reload + systemctl daemon-reexec + fi + fi + + # getty@tty1.service is no longer enabled by default, but we don't want to break + # existing setups. + if [ "$(vercmp 183 "$2")" -eq 1 ]; then + # systemctl seems to be whiny on sysvinit. this will succeed unless something + # horrific happens, so just mask the error. + systemctl -q enable getty@.service || true + fi +} + +post_remove() { + if getent group lock >/dev/null; then + groupdel lock + fi +} + +# vim:set ts=2 sw=2 et: |