Magellan Linux

Diff of /branches/magellan-next/include/mtools.minc

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 16 by niro, Thu Jun 2 17:44:13 2011 UTC revision 21 by niro, Thu Jun 2 22:39:08 2011 UTC
# Line 1  Line 1 
1  # $Header: /magellan-cvs/mage/include/mtools.minc,v 1.3 2008/02/10 12:13:56 niro Exp $  # $Id$
2    
3  # adds services to runlevels and starts them  # adds services to runlevels and starts them
4  # mstartservice service {/path/to/service_exec}  # mstartservice service {/path/to/service_exec}
# Line 7  mstartservice() Line 7  mstartservice()
7   local service="$1"   local service="$1"
8   local service_exec="$2"   local service_exec="$2"
9    
10     # only run if sysV init was found
11     if [[ ! -f /etc/rc.d/init.d/functions ]]
12     then
13     echo "sysV init not found, not adding service ${service} to runlevels!"
14     return
15     fi
16    
17   [[ -z ${service_exec} ]] && service_exec="$(which ${service})"   [[ -z ${service_exec} ]] && service_exec="$(which ${service})"
18    
19   # add service to default runlevels   # add service to default runlevels
# Line 35  mstopservice() Line 42  mstopservice()
42   local service="$1"   local service="$1"
43   local service_exec="$2"   local service_exec="$2"
44    
45   [[ -z ${service_exec} ]] && service_exec="$(which ${service} 2> /dev/null)"   # only run if sysV init was found
46     if [[ ! -f /etc/rc.d/init.d/functions ]]
47     then
48     echo "sysV init not found, not adding service ${service} to runlevels!"
49     return
50     fi
51    
52     [[ -z ${service_exec} ]] && service_exec="$(which ${service})"
53    
54   # only stop the service if ${service_exec} does not exist   # only stop the service if ${service_exec} does not exist
55   [[ -f ${MROOT}/${service_exec} ]] && return   [[ -f ${MROOT}/${service_exec} ]] && return
# Line 64  mreloadservice() Line 78  mreloadservice()
78   local service="$1"   local service="$1"
79   local service_exec="$2"   local service_exec="$2"
80    
81   [[ -z ${service_exec} ]] && service_exec="$(which ${service} 2> /dev/null)"   # only run if sysV init was found
82     if [[ ! -f /etc/rc.d/init.d/functions ]]
83     then
84     echo "sysV init not found, not adding service ${service} to runlevels!"
85     return
86     fi
87    
88     [[ -z ${service_exec} ]] && service_exec="$(which ${service})"
89    
90   # do not stop services on bootstrap or MROOT!=/   # do not stop services on bootstrap or MROOT!=/
91   if [[ ${MAGE_BOOTSTRAP} != true ]] && [[ -z ${MROOT} ]] || [[ ${MROOT} = / ]]   if [[ ${MAGE_BOOTSTRAP} != true ]] && [[ -z ${MROOT} ]] || [[ ${MROOT} = / ]]
# Line 93  mstartunit() Line 114  mstartunit()
114   fi   fi
115    
116   # we do not support $MROOT atm   # we do not support $MROOT atm
117   if [[ ${MROOT} != / ]] || [[ ! -z ${MROOT} ]]   if [[ ${MROOT} != / ]] && [[ ! -z ${MROOT} ]]
118   then   then
119   echo "\$MROOT is set, doing nothing!"   echo "\$MROOT is set, doing nothing!"
120   echo "Please add unit ${service} manually to the runlevels!"   echo "Please add unit ${service} manually to the runlevels!"
# Line 101  mstartunit() Line 122  mstartunit()
122   return   return
123   fi   fi
124    
125   [[ -z ${service_exec} ]] && service_exec="$(which ${service})"   if [[ -z ${service_exec} ]]
126     then
127     case ${service} in
128     *.service) service_exec="$(which ${service%%.service} 2> /dev/null)" ;;
129     *.socket) service_exec="$(which ${service%%.socket} 2> /dev/null)" ;;
130     *.mount) service_exec="$(which ${service%%.mount} 2> /dev/null)" ;;
131     *.target) service_exec="$(which ${service%%.target} 2> /dev/null)" ;;
132     *) service_exec="$(which ${service} 2> /dev/null)" ;;
133     esac
134     fi
135    
136   # add service to default runlevels   # add service to default runlevels
137   echo -e " ${COLBLUE}[${COLGREEN}+${COLBLUE}]${COLDEFAULT} adding unit ${service} to default runlevels ..."   echo -e " ${COLBLUE}[${COLGREEN}+${COLBLUE}]${COLDEFAULT} adding unit ${service} to default runlevels ..."
# Line 112  mstartunit() Line 142  mstartunit()
142   # do not start services on bootstrap or MROOT!=/   # do not start services on bootstrap or MROOT!=/
143   if [[ ${MAGE_BOOTSTRAP} != true ]] && [[ -z ${MROOT} ]] || [[ ${MROOT} = / ]]   if [[ ${MAGE_BOOTSTRAP} != true ]] && [[ -z ${MROOT} ]] || [[ ${MROOT} = / ]]
144   then   then
145     echo -e " ${COLBLUE}[${COLGREEN}+${COLBLUE}]${COLDEFAULT} starting unit ${service} ..."
146   # start or restart the service   # start or restart the service
147   systemctl try-restart ${service}   systemctl try-restart ${service}
148   fi   fi
# Line 132  mstopunit() Line 163  mstopunit()
163   fi   fi
164    
165   # we do not support $MROOT atm   # we do not support $MROOT atm
166   if [[ ${MROOT} != / ]] || [[ ! -z ${MROOT} ]]   if [[ ${MROOT} != / ]] && [[ ! -z ${MROOT} ]]
167   then   then
168   echo "\$MROOT is set, doing nothing!"   echo "\$MROOT is set, doing nothing!"
169   echo "Please remove unit ${service} manually from the runlevels!"   echo "Please remove unit ${service} manually from the runlevels!"
# Line 140  mstopunit() Line 171  mstopunit()
171   return   return
172   fi   fi
173    
174   [[ -z ${service_exec} ]] && service_exec="$(which ${service} 2> /dev/null)"   if [[ -z ${service_exec} ]]
175     then
176     case ${service} in
177     *.service) service_exec="$(which ${service%%.service} 2> /dev/null)" ;;
178     *.socket) service_exec="$(which ${service%%.socket} 2> /dev/null)" ;;
179     *.mount) service_exec="$(which ${service%%.mount} 2> /dev/null)" ;;
180     *.target) service_exec="$(which ${service%%.target} 2> /dev/null)" ;;
181     *) service_exec="$(which ${service} 2> /dev/null)" ;;
182     esac
183     fi
184    
185   # only stop the service if ${service_exec} does not exist   # only stop the service if ${service_exec} does not exist
186   [[ -f ${MROOT}/${service_exec} ]] && return   [[ -f ${MROOT}/${service_exec} ]] && return
# Line 154  mstopunit() Line 194  mstopunit()
194   # do not stop services on bootstrap or MROOT!=/   # do not stop services on bootstrap or MROOT!=/
195   if [[ ${MAGE_BOOTSTRAP} != true ]] && [[ -z ${MROOT} ]] || [[ ${MROOT} = / ]]   if [[ ${MAGE_BOOTSTRAP} != true ]] && [[ -z ${MROOT} ]] || [[ ${MROOT} = / ]]
196   then   then
197     echo -e " ${COLBLUE}[${COLGREEN}+${COLBLUE}]${COLDEFAULT} stopping unit ${service} ..."
198   systemctl stop ${service}   systemctl stop ${service}
199   # try harder   # try harder
200   if [[ -n $(pidof ${service_exec}) ]]   if [[ -n $(pidof ${service_exec}) ]]
# Line 180  mreloadunit() Line 221  mreloadunit()
221   fi   fi
222    
223   # we do not support $MROOT atm   # we do not support $MROOT atm
224   if [[ ${MROOT} != / ]] || [[ ! -z ${MROOT} ]]   if [[ ${MROOT} != / ]] && [[ ! -z ${MROOT} ]]
225   then   then
226   echo "\$MROOT is set, doing nothing!"   echo "\$MROOT is set, doing nothing!"
227   echo "Please remove unit ${service} manually from the runlevels!"   echo "Please remove unit ${service} manually from the runlevels!"
# Line 188  mreloadunit() Line 229  mreloadunit()
229   return   return
230   fi   fi
231    
232   [[ -z ${service_exec} ]] && service_exec="$(which ${service} 2> /dev/null)"   if [[ -z ${service_exec} ]]
233     then
234     case ${service} in
235     *.service) service_exec="$(which ${service%%.service} 2> /dev/null)" ;;
236     *.socket) service_exec="$(which ${service%%.socket} 2> /dev/null)" ;;
237     *.mount) service_exec="$(which ${service%%.mount} 2> /dev/null)" ;;
238     *.target) service_exec="$(which ${service%%.target} 2> /dev/null)" ;;
239     *) service_exec="$(which ${service} 2> /dev/null)" ;;
240     esac
241     fi
242    
243   # do not stop services on bootstrap or MROOT!=/   # do not stop services on bootstrap or MROOT!=/
244   if [[ ${MAGE_BOOTSTRAP} != true ]] && [[ -z ${MROOT} ]] || [[ ${MROOT} = / ]]   if [[ ${MAGE_BOOTSTRAP} != true ]] && [[ -z ${MROOT} ]] || [[ ${MROOT} = / ]]

Legend:
Removed from v.16  
changed lines
  Added in v.21