Home | History | Annotate | Download | only in build-aux
      1 #!/bin/sh
      2 # Get modification time of a file or directory and pretty-print it.
      3 
      4 scriptversion=2009-04-28.21; # UTC
      5 
      6 # Copyright (C) 1995, 1996, 1997, 2003, 2004, 2005, 2007, 2009 Free
      7 # Software Foundation, Inc.
      8 # written by Ulrich Drepper <drepper (at] gnu.ai.mit.edu>, June 1995
      9 #
     10 # This program is free software; you can redistribute it and/or modify
     11 # it under the terms of the GNU General Public License as published by
     12 # the Free Software Foundation; either version 2, or (at your option)
     13 # any later version.
     14 #
     15 # This program is distributed in the hope that it will be useful,
     16 # but WITHOUT ANY WARRANTY; without even the implied warranty of
     17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     18 # GNU General Public License for more details.
     19 #
     20 # You should have received a copy of the GNU General Public License
     21 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
     22 
     23 # As a special exception to the GNU General Public License, if you
     24 # distribute this file as part of a program that contains a
     25 # configuration script generated by Autoconf, you may include it under
     26 # the same distribution terms that you use for the rest of that program.
     27 
     28 # This file is maintained in Automake, please report
     29 # bugs to <bug-automake (at] gnu.org> or send patches to
     30 # <automake-patches (at] gnu.org>.
     31 
     32 case $1 in
     33   '')
     34      echo "$0: No file.  Try \`$0 --help' for more information." 1>&2
     35      exit 1;
     36      ;;
     37   -h | --h*)
     38     cat <<\EOF
     39 Usage: mdate-sh [--help] [--version] FILE
     40 
     41 Pretty-print the modification time of FILE.
     42 
     43 Report bugs to <bug-automake (at] gnu.org>.
     44 EOF
     45     exit $?
     46     ;;
     47   -v | --v*)
     48     echo "mdate-sh $scriptversion"
     49     exit $?
     50     ;;
     51 esac
     52 
     53 # Prevent date giving response in another language.
     54 LANG=C
     55 export LANG
     56 LC_ALL=C
     57 export LC_ALL
     58 LC_TIME=C
     59 export LC_TIME
     60 
     61 # GNU ls changes its time format in response to the TIME_STYLE
     62 # variable.  Since we cannot assume `unset' works, revert this
     63 # variable to its documented default.
     64 if test "${TIME_STYLE+set}" = set; then
     65   TIME_STYLE=posix-long-iso
     66   export TIME_STYLE
     67 fi
     68 
     69 save_arg1=$1
     70 
     71 # Find out how to get the extended ls output of a file or directory.
     72 if ls -L /dev/null 1>/dev/null 2>&1; then
     73   ls_command='ls -L -l -d'
     74 else
     75   ls_command='ls -l -d'
     76 fi
     77 # Avoid user/group names that might have spaces, when possible.
     78 if ls -n /dev/null 1>/dev/null 2>&1; then
     79   ls_command="$ls_command -n"
     80 fi
     81 
     82 # A `ls -l' line looks as follows on OS/2.
     83 #  drwxrwx---        0 Aug 11  2001 foo
     84 # This differs from Unix, which adds ownership information.
     85 #  drwxrwx---   2 root  root      4096 Aug 11  2001 foo
     86 #
     87 # To find the date, we split the line on spaces and iterate on words
     88 # until we find a month.  This cannot work with files whose owner is a
     89 # user named `Jan', or `Feb', etc.  However, it's unlikely that `/'
     90 # will be owned by a user whose name is a month.  So we first look at
     91 # the extended ls output of the root directory to decide how many
     92 # words should be skipped to get the date.
     93 
     94 # On HPUX /bin/sh, "set" interprets "-rw-r--r--" as options, so the "x" below.
     95 set x`$ls_command /`
     96 
     97 # Find which argument is the month.
     98 month=
     99 command=
    100 until test $month
    101 do
    102   shift
    103   # Add another shift to the command.
    104   command="$command shift;"
    105   case $1 in
    106     Jan) month=January; nummonth=1;;
    107     Feb) month=February; nummonth=2;;
    108     Mar) month=March; nummonth=3;;
    109     Apr) month=April; nummonth=4;;
    110     May) month=May; nummonth=5;;
    111     Jun) month=June; nummonth=6;;
    112     Jul) month=July; nummonth=7;;
    113     Aug) month=August; nummonth=8;;
    114     Sep) month=September; nummonth=9;;
    115     Oct) month=October; nummonth=10;;
    116     Nov) month=November; nummonth=11;;
    117     Dec) month=December; nummonth=12;;
    118   esac
    119 done
    120 
    121 # Get the extended ls output of the file or directory.
    122 set dummy x`eval "$ls_command \"\$save_arg1\""`
    123 
    124 # Remove all preceding arguments
    125 eval $command
    126 
    127 # Because of the dummy argument above, month is in $2.
    128 #
    129 # On a POSIX system, we should have
    130 #
    131 # $# = 5
    132 # $1 = file size
    133 # $2 = month
    134 # $3 = day
    135 # $4 = year or time
    136 # $5 = filename
    137 #
    138 # On Darwin 7.7.0 and 7.6.0, we have
    139 #
    140 # $# = 4
    141 # $1 = day
    142 # $2 = month
    143 # $3 = year or time
    144 # $4 = filename
    145 
    146 # Get the month.
    147 case $2 in
    148   Jan) month=January; nummonth=1;;
    149   Feb) month=February; nummonth=2;;
    150   Mar) month=March; nummonth=3;;
    151   Apr) month=April; nummonth=4;;
    152   May) month=May; nummonth=5;;
    153   Jun) month=June; nummonth=6;;
    154   Jul) month=July; nummonth=7;;
    155   Aug) month=August; nummonth=8;;
    156   Sep) month=September; nummonth=9;;
    157   Oct) month=October; nummonth=10;;
    158   Nov) month=November; nummonth=11;;
    159   Dec) month=December; nummonth=12;;
    160 esac
    161 
    162 case $3 in
    163   ???*) day=$1;;
    164   *) day=$3; shift;;
    165 esac
    166 
    167 # Here we have to deal with the problem that the ls output gives either
    168 # the time of day or the year.
    169 case $3 in
    170   *:*) set `date`; eval year=\$$#
    171        case $2 in
    172 	 Jan) nummonthtod=1;;
    173 	 Feb) nummonthtod=2;;
    174 	 Mar) nummonthtod=3;;
    175 	 Apr) nummonthtod=4;;
    176 	 May) nummonthtod=5;;
    177 	 Jun) nummonthtod=6;;
    178 	 Jul) nummonthtod=7;;
    179 	 Aug) nummonthtod=8;;
    180 	 Sep) nummonthtod=9;;
    181 	 Oct) nummonthtod=10;;
    182 	 Nov) nummonthtod=11;;
    183 	 Dec) nummonthtod=12;;
    184        esac
    185        # For the first six month of the year the time notation can also
    186        # be used for files modified in the last year.
    187        if (expr $nummonth \> $nummonthtod) > /dev/null;
    188        then
    189 	 year=`expr $year - 1`
    190        fi;;
    191   *) year=$3;;
    192 esac
    193 
    194 # The result.
    195 echo $day $month $year
    196 
    197 # Local Variables:
    198 # mode: shell-script
    199 # sh-indentation: 2
    200 # eval: (add-hook 'write-file-hooks 'time-stamp)
    201 # time-stamp-start: "scriptversion="
    202 # time-stamp-format: "%:y-%02m-%02d.%02H"
    203 # time-stamp-time-zone: "UTC"
    204 # time-stamp-end: "; # UTC"
    205 # End:
    206