summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--HISTORY8
-rw-r--r--README2
-rw-r--r--README.de2
-rwxr-xr-xrunvdr140
-rw-r--r--runvdr.conf.example30
5 files changed, 158 insertions, 24 deletions
diff --git a/HISTORY b/HISTORY
index c18a7a9..5d1f4e6 100644
--- a/HISTORY
+++ b/HISTORY
@@ -1,6 +1,14 @@
runvdr extreme Revision History
-------------------------------
+2009-06-28: Version 0.4.2
+- New: Support -i and --instance of VDR-1.7.4+
+- New: Command line option to set VDR_CHARSET_OVERRIDE of VDR 1.5.18+
+- New: Function-style callbacks for DVB load/unload commands (backwards compatible)
+- New: Option to always unload DVB drivers on exit
+- New: Callbacks for X-Server startup and shutdown to run additional programs
+- Fix: --lirc not working. Thx to caps!
+
2009-04-13: Version 0.4.1
- Fix: Parsing sysconfig file
- Fix: --xserver option not working, some weired options bugs fixed
diff --git a/README b/README
index dbf0965..5862f76 100644
--- a/README
+++ b/README
@@ -56,7 +56,7 @@ also available on command line, see --help.
For the init-script (Debian):
- Copy init.d.runvdr.Debian to /etc/init.d/runvdr
-- Use update-rc.d to set up startup runlevel
+- Use sysv-rc-conf or update-rc.d to set up startup runlevel
For runvdr-conf.d:
- Copy runvdr-conf.d to /usr/local/bin/
diff --git a/README.de b/README.de
index 84eb05d..09389cb 100644
--- a/README.de
+++ b/README.de
@@ -57,7 +57,7 @@ per Kommandozeile verfügbar, siehe runvdr --help.
Für das init-Skript (Debian):
- Kopiere init.d.runvdr.Debian nach /etc/init.d/runvdr
-- Benutze update-rc.d um die Start-Runlevel zu konfigurieren.
+- Benutze sysv-rc-conf oder update-rc.d um die Start-Runlevel zu konfigurieren.
Für runvdr-conf.d:
- Kopiere runvdr-conf.d nach /usr/local/bin/
diff --git a/runvdr b/runvdr
index 99a126f..b6f80cf 100755
--- a/runvdr
+++ b/runvdr
@@ -1,12 +1,28 @@
#!/bin/bash
#
-# runvdr extreme
+# runvdr extreme - configurable vdr launcher script
#
-# configurable vdr launcher script
+# Copyright (C) 2006-2009 by Udo Richter
#
-# by Udo Richter <udo_richter(a)gmx.de>
-# http://www.richter-udo.de/vdr/scripts.html#runvdr
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+# Or, point your browser to http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
+#
+# The author can be reached at <udo_richter(a)gmx.de>
+#
+# The project's page is at http://www.udo-richter.de/vdr/scripts.html#runvdr
+
RUNVDRCONF=""
@@ -35,6 +51,9 @@ SETTERM="setterm"
# --runvdr-pid=# RUNVDRPID location of runvdr.pid file
# --dvb-load=# DVBLOAD command to load DVB drivers
# --dvb-unload=# DVBUNLOAD command to unload DVB drivers
+# --dvb-unload-on-exit DVBUNLOADONEXIT do unload DVB drivers on exit
+# --x-startup=# XSTARTUP command executed after X startup
+# --x-shutdown=# XSHUTDOWN command executed before X shutdown
# --wrapper=# WRAPPER wrapper command for calling vdr
# --terminate[=#] TERMINATE Terminate runvdr by pid
# --wait[=#] WAIT Wait # seconds for --terminate to finish
@@ -45,6 +64,7 @@ SETTERM="setterm"
# --maxrestarts=# MAXRESTARTS Max number of rapid restarts before give-up
# --restarttime=# RESTARTTIME Max time for restart to be rapid
# --language=# LANGUAGE Locale to set for VDR
+# --charset-override=# VDR_CHARSET_OVERRIDE Override VDR charset
# -V --version VERSION print version information and exit
# -h --help HELP print this help and exit
#
@@ -59,6 +79,7 @@ SETTERM="setterm"
# -L # --lib # LIBDIR search for plugins in DIR (default is %s)
# --lirc #? LIRC use a LIRC remote control device, attached to PATH
# --localedir # LOCALEDIR search for locale files in DIR
+# -i # --instance # INSTANCE use ID as the id of this VDR instance
# -l # --log # LOGLEVEL set log level (default: 3)
# -m --mute MUTE mute audio of the primary DVB device at startup
# --no-kbd NOKBD don't use the keyboard as an input device
@@ -91,13 +112,14 @@ function ParseCommandLine_Step1() {
# Stores pre-processed options in $OPTIONS
# evaluates -C, --runvdr-conf and --xserver-proxy only
- SHORTOPT="a:c:C:dD:E:g:hl:L:mp:P:r:s:t:u:v:Vw:"
+ SHORTOPT="a:c:C:dD:E:g:hi:l:L:mp:P:r:s:t:u:v:Vw:"
LONGOPT="runvdr-conf:,xserver-proxy:,pluginsetup-conf:,setupplugin-conf:,vdr:,\
switchterminal:,maxrestarts:,restarttime:,xserver:,\
- runvdr-pid:,dvb-load:,dvb-unload:,language:,wrapper:,\
+ runvdr-pid:,dvb-load:,dvb-unload:,dvb-unload-on-exit,x-startup:,\
+ x-shutdown:,language:,charset-override:,wrapper:,\
term-timeout:,kill-timeout:,terminate::,restart::,dvb-restart::,\
wait::,audio:,config:,daemon,device:,epgfile:,grab:,help,lib:,lirc::,\
- log:,localedir:,mute,no-kbd,plugin:,port:,rcu::,record:,shutdown:,\
+ instance:,log:,localedir:,mute,no-kbd,plugin:,port:,rcu::,record:,shutdown:,\
terminal:,user:,userdump,version,vfat,video:,watchdog:"
# prepare all optios for later processing
@@ -117,7 +139,11 @@ function ParseCommandLine_Step1() {
--runvdr-pid) shift 2;;
--dvb-load) shift 2;;
--dvb-unload) shift 2;;
+ --dvb-unload-on-exit) shift ;;
+ --x-startup) shift 2;;
+ --x-shutdown) shift 2;;
--language) shift 2;;
+ --charset-override) shift 2;;
--wrapper) shift 2;;
--term-timeout) shift 2;;
--kill-timeout) shift 2;;
@@ -136,6 +162,7 @@ function ParseCommandLine_Step1() {
-D|--device) shift 2;;
-E|--epgfile) shift 2;;
-g|--grab) shift ;;
+ -i|--instance) shift 2;;
-l|--log) shift 2;;
-L|--lib) shift 2;;
--lirc) shift 2;;
@@ -177,7 +204,11 @@ function Clean() {
RUNVDRPID=
DVBLOAD=
DVBUNLOAD=
+ DVBUNLOADONEXIT=
+ XSTARTUP=
+ XSHUTDOWN=
LANGUAGE=
+ VDR_CHARSET_OVERRIDE=
WRAPPER=
TERMTIMEOUT=
KILLTIMEOUT=
@@ -196,6 +227,7 @@ function Clean() {
DVBDEVICE=()
EPGFILE=
GRAB=
+ INSTANCE=
LIBDIR=
LIRC=
LOGLEVEL=
@@ -277,7 +309,7 @@ function AddDevice() {
function AddParams() {
# Add to unparsed parameter list
for i ; do
- ADDPARAMS[${#ADDPARAMS[*]}]="$i"
+ ADDPARAMS[${#ADDPARAMS[*]}]="$i"
done
}
@@ -354,7 +386,11 @@ function ParseCommandLine_Step2() {
--runvdr-pid) RUNVDRPID="$2"; shift 2;;
--dvb-load) DVBLOAD="$2"; shift 2;;
--dvb-unload) DVBUNLOAD="$2"; shift 2;;
+ --dvb-unload-on-exit) DVBUNLOADONEXIT=1; shift ;;
+ --x-startup) XSTARTUP="$2"; shift 2;;
+ --x-shutdown) XSHUTDOWN="$2"; shift 2;;
--language) LANGUAGE="$2"; shift 2;;
+ --charset-override) VDR_CHARSET_OVERRIDE="$2"; shift 2;;
--wrapper) WRAPPER="$2"; shift 2;;
--term-timeout) TERMTIMEOUT="$2"; shift 2;;
--kill-timeout) KILLTIMEOUT="$2"; shift 2;;
@@ -374,6 +410,7 @@ function ParseCommandLine_Step2() {
-D|--device) AddDevice "$2"; shift 2;;
-E|--epgfile) EPGFILE="$2"; shift 2;;
-g|--grab) GRAB="1"; shift ;;
+ -i|--instance) INSTANCE="$2"; shift 2;;
-l|--log) LOGLEVEL="$2"; shift 2;;
-L|--lib) LIBDIR="$2"; shift 2;;
--lirc) LIRC="$2"; shift 2;;
@@ -405,7 +442,7 @@ function ParseCommandLine_Step2() {
# Add all remaining options directly to additional params
- AddParams "$@"
+ AddParams "$@"
return 0
}
@@ -426,8 +463,12 @@ runvdr Options:
--runvdr-pid=# location of runvdr.pid file
--dvb-load=# command to load DVB drivers
--dvb-unload=# command to unload DVB drivers
+--dvb-unload-on-exit do unload DVB drivers on exit
+--x-startup=# command executed after X startup
+--x-shutdown=# command executed before X shutdown
--wrapper=# wrapper command for calling vdr
--language=# Locale to set for VDR
+--charset-override=# Override VDR charset
--terminate[=#] Terminate runvdr by pid
--wait[=#] Wait # seconds for --terminate to finish
--restart[=#] Send restart signal by pid
@@ -449,6 +490,7 @@ Parsed VDR options:
Use '-x' to ignore device x from config file
-E # --epgfile=# write the EPG data into the given FILE. - to disable.
-g # --grab=# write images from the SVDRP command GRAB into the given DIR
+-i # --instance=# use ID as the id of this VDR instance
-L # --lib=# search for plugins in DIR
--lirc[=#] use a LIRC remote control device, attached to PATH
--localedir=# search for locale files in DIR
@@ -477,7 +519,7 @@ END-OF-HELP
function AddCommandLine() {
# Add all parameters to command line array
for params ; do
- VDRCOMMAND[${#VDRCOMMAND[*]}]="$params"
+ VDRCOMMAND[${#VDRCOMMAND[*]}]="$params"
done
}
@@ -512,12 +554,13 @@ function BuildCommand() {
[ -n "$EPGFILE" ] && AddCommandLine -E "$EPGFILE"
[ -n "$GRAB" ] && AddCommandLine -g "$GRAB"
+ [ -n "$INSTANCE" ] && AddCommandLine -i "$INSTANCE"
[ -n "$LOGLEVEL" ] && AddCommandLine -l "$LOGLEVEL"
[ -n "$LIBDIR" ] && AddCommandLine -L "$LIBDIR"
case "$LIRC" in
- 1|"") AddCommandLine --lirc";;
+ 1|"") AddCommandLine --lirc;;
0) ;;
- *) AddCommandLine --lirc=\"$LIRC\"";;
+ *) AddCommandLine --lirc="$LIRC";;
esac
[ -n "$LOCALEDIR" ] && AddCommandLine --localedir "$LOCALEDIR"
[ -n "$MUTE" ] && AddCommandLine -m
@@ -607,6 +650,41 @@ function WaitKill() {
echo failed.
}
+# Helper functions for callbacks
+
+function Do_DVBLOAD() {
+ if [ -n "$DVBLOAD" ] ; then
+ eval "$DVBLOAD"
+ elif [ "`type -t DVBLOAD`" = "function" ] ; then
+ DVBLOAD
+ fi
+}
+
+function Do_DVBUNLOAD() {
+ if [ -n "$DVBUNLOAD" ] ; then
+ eval "$DVBUNLOAD"
+ elif [ "`type -t DVBUNLOAD`" = "function" ] ; then
+ DVBUNLOAD
+ fi
+}
+
+function Do_XSTARTUP() {
+ if [ -n "$XSTARTUP" ] ; then
+ eval "$XSTARTUP"
+ elif [ "`type -t XSTARTUP`" = "function" ] ; then
+ XSTARTUP
+ fi
+}
+
+function Do_XSHUTDOWN() {
+ # X shutdown command
+ if [ -n "$XSHUTDOWN" ] ; then
+ eval "$XSHUTDOWN"
+ elif [ "`type -t XSHUTDOWN`" = "function" ] ; then
+ XSHUTDOWN
+ fi
+}
+
#### ---------------
@@ -619,6 +697,8 @@ ParseCommandLine_Step1 "$@" || exit 1
# Act as a proxy for calling VDR, from within X session
if [ -n "$XSERVERPROXY" ] ; then
+ # X startup command
+ Do_XSTARTUP
# Unpack proxy command line
eval "VDRCOMMAND=($VDRCOMMANDPROXY)"
"${VDRCOMMAND[@]}" &
@@ -626,6 +706,8 @@ if [ -n "$XSERVERPROXY" ] ; then
echo "PID $PID" > "$XSERVERPROXY"
wait $PID
echo "RET $?" >> "$XSERVERPROXY"
+ # X shutdown command
+ Do_XSHUTDOWN
exit 0
fi
@@ -645,7 +727,7 @@ if [ -n "$HELP" ] ; then
fi
if [ -n "$VERSION" ] ; then
- echo "runvdr extreme version 0.4.0"
+ echo "runvdr extreme version 0.4.2"
exit 0
fi
@@ -726,7 +808,7 @@ fi
# Load driver if it hasn't been loaded already:
-eval "$DVBLOAD"
+Do_DVBLOAD
# Count how often VDR terminated very quickly
SHORTRUNTIMES=0
@@ -775,6 +857,10 @@ while (true) do
# Pack command array into single env string:
export VDRCOMMANDPROXY=`printf '%q ' "${VDRCOMMAND[@]}"`
+ export XSTARTUP
+ export XSHUTDOWN
+ [ "`type -t XSTARTUP`" = "function" ] && export -f XSTARTUP
+ [ "`type -t XSHUTDOWN`" = "function" ] && export -f XSHUTDOWN
# Fire up X server that calls back runvdr, and run into XSERVERPROXY there
eval "xinit \""$0"\" --xserver-proxy=\""$PROXYFILE"\" -- $XSERVER &"
@@ -822,6 +908,12 @@ while (true) do
# Kill remaining VDR traces
WaitKill $PID $VDRPRG $TERMTIMEOUT $KILLTIMEOUT
+ # Wait for X server to be down too
+ [ "$XSERVERPID" ] && wait "$XSERVERPID"
+
+ # Unload DVB drivers requested?
+ [ -n "$DVBUNLOADONEXIT" ] && Do_DVBUNLOAD
+
# and exit
break
;;
@@ -846,8 +938,8 @@ while (true) do
[ "$XSERVERPID" ] && wait "$XSERVERPID"
# reload DVB stuff
- eval "$DVBUNLOAD"
- eval "$DVBLOAD"
+ Do_DVBUNLOAD
+ Do_DVBLOAD
;;
*) # Non-signal termination
if [ $RET -eq 0 -o $RET -eq 2 ] ; then
@@ -856,6 +948,12 @@ while (true) do
# Kill remaining VDR traces
WaitKill $PID $VDRPRG $TERMTIMEOUT $KILLTIMEOUT
+ # Wait for X server to be down too
+ [ "$XSERVERPID" ] && wait "$XSERVERPID"
+
+ # Unload DVB drivers requested?
+ [ -n "$DVBUNLOADONEXIT" ] && Do_DVBUNLOAD
+
# and exit
break
fi
@@ -865,6 +963,12 @@ while (true) do
# Kill remaining VDR traces
WaitKill $PID $VDRPRG $TERMTIMEOUT $KILLTIMEOUT
+ # Wait for X server to be down too
+ [ "$XSERVERPID" ] && wait "$XSERVERPID"
+
+ # Unload DVB drivers requested?
+ [ -n "$DVBUNLOADONEXIT" ] && Do_DVBUNLOAD
+
# and exit
break;
fi
@@ -877,8 +981,8 @@ while (true) do
[ "$XSERVERPID" ] && wait "$XSERVERPID"
# reload DVB
- eval "$DVBUNLOAD"
- eval "$DVBLOAD"
+ Do_DVBUNLOAD
+ Do_DVBLOAD
# and loop
;;
diff --git a/runvdr.conf.example b/runvdr.conf.example
index f22aac0..251eb09 100644
--- a/runvdr.conf.example
+++ b/runvdr.conf.example
@@ -32,11 +32,15 @@ VDRPRG="/usr/local/bin/vdr"
# Command to load the DVB drivers
# DVBLOAD will be launched before VDR starts and whenever the drivers
# need to be reloaded.
-DVBLOAD=''
+#function DVBLOAD() {
+# modprobe ....
+#}
# Command to unload the DVB drivers
# DVBUNLOAD will be launched whenever the drivers need to be reloaded.
-DVBUNLOAD=''
+#function DVBUNLOAD() {
+# rmmod ....
+#}
# Use VIDEODIR as video directory. The default is /video.
VIDEODIR="/video"
@@ -78,7 +82,7 @@ AddPlugin
AddPlugin
# Search for plugins in directory LIBDIR. Default is ./PLUGINS/lib.
-LIBDIR=
+LIBDIR=""
# If you use PluginSetup: Where is the the plugin_setup_runvdr.conf file?
# PLUGINSETUPCONF="$CONFIGDIR/plugins/plugin_setup_runvdr.conf"
@@ -164,12 +168,23 @@ VFAT=
# Fire up own X server as output device
# XSERVER="/usr/bin/X -nolisten tcp -config /etc/X11/xorg-runvdr.conf :0"
+# X startup commands, called within the X server
+#function XSTARTUP() {
+# while true ; do sleep 5; vdr-sxfe; done &
+# SXFEPID=$!
+#}
+
+# X shutdown commands, called within the X server
+#function XSHUTDOWN() {
+# kill $SXFEPID
+#}
+
# Store PID of runvdr into a file?
# RUNVDRPID=~/.runvdr.pid
RUNVDRPID=/var/run/runvdr.pid
# Set the controlling terminal. For example, /dev/tty8
-TERMINAL=/dev/tty8
+TERMINAL="/dev/tty8"
# Switch console to some terminal? Needs terminal number.
# For example, SWITCHTERMINAL=8
@@ -179,6 +194,9 @@ SWITCHTERMINAL=8
# This affects sort options in recordings.
# LANGUAGE="de_DE@euro"
+# Set character set that VDR shoud use
+# VDR_CHARSET_OVERRIDE="ISO-8859-15"
+
# If VDR restarts automatically, only do this number of restarts before giving up
# Setting this to 0 will cancel any restart attempt of VDR
MAXRESTARTS=5
@@ -187,6 +205,10 @@ MAXRESTARTS=5
# Setting this to 0 will never count restarts, and VDR can restart forever
RESTARTTIME=10
+# Should we unload the DVB driver when finally exiting runvdr?
+# If not set, or set to 0, exit without unloading drivers
+DVBUNLOADONEXIT=
+
# Additional parameters to pass to VDR directly, without parsing:
# Add them without extra quoting, like AddParams -a -b -c "Some Parameter"
AddParams