2024-02-03 18:09:40 +01:00
|
|
|
#!/bin/sh
|
2024-02-03 18:24:46 +01:00
|
|
|
# WARN: this will clobber logfiles
|
2024-02-03 18:09:40 +01:00
|
|
|
|
|
|
|
LOGFILE="${LOGFILE:-${HOME}/.local/log/${1}.log}"
|
|
|
|
BOLD="$(tput bold)"
|
|
|
|
RED="$(tput setaf 1)"
|
|
|
|
GREEN="$(tput setaf 2)"
|
|
|
|
NC="$(tput sgr0)"
|
|
|
|
|
|
|
|
infolog() {
|
|
|
|
while IFS= read -r line; do
|
2024-02-03 18:24:46 +01:00
|
|
|
echo "[$(date +%X)][${BOLD}${GREEN}INF${NC}][$1] $line" >"${LOGFILE}"
|
2024-02-03 18:09:40 +01:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
errorlog() {
|
|
|
|
while IFS= read -r line; do
|
2024-02-03 18:24:46 +01:00
|
|
|
echo "[$(date +%X)][${BOLD}${RED}ERR${NC}][$1] $line" >"${LOGFILE}"
|
2024-02-03 18:09:40 +01:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
start() {
|
|
|
|
stdout="$XDG_RUNTIME_DIR/dwm-stdout"
|
|
|
|
stderr="$XDG_RUNTIME_DIR/dwm-stderr"
|
|
|
|
[ -p "$stdout" ] || mkfifo "$stdout"
|
|
|
|
[ -p "$stderr" ] || mkfifo "$stderr"
|
|
|
|
cat <"$stdout" | infolog "$1" &
|
|
|
|
cat <"$stderr" | errorlog "$1" &
|
|
|
|
pidof -sx "$1" || "$@" >"$stdout" 2>"$stderr"
|
|
|
|
}
|
|
|
|
|
|
|
|
start "$@"
|