diff options
author | Hans-Christoph Steiner <eighthave@users.sourceforge.net> | 2006-04-11 05:44:37 +0000 |
---|---|---|
committer | Hans-Christoph Steiner <eighthave@users.sourceforge.net> | 2006-04-11 05:44:37 +0000 |
commit | aba52d5042d729b91e8345e88cea48980d6cfe95 (patch) | |
tree | d1bd8666e1afa21d88c92205bd8e4106b3bafde3 /scripts | |
parent | 5ee5e6584d82c1884d20845bbee04786640b51a7 (diff) |
properly working debian startup/shutdown script. Pd is now a daemon! We just need sysloggin...
svn path=/trunk/; revision=4875
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/debian/default/pd | 8 | ||||
-rwxr-xr-x | scripts/debian/init.d/pd (renamed from scripts/init.d/pd) | 83 |
2 files changed, 70 insertions, 21 deletions
diff --git a/scripts/debian/default/pd b/scripts/debian/default/pd new file mode 100644 index 00000000..d4801312 --- /dev/null +++ b/scripts/debian/default/pd @@ -0,0 +1,8 @@ +# this needs to be "yes" for it to start automatically +RUNPDDAEMON=yes + +# load your patches here +OPTIONS="-open /home/hans/cvs/pure-data/doc/tutorials/networking/chat-server.pd" + + + diff --git a/scripts/init.d/pd b/scripts/debian/init.d/pd index e67f6dce..70cae357 100755 --- a/scripts/init.d/pd +++ b/scripts/debian/init.d/pd @@ -21,37 +21,82 @@ # .hc <hans@at.or.at> # +set -e + PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin -DAEMON=/usr/bin/pd -NAME=pd DESC="Pure Data" +NAME=pd +DAEMON=/usr/local/bin/$NAME +PIDFILE=/var/run/$NAME.pid +SCRIPTNAME=/etc/init.d/$NAME +# Gracefully exit if the package has been removed. test -x $DAEMON || exit 0 +# options +RUNPDDAEMON=no +USER=nobody +PORT=34985 + +# Read config file if it is present. +if [ -r /etc/default/$NAME ] +then + . /etc/default/$NAME +fi + +if [ "$RUNPDDAEMON" != "yes" ];then + echo "Pd not configured to run as a daemon. Edit /etc/default/$NAME." + exit 1 +fi + +if [ "x$USER" = "x" ] +then + echo "Error: empty USER name" + exit 1 +fi + +PARAMS="-nogui -noaudio -nomidi $OPTIONS" -function start() { - /bin/su - arw -c "/usr/bin/pd -nogui" > /tmp/pd-`date +20%y-%m-%d_%H.%M.%S`.log 2>&1 & +# for the log file +DATE=`date +20%y-%m-%d_%H.%M.%S` + +# +# Function that starts the daemon/service. +# +d_start() { +# /bin/su - arw -c "/usr/bin/pd -nogui" > /tmp/pd-`date +20%y-%m-%d_%H.%M.%S`.log 2>&1 & + start-stop-daemon -v --start --quiet --background --make-pidfile \ + --chuid $USER --pidfile $PIDFILE --exec $DAEMON -- $PARAMS } -function stop() { - echo "quit;quit;quit;" | /usr/bin/pdsend 5555 - sleep 5 - /usr/bin/killall -KILL pd || echo "Warning: $DESC was not running" +# +# Function that stops the daemon/service. +# +d_stop() { + start-stop-daemon --stop --quiet --pidfile $PIDFILE \ + --user $USER --name $NAME --retry 5 +# echo "quit;quit;quit;" | /usr/bin/pdsend $PORT +# sleep 5 +# /usr/bin/killall -KILL pd || echo "Warning: $DESC was not running" +} + +# +# Function that sends a SIGHUP to the daemon/service. +# +d_reload() { + start-stop-daemon --stop --quiet --pidfile $PIDFILE \ + --name $NAME --signal 1 } case "$1" in start) echo -n "Starting $DESC: $NAME" - start - #start-stop-daemon --start --quiet --pidfile /var/run/$NAME.pid \ - # --exec $DAEMON + d_start echo "." ;; stop) echo -n "Stopping $DESC: $NAME " - stop - #start-stop-daemon --stop --quiet --pidfile /var/run/$NAME.pid \ - # --exec $DAEMON + d_stop echo "." ;; #reload) @@ -74,13 +119,9 @@ case "$1" in # just the same as "restart". # echo -n "Restarting $DESC: $NAME" - stop - #start-stop-daemon --stop --quiet --pidfile \ - # /var/run/$NAME.pid --exec $DAEMON - sleep 5 - start - #start-stop-daemon --start --quiet --pidfile \ - # /var/run/$NAME.pid --exec $DAEMON + d_stop + sleep 1 + d_start echo "." ;; *) |