#!/bin/sh # # distccd - A distributed compilation server. # # # chkconfig: - 80 20 # description: distccd - distcc distributed compilation server # ### BEGIN INIT INFO # Provides: distccd # Required-Start: $network $syslog $local_fs # Required-Stop: $network $syslog $local_fs # Default-Stop: 0 1 2 6 # Short-Description: Distributed C/C++ Compilation Server # Description: distcc is a program to distribute compilation of C or C++ # code across several machines on a network. distcc should # always generate the same results as a local compile, is # simple to install and use, and is often two or more times # faster than a local compile. ### END INIT INFO # Source function library. . /etc/rc.d/init.d/functions exec="/usr/bin/distccd" prog="distccd" # Default variables SYSCONFIG="/etc/sysconfig/distccd" OPTIONS="" USER="nobody" DISTCCPATH="$PATH" [ -e /etc/sysconfig/$prog ] && . /etc/sysconfig/$prog lockfile=/var/lock/subsys/$prog start() { [ -x $exec ] || exit 5 [ -z "$OPTIONS" ] && exit 6 echo -n $"Starting $prog: " DISTCCD_PATH="$DISTCCPATH" $prog --daemon --user "$USER" $OPTIONS && success || failure retval=$? echo [ $retval -eq 0 ] && touch $lockfile return $retval } stop() { echo -n $"Stopping $prog: " killproc $prog retval=$? echo [ $retval -eq 0 ] && rm -f $lockfile return $retval } restart() { stop start } reload() { restart } force_reload() { restart } rh_status() { # run checks to determine if the service is running or use generic status status $prog } rh_status_q() { rh_status >/dev/null 2>&1 } case "$1" in start) rh_status_q && exit 0 $1 ;; stop) rh_status_q || exit 0 $1 ;; restart) $1 ;; reload) rh_status_q || exit 7 $1 ;; force-reload) force_reload ;; status) rh_status ;; condrestart|try-restart) rh_status_q || exit 0 restart ;; *) echo $"Usage: $0 {start|stop|status|restart|try-restart|reload|force-reload}" exit 2 esac exit $?