| Index: experimental/webtry/sys/webtry_init | 
| diff --git a/experimental/webtry/sys/webtry_init b/experimental/webtry/sys/webtry_init | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..359e19e46c4db49653acaebcaa2319c4181420e4 | 
| --- /dev/null | 
| +++ b/experimental/webtry/sys/webtry_init | 
| @@ -0,0 +1,159 @@ | 
| +#! /bin/sh | 
| +### BEGIN INIT INFO | 
| +# Provides:          webtry | 
| +# Required-Start:    $remote_fs $syslog | 
| +# Required-Stop:     $remote_fs $syslog | 
| +# Default-Start:     2 3 4 5 | 
| +# Default-Stop:      0 1 6 | 
| +# Short-Description: Start webtry. | 
| +# Description:       Web server for trying Skia C++ code. | 
| +### END INIT INFO | 
| + | 
| +# Author: Joe Gregorio <jcgregorio@google.com> | 
| +# | 
| +# Copied from /etc/init.d/skeleton and modified only the following | 
| +# environment variables and updated the start-stop-daemon calls | 
| +# in do_start() to add --make-pidfile, --background, and --chuid. | 
| + | 
| +# 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="The Skia webtry application." | 
| +NAME=webtry | 
| +DAEMON=/home/webtry/skia/experimental/webtry/$NAME | 
| +DAEMON_ARGS="--use_chroot" | 
| +PIDFILE=/var/run/$NAME.pid | 
| +SCRIPTNAME=/etc/init.d/$NAME | 
| + | 
| +# 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.2-14) to ensure that this file is present | 
| +# and status_of_proc is working. | 
| +. /lib/lsb/init-functions | 
| + | 
| +# | 
| +# Function that starts the daemon/service | 
| +# | 
| +do_start() | 
| +{ | 
| +	# Return | 
| +	#   0 if daemon has been started | 
| +	#   1 if daemon was already running | 
| +	#   2 if daemon could not be started | 
| +	start-stop-daemon --start --pidfile $PIDFILE --exec $DAEMON --make-pidfile --background --chuid webtry --test > /dev/null \ | 
| +		|| return 1 | 
| +	start-stop-daemon --start --pidfile $PIDFILE --exec $DAEMON --make-pidfile --background --chuid webtry --exec $DAEMON -- \ | 
| +		$DAEMON_ARGS \ | 
| +		|| return 2 | 
| +	# Add code here, if necessary, that waits for the process to be ready | 
| +	# to handle requests from services started subsequently which depend | 
| +	# on this one.  As a last resort, sleep for some time. | 
| +} | 
| + | 
| +# | 
| +# 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 | 
| +	;; | 
| +  status) | 
| +	status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $? | 
| +	;; | 
| +  #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|status|restart|force-reload}" >&2 | 
| +	exit 3 | 
| +	;; | 
| +esac | 
| + | 
| +: | 
|  |