Clean up the invirt-console-server init script with some ideas from
authorEvan Broder <broder@mit.edu>
Sat, 22 Nov 2008 10:36:22 +0000 (05:36 -0500)
committerEvan Broder <broder@mit.edu>
Sat, 22 Nov 2008 10:36:22 +0000 (05:36 -0500)
debathena-pyhesiodfs

svn path=/trunk/packages/invirt-console-server/; revision=1741

debian/changelog
debian/invirt-console-server.init

index 13f29f2..dec5b18 100644 (file)
@@ -1,3 +1,9 @@
+invirt-console-server (0.1.1) unstable; urgency=low
+
+  * Clean up the init script with some ideas from debathena-pyhesiodfs.
+
+ -- Evan Broder <broder@mit.edu>  Sat, 22 Nov 2008 05:25:54 -0500
+
 invirt-console-server (0.1.0) unstable; urgency=low
 
   * Add real caching to consolefs
 invirt-console-server (0.1.0) unstable; urgency=low
 
   * Add real caching to consolefs
index 3b60f73..17e44bb 100755 (executable)
@@ -18,7 +18,8 @@ PATH=/sbin:/usr/sbin:/bin:/usr/bin
 DESC="the Invirt console server"
 NAME=invirt-console-server
 DAEMON=/usr/bin/invirt-consolefs
 DESC="the Invirt console server"
 NAME=invirt-console-server
 DAEMON=/usr/bin/invirt-consolefs
-DAEMON_ARGS="/consolefs"
+MOUNTPOINT="/consolefs"
+DAEMON_ARGS="-f $MOUNTPOINT"
 PIDFILE=/var/run/$NAME.pid
 SCRIPTNAME=/etc/init.d/$NAME
 
 PIDFILE=/var/run/$NAME.pid
 SCRIPTNAME=/etc/init.d/$NAME
 
@@ -55,10 +56,17 @@ do_start()
     #   0 if daemon has been started
     #   1 if daemon was already running
     #   2 if daemon could not be started
     #   0 if daemon has been started
     #   1 if daemon was already running
     #   2 if daemon could not be started
-    modprobe fuse
+    
+    # Try to make sure fuse is setup
+    [ -e /dev/fuse ] || modprobe fuse || return 2
+    
+    if cat /proc/mounts | grep " $MOUNTPOINT " >/dev/null 2>&1; then
+        return 1
+    fi
+    
     gen_config
     gen_config
-    daemon --running -n $NAME && return 1
-    daemon -r -O daemon.info -E daemon.err -n $NAME -U $DAEMON $DAEMON_ARGS || return 2
+    
+    daemon -r -O daemon.info -E daemon.err -n $NAME -- $DAEMON $DAEMON_ARGS || return 2
 }
 
 #
 }
 
 #
@@ -71,13 +79,16 @@ do_stop()
     #   1 if daemon was already stopped
     #   2 if daemon could not be stopped
     #   other if a failure occurred
     #   1 if daemon was already stopped
     #   2 if daemon could not be stopped
     #   other if a failure occurred
+    
+    if ! cat /proc/mounts | grep " $MOUNTPOINT " >/dev/null 2>&1; then
+        return 1
+    fi
+    
     daemon --stop -n $NAME
     RETVAL="$?"
     [ "$RETVAL" = 2 ] && return 2
     # Many daemons don't delete their pidfiles when they exit.
     rm -f $PIDFILE
     daemon --stop -n $NAME
     RETVAL="$?"
     [ "$RETVAL" = 2 ] && return 2
     # Many daemons don't delete their pidfiles when they exit.
     rm -f $PIDFILE
-    umount "$DAEMON_ARGS"
-    return "$RETVAL"
 }
 
 do_reload()
 }
 
 do_reload()