X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=timezone.init;h=5b52348c2529fa8822e86fd27e8f1e856e159067;hb=f720b8daf02a554804a1527f4ccb3eccf9596606;hp=aca05d3aaee49dc2ccf6b14c5251c2506882d2da;hpb=96bffd5243e712b586ea4b2f8c64ee89c91669c9;p=packages%2Ftzdata.git diff --git a/timezone.init b/timezone.init old mode 100644 new mode 100755 index aca05d3..5b52348 --- a/timezone.init +++ b/timezone.init @@ -3,15 +3,15 @@ # timezone Set time zone information. # chkconfig: 2345 10 90 # description: This script is setting time zone information for your machine. -# Author: Pawel Wilk # -# $Id$ [ -f /etc/sysconfig/timezone ] || exit 0 # Source function library. . /etc/rc.d/init.d/functions +upstart_controlled --except status disable + . /etc/sysconfig/timezone ZONE_FILE="$ZONE_INFO_DIR" @@ -26,6 +26,7 @@ ZONE_FILE="$ZONE_FILE/$TIMEZONE" start() { if [ -f /var/lock/subsys/timezone ]; then + msg_already_running timezone return fi @@ -34,24 +35,36 @@ start() { MESSAGE=$(nls 'Setting time zone information (%s)' "$TIMEZONE") - run_cmd "$MESSAGE" cp -af $ZONE_FILE /etc/localtime + run_cmd "$MESSAGE" cp -af "$ZONE_FILE" /etc/localtime RETVAL=$? restorecon /etc/localtime >/dev/null 2>&1 + else + show "Missing %s file" "$ZONE_FILE" + fail + RETVAL=2 fi [ $RETVAL -eq 0 ] && touch /var/lock/subsys/timezone } stop() { - if [ -f /var/lock/subsys/timezone ]; then - rm -f /var/lock/subsys/timezone - fi + rm -f /var/lock/subsys/timezone >/dev/null 2>&1 } disable() { run_cmd "Unsetting time zone information" rm -f /etc/localtime } +# return true if FILE1 and FILE2 are identical +identical() { + local crc1 crc2 + test -f "$1" || return 1 + test -f "$2" || return 1 + crc1=$(cksum "$1" | awk '{print $1}') + crc2=$(cksum "$2" | awk '{print $1}') + [ "$crc1" = "$crc2" ] +} + RETVAL=0 # See how we were called. case "$1" in @@ -59,7 +72,7 @@ case "$1" in start ;; stop) - stop + stop ;; restart|try-restart|reload|force-reload) stop @@ -69,7 +82,14 @@ case "$1" in disable ;; status) - nls 'Time zone configured to (%s)' "$TIMEZONE" + nls 'Timezone is configured to %s' "$TIMEZONE" + if [ ! -f "$ZONE_FILE" ]; then + nls "Missing %s file" "$ZONE_FILE" + exit 1 + elif ! identical "$ZONE_FILE" /etc/localtime; then + nls 'Current time zone differs from %s' "$TIMEZONE" + exit 1 + fi ;; *) msg_usage "$0 {start|stop|restart|try-restart|reload|force-reload|disable|status}"