From 552557b97ebac415f31c87ba5d8af621e2d4de6f Mon Sep 17 00:00:00 2001
From: Hans-Christoph Steiner <eighthave@users.sourceforge.net>
Date: Thu, 18 Mar 2010 01:17:31 +0000
Subject: more changes to separate 'pd-extended' files from 'puredata' files

svn path=/trunk/; revision=13224
---
 packages/linux_make/Makefile            |   9 +-
 packages/linux_make/pd-extended.desktop |   2 +-
 scripts/debian/default/pd-extended      |  12 +++
 scripts/debian/init.d/pd-extended       | 150 ++++++++++++++++++++++++++++++++
 4 files changed, 169 insertions(+), 4 deletions(-)
 create mode 100644 scripts/debian/default/pd-extended
 create mode 100755 scripts/debian/init.d/pd-extended

diff --git a/packages/linux_make/Makefile b/packages/linux_make/Makefile
index a1bdaf78..0ea80135 100755
--- a/packages/linux_make/Makefile
+++ b/packages/linux_make/Makefile
@@ -104,11 +104,11 @@ deb: $(bindir)
 	install -p -m0644 $(scripts_src)/bash_completion/pd \
 		$(DESTDIR)/etc/bash_completion.d
 	install -d $(DESTDIR)/etc/default
-	install -p -m0644 $(scripts_src)/debian/default/pd 
+	install -p -m0644 $(scripts_src)/debian/default/pd-extended \
 		$(DESTDIR)/etc/default
 	install -d $(DESTDIR)/etc/init.d
-	install -p -m0644 $(scripts_src)/debian/init.d/pd \
-		$(DESTDIR)/etc/init.d
+	install -p -m0644 $(scripts_src)/debian/init.d/pd-extended \
+		$(DESTDIR)/etc/init.d/
 # default prefs file
 	install -d $(DESTDIR)/etc/pd-extended
 	ln -s $(libpddir)/default.pdsettings \
@@ -121,6 +121,9 @@ deb: $(bindir)
 # Pd-related scripts
 	install -p $(scripts_src)/pd-diff $(DESTDIR)$(bindir)
 	install -p $(scripts_src)/config-switcher.sh $(DESTDIR)$(bindir)
+# rename pd executable
+	mv $(DESTDIR)$(bindir)/pd $(DESTDIR)$(bindir)/pd-extended
+	ln -s $(bindir)/pd-extended $(DESTDIR)$(bindir)/pd
 # debian packaging
 	test -d $(DESTDIR)/DEBIAN || mkdir -p $(DESTDIR)/DEBIAN
 	cp $(packages_src)/linux_make/debian/control $(DESTDIR)/DEBIAN
diff --git a/packages/linux_make/pd-extended.desktop b/packages/linux_make/pd-extended.desktop
index 22916ed9..eeb92270 100644
--- a/packages/linux_make/pd-extended.desktop
+++ b/packages/linux_make/pd-extended.desktop
@@ -9,7 +9,7 @@ Comment[es]=Plataforma de programaci
 Comment[fr]=Plateforme de programmation visuelle pour applications multim�dia
 Comment[it]=Piattaforma di programmazione visuale per applicazioni multimedia
 Comment[pt]=Plataforma de programa��o visuais para multimedia
-Exec=/usr/bin/pd %F
+Exec=/usr/bin/pd-extended %F
 Terminal=false
 Type=Application
 Icon=pd
diff --git a/scripts/debian/default/pd-extended b/scripts/debian/default/pd-extended
new file mode 100644
index 00000000..0d5e11b8
--- /dev/null
+++ b/scripts/debian/default/pd-extended
@@ -0,0 +1,12 @@
+# this needs to be "yes" for it to start automatically
+#RUNPDDAEMON=yes
+
+# if your Pd-extended is installed elsewhere, set the correct location
+#DAEMON=/usr/bin/pd-extended
+
+# load your patches here
+#OPTIONS="-nogui -open /home/hans/cvs/pure-data/doc/tutorials/networking/chat-server.pd"
+
+# if you want to use a different user.  AVOID USING "root"! Pd is not secure!
+#USER=nobody
+
diff --git a/scripts/debian/init.d/pd-extended b/scripts/debian/init.d/pd-extended
new file mode 100755
index 00000000..bee98768
--- /dev/null
+++ b/scripts/debian/init.d/pd-extended
@@ -0,0 +1,150 @@
+#! /bin/sh
+### BEGIN INIT INFO
+# Provides:          pd
+# Required-Start:    $remote_fs
+# Required-Stop:     $remote_fs
+# Default-Start:     2 3 4 5
+# Default-Stop:      0
+# Short-Description: Pure Data
+# Description:       Pure Data realtime graphical programming environment.
+### END INIT INFO
+
+# Author: Hans-Christoph Steiner <hans@eds.org>
+
+# Do NOT "set -e"
+
+# PATH should only include /usr/* if it runs after the mountnfs.sh script
+PATH=/sbin:/usr/sbin:/bin:/usr/bin
+DESC="Pd-extended"
+NAME=pd-extended
+DAEMON=/usr/bin/$NAME
+#DAEMON_ARGS="--options args"
+PIDFILE=/var/run/$NAME.pid
+SCRIPTNAME=/etc/init.d/$NAME
+
+# options
+RUNPDDAEMON=no
+USER=nobody
+#PORT=34985
+
+# this is meant for running Pd as a server, so it turns off everything
+PARAMS="-nogui -noaudio -nomidi $OPTIONS"
+
+# Exit if the package is not installed
+[ -x "$DAEMON" ] || exit 0
+
+# Read configuration variable file if it is present
+[ -r /etc/default/$NAME ] && . /etc/default/$NAME
+
+# Load the VERBOSE setting and other rcS variables
+. /lib/init/vars.sh
+
+# Define LSB log_* functions.
+# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
+. /lib/lsb/init-functions
+
+#
+# Function that starts the daemon/service
+#
+do_start() {
+# if you want a log, use this line (until Pd gets syslog support)
+#	 /bin/su - $USER -c "$DAEMON $PARAMS" > /tmp/pd-$DATE.log 2>&1 &
+	start-stop-daemon -v --start --quiet --background --make-pidfile \
+		 --chuid $USER --pidfile $PIDFILE --exec $DAEMON -- $PARAMS
+}
+
+#
+# Function that stops the daemon/service
+#
+do_stop()
+{
+	# Return
+	#   0 if daemon has been stopped
+	#   1 if daemon was already stopped
+	#   2 if daemon could not be stopped
+	#   other if a failure occurred
+	start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
+	RETVAL="$?"
+	[ "$RETVAL" = 2 ] && return 2
+	# Wait for children to finish too if this is a daemon that forks
+	# and if the daemon is only ever run from this initscript.
+	# If the above conditions are not satisfied then add some other code
+	# that waits for the process to drop all resources that could be
+	# needed by services started subsequently.  A last resort is to
+	# sleep for some time.
+	start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
+	[ "$?" = 2 ] && return 2
+	# Many daemons don't delete their pidfiles when they exit.
+	rm -f $PIDFILE
+	return "$RETVAL"
+}
+
+#
+# Function that sends a SIGHUP to the daemon/service
+#
+do_reload() {
+	#
+	# If the daemon can reload its configuration without
+	# restarting (for example, when it is sent a SIGHUP),
+	# then implement that here.
+	#
+	start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
+	return 0
+}
+
+case "$1" in
+  start)
+	[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
+	do_start
+	case "$?" in
+		0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
+		2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
+	esac
+	;;
+  stop)
+	[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
+	do_stop
+	case "$?" in
+		0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
+		2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
+	esac
+	;;
+  #reload|force-reload)
+	#
+	# If do_reload() is not implemented then leave this commented out
+	# and leave 'force-reload' as an alias for 'restart'.
+	#
+	#log_daemon_msg "Reloading $DESC" "$NAME"
+	#do_reload
+	#log_end_msg $?
+	#;;
+  restart|force-reload)
+	#
+	# If the "reload" option is implemented then remove the
+	# 'force-reload' alias
+	#
+	log_daemon_msg "Restarting $DESC" "$NAME"
+	do_stop
+	case "$?" in
+	  0|1)
+		do_start
+		case "$?" in
+			0) log_end_msg 0 ;;
+			1) log_end_msg 1 ;; # Old process is still running
+			*) log_end_msg 1 ;; # Failed to start
+		esac
+		;;
+	  *)
+	  	# Failed to stop
+		log_end_msg 1
+		;;
+	esac
+	;;
+  *)
+	#echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
+	echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
+	exit 3
+	;;
+esac
+
+:
-- 
cgit v1.2.1