diff options
author | William Hubbs <w.d.hubbs@gmail.com> | 2022-04-06 10:51:55 -0500 |
---|---|---|
committer | William Hubbs <w.d.hubbs@gmail.com> | 2022-04-06 10:51:55 -0500 |
commit | 391d12db48754861b5cecac92ee3321597ee02c1 (patch) | |
tree | b42fad5a31ca342de7b7ecf1fb78784194c1400c /scripts | |
parent | 0efc1b133e4182bd53cde78153bd8b5cc2e99448 (diff) |
migrate fully to meson build system
- drop old build system
- move shared include and source files to common directory
- drop "rc-" prefix from shared include and source files
- move executable-specific code to individual directories under src
- adjust top-level .gitignore file for new build system
This closes #489.
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/.gitignore | 5 | ||||
-rw-r--r-- | scripts/Makefile | 30 | ||||
-rw-r--r-- | scripts/halt.in | 29 | ||||
-rw-r--r-- | scripts/meson.build | 45 | ||||
-rwxr-xr-x | scripts/meson_script_links.sh | 19 | ||||
-rwxr-xr-x | scripts/on_ac_power | 47 | ||||
-rw-r--r-- | scripts/poweroff.in | 28 | ||||
-rw-r--r-- | scripts/rc-sstat.in | 149 | ||||
-rw-r--r-- | scripts/reboot.in | 30 | ||||
-rw-r--r-- | scripts/shutdown.in | 46 |
10 files changed, 0 insertions, 428 deletions
diff --git a/scripts/.gitignore b/scripts/.gitignore deleted file mode 100644 index e26c51ae..00000000 --- a/scripts/.gitignore +++ /dev/null @@ -1,5 +0,0 @@ -halt -poweroff -rc-sstat -reboot -shutdown diff --git a/scripts/Makefile b/scripts/Makefile deleted file mode 100644 index d2215b34..00000000 --- a/scripts/Makefile +++ /dev/null @@ -1,30 +0,0 @@ -MK= ../mk -include ${MK}/os.mk - -DIR= ${LIBEXECDIR}/bin -BIN= on_ac_power -INSTALLAFTER = _installafter - -ifeq (${OS},Linux) -SRCS+= rc-sstat.in -BIN+= rc-sstat -ifeq (${MKSYSVINIT},yes) -SRCS+= halt.in poweroff.in reboot.in shutdown.in -BIN+= halt poweroff reboot shutdown - endif -endif - -_installafter: -ifeq (${OS},Linux) - ${INSTALL} -d ${DESTDIR}${SBINDIR} - ln -sf ${DIR}/rc-sstat ${DESTDIR}/${SBINDIR}/rc-sstat -ifeq (${MKSYSVINIT},yes) - ln -sf ${DIR}/halt ${DESTDIR}/${SBINDIR}/halt - ln -sf ${DIR}/poweroff ${DESTDIR}/${SBINDIR}/poweroff - ln -sf ${DIR}/reboot ${DESTDIR}/${SBINDIR}/reboot - ln -sf ${DIR}/shutdown ${DESTDIR}/${SBINDIR}/shutdown - ln -sf openrc-init ${DESTDIR}/${SBINDIR}/init -endif -endif - -include ${MK}/scripts.mk diff --git a/scripts/halt.in b/scripts/halt.in deleted file mode 100644 index 209dc130..00000000 --- a/scripts/halt.in +++ /dev/null @@ -1,29 +0,0 @@ -#!/bin/sh - -option_arg= -poweroff_arg= -while getopts :nwdfiph opt; do - case "$opt" in - n) ;; - w) poweroff_arg=--write-only ;; - d) option_arg=--no-write ;; - f) ;; - i) ;; - p) poweroff_arg=--poweroff ;; - [?]) printf "%s\n" "${0##*/}: invalid command line option" >&2 - exit 1 - ;; - esac -done -shift $((OPTIND-1)) - -if [ -z "${poweroff_arg}" ]; then - poweroff_arg=--poweroff -fi - -script_args="$@" -if [ -z "${script_args}" ]; then - script_args=now -fi - -exec @SBINDIR@/openrc-shutdown ${option_arg} ${poweroff_arg} "${script_args}" diff --git a/scripts/meson.build b/scripts/meson.build deleted file mode 100644 index 07d38acc..00000000 --- a/scripts/meson.build +++ /dev/null @@ -1,45 +0,0 @@ -script_conf_data = configuration_data() -script_conf_data.set('SBINDIR', sbindir) - -script_dir = rc_libexecdir / 'bin' - -scripts_internal = [ - 'on_ac_power', - ] - -scripts_Linux = [ - 'rc-sstat.in', - ] - -scripts_sysvinit = [ - 'halt.in', - 'poweroff.in', - 'shutdown.in', - 'reboot.in', - ] - -install_data(scripts_internal, - install_dir : script_dir, - install_mode: 'rwxr-xr-x') - -if os == 'Linux' - foreach file : scripts_Linux - configure_file(input : file, - output : '@BASENAME@', - configuration : script_conf_data, - install_dir: script_dir, - install_mode: 'rwxr-xr-x') - endforeach - if get_option('sysvinit') - foreach file : scripts_sysvinit - configure_file(input : file, - output : '@BASENAME@', - configuration : script_conf_data, - install_dir: script_dir, - install_mode: 'rwxr-xr-x') - endforeach - endif -endif - -meson.add_install_script('meson_script_links.sh', rc_libexecdir, - sbindir) diff --git a/scripts/meson_script_links.sh b/scripts/meson_script_links.sh deleted file mode 100755 index f13e767d..00000000 --- a/scripts/meson_script_links.sh +++ /dev/null @@ -1,19 +0,0 @@ -#!/bin/sh - -set -e -set -u - -rc_libexecdir="$1" -sbindir="$2" -binaries=" halt poweroff rc-sstat reboot shutdown" -for f in $binaries; do - if [ -x "${DESTDIR}${rc_libexecdir}/bin/${f}" ]; then - ln -snf "${rc_libexecdir}/bin/${f}" \ - "${DESTDIR}${sbindir}/${f}" - fi -done -# sysvinit is active when halt exits -if [ -x "${DESTDIR}${rc_libexecdir}/bin/halt" ]; then - ln -snf "${sbindir}/openrc-init" \ - "${DESTDIR}${sbindir}/init" -fi diff --git a/scripts/on_ac_power b/scripts/on_ac_power deleted file mode 100755 index a4c1cf9c..00000000 --- a/scripts/on_ac_power +++ /dev/null @@ -1,47 +0,0 @@ -#!/bin/sh -# Detect AC power or not in a portable way -# Exit 0 if on AC power, 1 if not and 255 if we don't know how to work it out - -# Copyright (c) 2007-2015 The OpenRC Authors. -# See the Authors file at the top-level directory of this distribution and -# https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS -# -# This file is part of OpenRC. It is subject to the license terms in -# the LICENSE file found in the top-level directory of this -# distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE -# This file may not be copied, modified, propagated, or distributed -# except according to the terms contained in the LICENSE file. - -if [ -f /proc/acpi/ac_adapter/*/state ]; then - cat /proc/acpi/ac_adapter/*/state | while read line; do - case "$line" in - "state:"*"off-line") exit 128;; - esac - done -elif [ -d /sys/class/power_supply ]; then - for dir in /sys/class/power_supply/*/; do - [ "$(cat "${dir}/type")" != "Mains" ] && continue - [ "$(cat "${dir}/online")" = 0 ] && exit 128 - done -elif [ -f /proc/pmu/info ]; then - cat /proc/pmu/info | while read line; do - case "$line" in - "AC Power"*": 0") exit 128;; - esac - done -elif command -v envstat >/dev/null 2>&1; then - # NetBSD has envstat - envstat -d acpiacad0 2>/dev/null | while read line; do - case "$line" in - "connected:"*"OFF") exit 128;; - esac - done -elif sysctl -q hw.acpi.acline >/dev/null 2>/dev/null; then - case $(sysctl -n hw.acpi.acline) in - 0) exit 1;; - *) exit 0;; - esac -else - exit 255 -fi -[ $? != 128 ] diff --git a/scripts/poweroff.in b/scripts/poweroff.in deleted file mode 100644 index 4e944bdc..00000000 --- a/scripts/poweroff.in +++ /dev/null @@ -1,28 +0,0 @@ -#!/bin/sh - -option_arg= -poweroff_arg= -while getopts :nwdfiph opt; do - case "$opt" in - n) ;; - w) poweroff_arg=--write-only ;; - d) option_arg=--no-write ;; - f) ;; - i) ;; - [?]) printf "%s\n" "${0##*/}: invalid command line option" >&2 - exit 1 - ;; - esac -done -shift $((OPTIND-1)) - -if [ -z "${poweroff_arg}" ]; then - poweroff_arg=--poweroff -fi - -script_args="$@" -if [ -z "${script_args}" ]; then - script_args=now -fi - -exec @SBINDIR@/openrc-shutdown ${option_arg} ${poweroff_arg} "${script_args}" diff --git a/scripts/rc-sstat.in b/scripts/rc-sstat.in deleted file mode 100644 index 4811293d..00000000 --- a/scripts/rc-sstat.in +++ /dev/null @@ -1,149 +0,0 @@ -#!/bin/sh -# Copyright (c) 2015 The OpenRC Authors. -# See the Authors file at the top-level directory of this distribution and -# https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS -# -# This file is part of OpenRC. It is subject to the license terms in -# the LICENSE file found in the top-level directory of this -# distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE -# This file may not be copied, modified, propagated, or distributed -# except according to the terms contained in the LICENSE file. - -# Define variables -scandir="/run/openrc/s6-scan" -statfile=/dev/shm/s6-svstat.${USER} - -color_red='\E[01;31m' -color_green='\E[32m' -color_yellow='\E[01;33m' - -# Time Modules -uptimeModules() { - # Given a single integer argument representing seconds of uptime... - # convert uptime to a friendly human readable string: '2d 16h 58m 46s' - # define a variable to keep track of the longest length uptime string - uSec=${1:-0} - - uDay=$(( $uSec / 86400 )) - uSec=$(( $uSec % 86400 )) - uHour=$(( $uSec / 3600 )) - uSec=$(( $uSec % 3600 )) - uMin=$(( $uSec / 60 )) - uSec=$(( $uSec % 60 )) - - [ $uDay -ne 0 ] && pDay="${uDay}d " || pDay="" - [ $uHour -ne 0 ] && pHour="${uHour}h " || pHour="" - [ $uMin -ne 0 ] && pMin="${uMin}m " || pMin="" - [ $uSec -ne 0 ] && pSec="${uSec}s " || pSec="" - - parsedUptime="$( echo ${pDay}${pHour}${pMin}${pSec} | sed 's#[ \t]*$##' )" - uCharCount=${#parsedUptime} -} - -# Make sure we are running as root -if [ $(id -u) != 0 ]; then - printf "This command must be run as root\n" - exit 1 -fi - -# Make sure scandir exists -if [ ! -d $scandir ]; then - printf "%s\n" "$scandir does not exist" - exit 1 -fi - -# Make sure s6-svscan is running -if ! pgrep s6-svscan >/dev/null ; then - printf "s6-svscan is not running\n" - exit 1 -fi - -# If TERM is undefined (launching sstat through an ssh command) then make it vt100 -if [ -z $TERM -o $TERM = "dumb" ]; then - export TERM=vt100 -fi - -# Gather list of candidate services s6-supervise may be supervising -# filter for folders and symlinks at /run/openrc/s6-scan/* ommiting output starting with '.' -services="$(find $scandir -maxdepth 1 -mindepth 1 \( -type d -or -type l \) | awk -F'/' '{ if ( $NF !~ "^\\." ) print $NF}')" -if [ -z "$services" ]; then - printf "s6 found no services configured for supervision\n" - exit 1 -fi - -# Gather status for each service from s6-svstat -# write to tmp file in memory for non I/O bound repeatative access -rm -f $statfile 2>/dev/null -for service in $services ; do - echo "$service $(s6-svstat ${scandir}/${service})" >> $statfile -done - -# Define longest string from parsed uptime (default to 7 to match string length of 'Up Time') -timeStringLength=7 -for uptime in $(awk '$2 == "up" {print $5}' $statfile | sort -run) -do - uptimeModules $uptime - [ ${uCharCount} -gt $timeStringLength ] && timeStringLength=$uCharCount -done - - -# Print the status header like so... -# Service Name State PID Up Time Start Time -#---------------------------- ----- ----- -------------- ------------------- -printf "\n" -printf "%28s %5s %5s %${timeStringLength}s %19s\n" "Service Name" "State" "PID" "Up Time" "Start Time" -for dashes in 28 5 5 $timeStringLength 19 ; do - printf "%0.s-" $(seq 1 $dashes) ; echo -n ' ' -done && printf "\n" - - -# sshd up (pid 26300) 80373 seconds -cat $statfile | \ -while read line -do - set $line - - service=$1 - state=$2 - pid=${4/)/} - time=$5 - - # call function to convert time in seconds and define additional variables - uptimeModules $time - - if [ "$state" = up ]; then - if [ $time -lt 30 ]; then - # uptime < 30 seconds, color the whole line yellow - echo -en "$color_yellow" - # 1st 4 columns are printed with printf for space padding - printf "%28s %5s %5s %${timeStringLength}s" $service $state $pid "$parsedUptime" - # 4th column is output from date -d - echo -e " $(date -d "${time} seconds ago" "+%F %T")" - # reset terminal colors - tput sgr0 - else - printf "%28s" $service - # uptime > 30 seconds, color just the "state" value green - echo -en "$color_green" - printf " %5s" $state - # reset terminal colors - tput sgr0 - printf " %5s" $pid - printf " %${timeStringLength}s" "$parsedUptime" - echo -e " $(date -d "${time} seconds ago" "+%F %T")" - fi - else - printf "%28s" $service - echo -en "$color_red" - printf " %5s" $state - tput sgr0 - echo "" - fi -done - -# Cleanup -rm -f $statfile 2>/dev/null - -printf "\n\n" - -rc-status diff --git a/scripts/reboot.in b/scripts/reboot.in deleted file mode 100644 index bf50967a..00000000 --- a/scripts/reboot.in +++ /dev/null @@ -1,30 +0,0 @@ -#!/bin/sh - -option_arg= -poweroff_arg= -while getopts :nwdfhik opt; do - case "$opt" in - n) ;; - w) poweroff_arg=--write-only ;; - d) option_arg=--no-write ;; - f) ;; - h) ;; - i) ;; - k) poweroff_arg=--kexec ;; - [?]) printf "%s\n" "${0##*/}: invalid command line option" >&2 - exit 1 - ;; - esac -done -shift $((OPTIND-1)) - -if [ -z "${poweroff_arg}" ]; then - poweroff_arg=--reboot -fi - -script_args="$@" -if [ -z "${script_args}" ]; then - script_args=now -fi - -exec @SBINDIR@/openrc-shutdown ${option_arg} ${poweroff_arg} "${script_args}" diff --git a/scripts/shutdown.in b/scripts/shutdown.in deleted file mode 100644 index 23e5e31d..00000000 --- a/scripts/shutdown.in +++ /dev/null @@ -1,46 +0,0 @@ -#!/bin/sh - -do_halt=false -while getopts :akrhPHfFnct: opt; do - case "$opt" in - a) ;; - k) ;; - r) - shutdown_arg=--reboot - ;; - h) - do_halt=true - shutdown_arg=--poweroff - ;; - P) - if ! ${do_halt}; then - printf "%s\n" "The -P flag requires the -h flag" >&2 - exit 1 - fi - shutdown_arg=--poweroff - ;; - H) - if ! ${do_halt}; then - printf "%s\n" "The -H flag requires the -h flag" >&2 - exit 1 - fi - shutdown_arg=--halt - ;; - f) ;; - F) ;; - n) ;; - c) ;; - t) ;; - [?]) printf "%s\n" "${0##*/}: invalid command line option" >&2 - exit 1 - ;; - esac -done -shift $((OPTIND-1)) - -if [ -z "${shutdown_arg}" ]; then - shutdown_arg=--single -fi - -printf "%s %s\n" "@SBINDIR@/openrc-shutdown ${shutdown_arg}" "$@" -exec @SBINDIR@/openrc-shutdown ${shutdown_arg} "$@" |