mirror of
https://github.com/archlinuxarm/PKGBUILDs.git
synced 2024-12-28 23:21:53 +00:00
182 lines
6.9 KiB
Bash
182 lines
6.9 KiB
Bash
# Maintainer: Dave Reisner <dreisner@archlinux.org>
|
|
# Maintainer: Tom Gundersen <teg@jklm.no>
|
|
|
|
# ALARM: Kevin Mihelich <kevin@archlinuxarm.org>
|
|
# - --disable-xattr; ARM just has too many old, hacked up kernels
|
|
|
|
pkgbase=systemd
|
|
pkgname=('systemd' 'libsystemd' 'systemd-sysvcompat')
|
|
pkgver=213
|
|
pkgrel=9.1
|
|
arch=('i686' 'x86_64')
|
|
url="http://www.freedesktop.org/wiki/Software/systemd"
|
|
makedepends=('acl' 'cryptsetup' 'docbook-xsl' 'gobject-introspection' 'gperf'
|
|
'gtk-doc' 'intltool' 'kmod' 'libcap' 'libgcrypt' 'libmicrohttpd' 'libxslt'
|
|
'util-linux' 'linux-api-headers' 'pam' 'python' 'python-lxml' 'quota-tools'
|
|
'shadow' 'xz')
|
|
options=('strip' 'debug')
|
|
source=("http://www.freedesktop.org/software/$pkgname/$pkgname-$pkgver.tar.xz"
|
|
'initcpio-hook-udev'
|
|
'initcpio-install-systemd'
|
|
'initcpio-install-udev'
|
|
'0001-units-use-KillMode-mixed-for-systemd-nspawn-.service.patch'
|
|
'0001-fsck-disable-l-option-for-now.patch'
|
|
'0001-udev-exclude-device-mapper-from-block-device-ownersh.patch'
|
|
'0001-udev-always-close-lock-file-descriptor.patch'
|
|
'0001-networkd-link-intialize-mac-address.patch'
|
|
'0001-udev-really-exclude-device-mapper-from-block-device-.patch')
|
|
md5sums=('06496edcf86ddf6d8c12d72ba78e735d'
|
|
'29245f7a240bfba66e2b1783b63b6b40'
|
|
'66cca7318e13eaf37c5b7db2efa69846'
|
|
'bde43090d4ac0ef048e3eaee8202a407'
|
|
'5f8ad7126970855614c7fa34b317728d'
|
|
'888cf85a92dd28bcf80e18539fef3915'
|
|
'f26803dda8811196c0564f928bfe69d1'
|
|
'2a14fe9876fa48f01cca3c1d575e5771'
|
|
'3d53d3bcd85ca0b2ff9f4e79d012808d'
|
|
'ae060fc00eeced6554e70d9a9c0eb42f')
|
|
|
|
prepare() {
|
|
cd "$pkgname-$pkgver"
|
|
|
|
patch -Np1 <"$srcdir/0001-units-use-KillMode-mixed-for-systemd-nspawn-.service.patch"
|
|
patch -Np1 <"$srcdir/0001-networkd-link-intialize-mac-address.patch"
|
|
patch -Np1 <"$srcdir/0001-fsck-disable-l-option-for-now.patch"
|
|
patch -Np1 <"$srcdir/0001-udev-always-close-lock-file-descriptor.patch"
|
|
patch -Np1 <"$srcdir/0001-udev-exclude-device-mapper-from-block-device-ownersh.patch"
|
|
patch -Np1 <"$srcdir/0001-udev-really-exclude-device-mapper-from-block-device-.patch"
|
|
}
|
|
|
|
|
|
build() {
|
|
cd "$pkgname-$pkgver"
|
|
|
|
export NM=gcc-nm RANLIB=gcc-ranlib
|
|
|
|
./configure \
|
|
--libexecdir=/usr/lib \
|
|
--localstatedir=/var \
|
|
--sysconfdir=/etc \
|
|
--enable-introspection \
|
|
--enable-gtk-doc \
|
|
--enable-compat-libs \
|
|
--disable-audit \
|
|
--disable-ima \
|
|
--disable-kdbus \
|
|
--disable-xattr \
|
|
--with-sysvinit-path= \
|
|
--with-sysvrcnd-path= \
|
|
--with-firmware-path="/usr/lib/firmware/updates:/usr/lib/firmware"
|
|
|
|
make
|
|
}
|
|
|
|
package_systemd() {
|
|
pkgdesc="system and service manager"
|
|
license=('GPL2' 'LGPL2.1' 'MIT')
|
|
depends=('acl' 'bash' 'dbus' 'glib2' 'kbd' 'kmod' 'hwids' 'libcap' 'libgcrypt'
|
|
'libsystemd' 'pam' 'libseccomp' 'util-linux' 'xz')
|
|
provides=('nss-myhostname' "systemd-tools=$pkgver" "udev=$pkgver")
|
|
replaces=('nss-myhostname' 'systemd-tools' 'udev')
|
|
conflicts=('nss-myhostname' 'systemd-tools' 'udev')
|
|
optdepends=('python: systemd library bindings'
|
|
'cryptsetup: required for encrypted block devices'
|
|
'libmicrohttpd: remote journald capabilities'
|
|
'quota-tools: kernel-level quota management'
|
|
'systemd-sysvcompat: symlink package to provide sysvinit binaries')
|
|
backup=(etc/dbus-1/system.d/org.freedesktop.systemd1.conf
|
|
etc/dbus-1/system.d/org.freedesktop.hostname1.conf
|
|
etc/dbus-1/system.d/org.freedesktop.login1.conf
|
|
etc/dbus-1/system.d/org.freedesktop.locale1.conf
|
|
etc/dbus-1/system.d/org.freedesktop.machine1.conf
|
|
etc/dbus-1/system.d/org.freedesktop.timedate1.conf
|
|
etc/pam.d/systemd-user
|
|
etc/systemd/bootchart.conf
|
|
etc/systemd/journald.conf
|
|
etc/systemd/logind.conf
|
|
etc/systemd/system.conf
|
|
etc/systemd/timesyncd.conf
|
|
etc/systemd/resolved.conf
|
|
etc/systemd/user.conf
|
|
etc/udev/udev.conf)
|
|
install="systemd.install"
|
|
|
|
make -C "$pkgname-$pkgver" DESTDIR="$pkgdir" install
|
|
|
|
# don't write units to /etc by default. some of these will be re-enabled on
|
|
# post_install.
|
|
rm "$pkgdir/etc/systemd/system/getty.target.wants/getty@tty1.service" \
|
|
"$pkgdir/etc/systemd/system/multi-user.target.wants/systemd-networkd.service" \
|
|
"$pkgdir/etc/systemd/system/multi-user.target.wants/systemd-resolved.service" \
|
|
"$pkgdir/etc/systemd/system/network-online.target.wants/systemd-networkd-wait-online.service"
|
|
rmdir "$pkgdir/etc/systemd/system/getty.target.wants" \
|
|
"$pkgdir/etc/systemd/system/network-online.target.wants"
|
|
|
|
# get rid of RPM macros
|
|
rm -r "$pkgdir/usr/lib/rpm"
|
|
|
|
# add back tmpfiles.d/legacy.conf
|
|
install -m644 "systemd-$pkgver/tmpfiles.d/legacy.conf" "$pkgdir/usr/lib/tmpfiles.d"
|
|
|
|
# Replace dialout/tape/cdrom group in rules with uucp/storage/optical group
|
|
sed -i 's#GROUP="dialout"#GROUP="uucp"#g;
|
|
s#GROUP="tape"#GROUP="storage"#g;
|
|
s#GROUP="cdrom"#GROUP="optical"#g' "$pkgdir"/usr/lib/udev/rules.d/*.rules
|
|
|
|
# add mkinitcpio hooks
|
|
install -Dm644 "$srcdir/initcpio-install-systemd" "$pkgdir/usr/lib/initcpio/install/systemd"
|
|
install -Dm644 "$srcdir/initcpio-install-udev" "$pkgdir/usr/lib/initcpio/install/udev"
|
|
install -Dm644 "$srcdir/initcpio-hook-udev" "$pkgdir/usr/lib/initcpio/hooks/udev"
|
|
|
|
# ensure proper permissions for /var/log/journal
|
|
chown root:systemd-journal "$pkgdir/var/log/journal"
|
|
chmod 2755 "$pkgdir/var/log/journal"
|
|
|
|
# fix pam file
|
|
sed 's|system-auth|system-login|g' -i "$pkgdir/etc/pam.d/systemd-user"
|
|
|
|
### split out manpages for sysvcompat
|
|
rm -rf "$srcdir/_sysvcompat"
|
|
install -dm755 "$srcdir"/_sysvcompat/usr/share/man/man8/
|
|
mv "$pkgdir"/usr/share/man/man8/{telinit,halt,reboot,poweroff,runlevel,shutdown}.8 \
|
|
"$srcdir"/_sysvcompat/usr/share/man/man8
|
|
|
|
### split off runtime libraries
|
|
rm -rf "$srcdir/_libsystemd"
|
|
install -dm755 "$srcdir"/_libsystemd/usr/lib
|
|
cd "$srcdir"/_libsystemd
|
|
mv "$pkgdir"/usr/lib/lib{systemd,{g,}udev}*.so* usr/lib
|
|
|
|
# include MIT license, since it's technically custom
|
|
install -Dm644 "$srcdir/$pkgname-$pkgver/LICENSE.MIT" \
|
|
"$pkgdir/usr/share/licenses/systemd/LICENSE.MIT"
|
|
}
|
|
|
|
package_libsystemd() {
|
|
pkgdesc="systemd client libraries"
|
|
depends=('glib2' 'glibc' 'libgcrypt' 'xz')
|
|
license=('GPL2')
|
|
provides=('libgudev-1.0.so' 'libsystemd.so' 'libsystemd-daemon.so' 'libsystemd-id128.so'
|
|
'libsystemd-journal.so' 'libsystemd-login.so' 'libudev.so')
|
|
|
|
mv "$srcdir/_libsystemd"/* "$pkgdir"
|
|
}
|
|
|
|
package_systemd-sysvcompat() {
|
|
pkgdesc="sysvinit compat for systemd"
|
|
license=('GPL2')
|
|
groups=('base')
|
|
conflicts=('sysvinit')
|
|
depends=('systemd')
|
|
|
|
mv "$srcdir/_sysvcompat"/* "$pkgdir"
|
|
|
|
install -dm755 "$pkgdir/usr/bin"
|
|
for tool in runlevel reboot shutdown poweroff halt telinit; do
|
|
ln -s 'systemctl' "$pkgdir/usr/bin/$tool"
|
|
done
|
|
|
|
ln -s '../lib/systemd/systemd' "$pkgdir/usr/bin/init"
|
|
}
|
|
|
|
# vim: ft=sh syn=sh et
|