[oe-commits] Otavio Salvador : systemd-systemctl-native: add a systemctl wrapper
git at git.openembedded.org
git at git.openembedded.org
Fri Nov 4 19:30:51 UTC 2011
Module: meta-openembedded.git
Branch: master
Commit: 79f35231a351a7df30db8b2037f274a41e8d9e58
URL: http://git.openembedded.org/?p=meta-openembedded.git&a=commit;h=79f35231a351a7df30db8b2037f274a41e8d9e58
Author: Otavio Salvador <otavio at ossystems.com.br>
Date: Fri Nov 4 17:25:58 2011 +0000
systemd-systemctl-native: add a systemctl wrapper
The wrapper allows for enabling services at rootfs generation thus
allowing systemd to be used in ready-only filesystems.
Signed-off-by: Otavio Salvador <otavio at ossystems.com.br>
Signed-off-by: Koen Kooi <koen at dominion.thruhere.net>
---
.../systemd/systemd-systemctl-native.bb | 13 +++++
.../systemd/systemd-systemctl-native/systemctl | 51 ++++++++++++++++++++
2 files changed, 64 insertions(+), 0 deletions(-)
diff --git a/meta-oe/recipes-core/systemd/systemd-systemctl-native.bb b/meta-oe/recipes-core/systemd/systemd-systemctl-native.bb
new file mode 100644
index 0000000..3ee757e
--- /dev/null
+++ b/meta-oe/recipes-core/systemd/systemd-systemctl-native.bb
@@ -0,0 +1,13 @@
+DESCRIPTION = "Wrapper to enable of systemd services"
+
+LICENSE = "MIT"
+LIC_FILES_CHKSUM = "file://${COREBASE}/LICENSE;md5=3f40d7994397109285ec7b81fdeb3b58"
+
+inherit native
+
+SRC_URI = "file://systemctl"
+
+do_install() {
+ install -d ${D}${bindir}
+ install -m 0755 ${WORKDIR}/systemctl ${D}${bindir}
+}
diff --git a/meta-oe/recipes-core/systemd/systemd-systemctl-native/systemctl b/meta-oe/recipes-core/systemd/systemd-systemctl-native/systemctl
new file mode 100755
index 0000000..1fc77fd
--- /dev/null
+++ b/meta-oe/recipes-core/systemd/systemd-systemctl-native/systemctl
@@ -0,0 +1,51 @@
+#!/bin/sh
+
+ROOT=
+
+# parse command line params
+while [ $# != 0 ]; do
+ opt="$1"
+
+ case "$opt" in
+ enable)
+ shift
+
+ service="$1"
+ shift
+ ;;
+ --root=*)
+ ROOT=${opt##--root=}
+ shift
+ ;;
+ *)
+ echo "'$opt' is an unkown option; exiting with error"
+ exit 1
+ ;;
+ esac
+done
+
+# find service file
+for p in $ROOT/etc/systemd/system \
+ $ROOT/lib/systemd/system \
+ $ROOT/usr/lib/systemd/system; do
+ if [ -e $p/$service ]; then
+ service_file=$p/$service
+ service_file=${service_file##$ROOT}
+ fi
+done
+if [ -z "$service_file" ]; then
+ echo "'$service' couldn't be found; exiting with error"
+ exit 1
+fi
+
+# create the required symbolic links
+wanted_by=$(grep WantedBy $ROOT/$service_file \
+ | sed 's,WantedBy=,,g' \
+ | tr ',' '\n' \
+ | grep '\.target$')
+
+for r in $wanted_by; do
+ mkdir -p $ROOT/etc/systemd/system/$r.wants
+ ln -s $service_file $ROOT/etc/systemd/system/$r.wants
+ echo "Enabled $service for $wanted_by."
+done
More information about the Openembedded-commits
mailing list