annotate lisp/hyperbole/htz.el @ 100:4be1180a9e89 r20-1b2

Import from CVS: tag r20-1b2
author cvs
date Mon, 13 Aug 2007 09:15:11 +0200
parents 131b0175ea99
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1 ;;!emacs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3 ;; FILE: htz.el
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
4 ;; SUMMARY: Timezone-based time and date support for Hyperbole.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
5 ;; USAGE: GNU Emacs Lisp Library
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
6 ;; KEYWORDS: calendar, hypermedia
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
7 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
8 ;; AUTHOR: Masanobu UMEDA / Bob Weiner
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents: 70
diff changeset
9 ;; ORG: Fujitsu Laboratories LTD. / InfoDock Associates
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
10 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
11 ;; ORIG-DATE: 14-Oct-91 at 07:22:08
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents: 70
diff changeset
12 ;; LAST-MOD: 20-Feb-97 at 12:21:10 by Bob Weiner
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
14 ;; This file is part of Hyperbole.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15 ;; Available for use and distribution under the same terms as GNU Emacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16 ;;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents: 70
diff changeset
17 ;; Copyright (C) 1991-1995, 1997 Free Software Foundation, Inc.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 ;; Developed with support from Motorola Inc.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
19 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
20 ;; Adapted from Timezone package for GNU Emacs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21 ;; Copyright(C) 1990 Masanobu UMEDA (umerin@mse.kyutech.ac.jp)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents: 70
diff changeset
22 ;; $Header: /afs/informatik.uni-tuebingen.de/local/web/xemacs/xemacs-cvs/XEmacs/xemacs/lisp/hyperbole/Attic/htz.el,v 1.2 1997/02/24 01:13:35 steve Exp $
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
23 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
24 ;; DESCRIPTION:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
25 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
26 ;; All date parsing functions accept the output of any other parsing
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
27 ;; function as input, so one can convert to a sortable date format, do a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
28 ;; compare and the display the result in a user selected format.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
29 ;; All date formats use a 4-digit year, so there are no problems around the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
30 ;; turn of the century.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
32 ;; Hyperbole uses this package to normalize all worldwide date times to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
33 ;; Greenwich Mean Time, so that Hyperbole buttons created by users in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
34 ;; different timezones will sort by time properly.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
35 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
36 ;; DESCRIP-END.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
37
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
38 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
39 ;;; Other required Elisp libraries
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
40 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
41
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
42 (require 'hypb)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
43
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
44 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
45 ;;; Public functions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
46 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
47
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
48 (defun htz:date-arpa (&optional date local timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
49 "Convert optional DATE or current date to an arpanet standard date.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
50 Optional 1st argument LOCAL specifies the default local timezone of the DATE.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
51 Optional 2nd argument TIMEZONE specifies a timezone to be represented in."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52 (or (vectorp date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
53 (setq date (htz:date-parse (or date (current-time-string)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
54 (let* ((year (string-to-int (aref date 0)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
55 (month (string-to-int (aref date 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
56 (day (string-to-int (aref date 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
57 (time (htz:time-parse (aref date 3)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
58 (hour (string-to-int (aref time 0)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
59 (minute (string-to-int (aref time 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
60 (second (string-to-int (aref time 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
61 (local (or (aref date 4) local htz:local)) ;Use original if defined
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
62 (timezone (or timezone local))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
63 (diff (- (htz:zone-to-hour timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
64 (htz:zone-to-hour local)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
65 (new (htz:time-fix year month day
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66 (+ hour diff) minute second)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
67 (htz:date-make-arpa (aref new 0) (aref new 1) (aref new 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 (htz:time-make-string
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
69 (aref new 3) (aref new 4) (aref new 5))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
70 timezone)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
71
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
72 (defun htz:date-parse (date &optional parsed-current-date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
73 "Parse DATE string and return a vector [year month day time timezone].
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
74 19 is prepended to year if necessary. Timezone in DATE is optional, it
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents: 70
diff changeset
75 defaults to the value of `htz:local'.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
76
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
77 Recognizes the following styles:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
78 (1) 14 Apr 89 03:20[:12] [GMT]
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
79 (2) Fri, 17 Mar [19]89 4:01[:33] [GMT]
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
80 (3) Mon Jan 16 16:12[:37] [GMT] 1989
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
81 (4) 19911014:07:51:08 or 1991101407:51:08 'sortable date'
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
82 (5) Mar 29 14:00 'ls -l date' requires 'parsed-current-date' arg
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
83 (6) Mar 7 1994 'ls -l date' requires 'parsed-current-date' arg"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
84 (let ((date (or date ""))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
85 (year nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
86 (month nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
87 (day nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
88 (time nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
89 (zone nil)) ; This may be nil.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
90 (cond ((string-match
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
91 "\\([0-9][0-9][0-9][0-9]\\)\\([0-1][0-9]\\)\\([0-3][0-9]\\):?\\([0-2][0-9]:[0-5][0-9:]+\\)[ ]*\\'" date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
92 ;; Style (4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
93 (setq year 1 month 2 day 3 time 4 zone nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
94 ((string-match
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
95 "\\([0-9]+\\) \\([^ ,]+\\) \\([0-9]+\\) \\([0-9]+:[0-9:]+\\)[ ]*\\'" date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
96 ;; Styles: (1) and (2) without timezone
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
97 (setq year 3 month 2 day 1 time 4 zone nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
98 ((string-match
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
99 "\\([0-9]+\\) \\([^ ,]+\\) \\([0-9]+\\) \\([0-9]+:[0-9:]+\\)[ ]*\\([-+a-zA-Z0-9]+\\)" date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
100 ;; Styles: (1) and (2) with timezone and buggy timezone
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
101 (setq year 3 month 2 day 1 time 4 zone 5))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
102 ((string-match
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
103 "\\([^ ,]+\\) +\\([0-9]+\\) \\([0-9]+:[0-9:]+\\) \\([0-9]+\\)" date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
104 ;; Styles: (3) without timezone
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
105 (setq year 4 month 1 day 2 time 3 zone nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
106 ((string-match
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
107 "\\([^ ,]+\\) +\\([0-9]+\\) \\([0-9]+:[0-9:]+\\) \\([-+a-zA-Z0-9]+\\) \\([0-9]+\\)" date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
108 ;; Styles: (3) with timezone
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
109 (setq year 5 month 1 day 2 time 3 zone 4))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
110 ((string-match "^\\([^ ,]+\\) +\\([0-9]+\\) +\\([0-9]+:[0-9:]+\\)$" date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
111 ;; Style: (5)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
112 (setq year nil month 1 day 2 time 3 zone nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
113 ((string-match
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
114 "^\\([^ ,]+\\) +\\([0-9]+\\) +\\([0-9][0-9][0-9][0-9]\\)$" date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
115 ;; Style: (6)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
116 (setq year 3 month 1 day 2 time nil zone nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
117 (t (error "(htz:date-parse): Invalid date format: '%s'" date)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
118 (if year
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
119 (setq year
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
120 (substring date (match-beginning year) (match-end year))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
121 year (if (/= (length year) 2) year
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
122 (let* ((yr (substring (current-time-string) -4))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
123 (curr-yr (substring yr 2))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
124 (century (substring yr 0 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
125 (concat (if (string< curr-yr yr)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
126 (format "%02d"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
127 (1- (string-to-int century)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
128 century)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
129 year))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
130 (setq year (if (vectorp parsed-current-date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
131 (aref parsed-current-date 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
132 "0")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
133 (if month
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
134 (setq month (substring date
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
135 (match-beginning month) (match-end month))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
136 month (if (/= (string-to-int month) 0) month
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
137 (int-to-string
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
138 (cdr (assoc (upcase month) htz:months-assoc)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
139 (setq month (if (vectorp parsed-current-date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
140 (aref parsed-current-date 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
141 "0")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
142 (if day
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
143 (setq day (substring date (match-beginning day) (match-end day)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
144 (setq day (if (vectorp parsed-current-date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
145 (aref parsed-current-date 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
146 "0")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
147 (if time
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
148 (setq time (substring date (match-beginning time) (match-end time)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
149 (setq time (if (vectorp parsed-current-date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
150 (aref parsed-current-date 3))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
151 (if zone
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
152 (setq zone (substring date (match-beginning zone) (match-end zone)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
153 (setq zone (if (vectorp parsed-current-date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
154 (aref parsed-current-date 4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
155 htz:local)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
156 ;; Return a vector.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
157 (vector year month day time zone)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
158
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
159 (defun htz:date-sortable (&optional date local timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
160 "Convert optional DATE or current date to a sortable date string.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
161 Optional 1st argument LOCAL specifies the local timezone of the DATE.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
162 Optional 2nd argument TIMEZONE specifies an output timezone to use."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
163 (or (vectorp date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
164 (setq date (htz:date-parse (or date (current-time-string)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
165 (let* ((year (string-to-int (aref date 0)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
166 (month (string-to-int (aref date 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
167 (day (string-to-int (aref date 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
168 (time (htz:time-parse (aref date 3)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
169 (hour (string-to-int (aref time 0)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
170 (minute (string-to-int (aref time 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
171 (second (string-to-int (aref time 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
172 (local (or (aref date 4) local htz:local)) ;Use original if defined
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
173 (timezone (or timezone local))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
174 (diff (- (htz:zone-to-hour timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
175 (htz:zone-to-hour local)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
176 (new (htz:time-fix year month day
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
177 (+ hour diff) minute second)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
178 (htz:date-make-sortable (aref new 0) (aref new 1) (aref new 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
179 (htz:time-make-string
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
180 (aref new 3) (aref new 4) (aref new 5)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
181
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
182 ;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
183 ;;; Parsers and Constructors of Date and Time
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
184 ;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
185
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
186 (defun htz:date-sortable-gmt (&optional date local)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
187 "Convert optional DATE or current date to a sortable date string in Greenwich Mean Time.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
188 Optional argument LOCAL specifies the local timezone of the DATE."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
189 (htz:date-sortable date local "GMT"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
190
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
191 (defun htz:date-unix (&optional date local timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
192 "Convert DATE or current date to a unix standard date.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
193 Optional 1st argument LOCAL specifies the local timezone of the DATE (default
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
194 is the timezone embedded in the date or if there is none, then the value of
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents: 70
diff changeset
195 `htz:local'). Optional 2nd argument TIMEZONE specifies the timezone in which
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents: 70
diff changeset
196 the date is returned; it defaults to the value of `htz:local'."
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
197 (or (vectorp date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
198 (setq date (htz:date-parse (or date (current-time-string)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
199 (or local (setq local (or (aref date 4) htz:local)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
200 (let* ((year (string-to-int (aref date 0)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
201 (month (string-to-int (aref date 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
202 (day (string-to-int (aref date 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
203 (time (htz:time-parse (aref date 3)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
204 (hour (string-to-int (aref time 0)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
205 (minute (string-to-int (aref time 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
206 (second (string-to-int (aref time 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
207 (timezone (or timezone local))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
208 (diff (- (htz:zone-to-hour timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
209 (htz:zone-to-hour local)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
210 (fixed (htz:time-fix year month day
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
211 (+ hour diff) minute second)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
212 (htz:date-make-unix
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
213 (aref fixed 0) (aref fixed 1) (aref fixed 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
214 (htz:time-make-string (aref fixed 3) (aref fixed 4) (aref fixed 5))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
215 timezone)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
216
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
217 (defun htz:span-in-days (start-date end-date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
218 "Return span in days between START-DATE and END-DATE strings.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
219 See 'htz:date-parse' for a list of acceptable date formats."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
220 (require 'calendar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
221 (let* ((parsed-current-date (htz:date-parse (current-time-string)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
222 (htz-start-date (htz:date-parse start-date parsed-current-date))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
223 (htz-end-date (htz:date-parse end-date parsed-current-date))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
224 (cal-start-date
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
225 (list (string-to-int (aref htz-start-date 1)) ;; month
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
226 (string-to-int (aref htz-start-date 2)) ;; day
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
227 (string-to-int (aref htz-start-date 0)))) ;; year
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
228 (cal-end-date
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
229 (list (string-to-int (aref htz-end-date 1)) ;; month
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
230 (string-to-int (aref htz-end-date 2)) ;; day
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
231 (string-to-int (aref htz-end-date 0)))) ;; year
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
232 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
233 (- (calendar-absolute-from-julian cal-end-date)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
234 (calendar-absolute-from-julian cal-start-date))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
235
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
236 (defun htz:time-parse (time)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
237 "Parse TIME (HH:MM:SS) and return a vector [hour minute second]."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
238 (let ((time (or time ""))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
239 (hour nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
240 (minute nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
241 (second nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
242 (cond ((string-match "\\`\\([0-9]+\\):\\([0-9]+\\):\\([0-9]+\\)\\'" time)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
243 ;; HH:MM:SS
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
244 (setq hour 1 minute 2 second 3))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
245 ((string-match "\\`\\([0-9]+\\):\\([0-9]+\\)\\'" time)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
246 ;; HH:MM
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
247 (setq hour 1 minute 2 second nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
248 ;; Return [hour minute second]
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
249 (vector
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
250 (if hour
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
251 (substring time (match-beginning hour) (match-end hour)) "0")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
252 (if minute
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
253 (substring time (match-beginning minute) (match-end minute)) "0")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
254 (if second
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
255 (substring time (match-beginning second) (match-end second)) "0"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
256
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
257 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
258 ;;; Private functions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
259 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
260
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
261 (defun htz:date-make-arpa (year month day time &optional timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
262 "Make arpanet standard date string from YEAR, MONTH, DAY, and TIME.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
263 Optional argument TIMEZONE specifies a time zone."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
264 (format "%02d %s %02d %s%s"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
265 day
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
266 (capitalize (car (rassq month htz:months-assoc)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
267 (- year (* (/ year 100) 100)) ;1990 -> 90
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
268 time
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
269 (if timezone (concat " " timezone) "")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
270 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
271
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
272 (defun htz:date-make-unix (year month day time &optional timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
273 "Approximate Unix date format from YEAR, MONTH, DAY, and TIME.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
274 Optional argument TIMEZONE specifies a time zone."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
275 (format "%s %02d %s%s %04d"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
276 (capitalize (car (rassq month htz:months-assoc)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
277 day time (if timezone (concat " " timezone) "") year))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
278
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
279 (defun htz:date-make-sortable (year month day time)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
280 "Make sortable date string from YEAR, MONTH, DAY, and TIME."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
281 (format "%04d%02d%02d:%s" year month day time))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
282
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
283 (defun htz:last-day-of-month (month year)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
284 "The last day in MONTH during YEAR."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
285 (if (and (= month 2) (htz:leap-year-p year))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
286 29
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
287 (aref [31 28 31 30 31 30 31 31 30 31 30 31] (1- month))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
288
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
289 (defun htz:leap-year-p (year)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
290 "Returns t if YEAR is a Gregorian leap year."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
291 (or (and (zerop (% year 4))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
292 (not (zerop (% year 100))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
293 (zerop (% year 400))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
294
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
295 (defun htz:time-fix (year month day hour minute second)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
296 "Fix date and time."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
297 (cond ((<= 24 hour) ; 24 -> 00
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
298 (setq hour (- hour 24))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
299 (setq day (1+ day))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
300 (if (< (htz:last-day-of-month month year) day)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
301 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
302 (setq month (1+ month))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
303 (setq day 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
304 (if (< 12 month)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
305 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
306 (setq month 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
307 (setq year (1+ year)))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
308 ((> 0 hour)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
309 (setq hour (+ hour 24))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
310 (setq day (1- day))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
311 (if (> 1 day)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
312 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
313 (setq month (1- month))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
314 (if (> 1 month)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
315 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
316 (setq month 12)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
317 (setq year (1- year))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
318 (setq day (htz:last-day-of-month month year))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
319 (vector year month day hour minute second))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
320
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
321 ;; Partly copied from Calendar program by Edward M. Reingold.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
322 (defun htz:time-make-string (hour minute second)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
323 "Make time string from HOUR, MINUTE, and SECOND."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
324 (format "%02d:%02d:%02d" hour minute second))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
325
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
326 (defun htz:zone-to-hour (timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
327 "Translate TIMEZONE (in zone name or integer) to integer hour."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
328 (if timezone
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
329 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
330 (setq timezone
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
331 (or (cdr (assoc (upcase timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
332 htz:world-timezones))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
333 (and (fboundp 'current-time-zone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
334 (if (listp (current-time-zone))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
335 (car (cdr (current-time-zone)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
336 (current-time-zone)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
337 timezone))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
338 (if (stringp timezone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
339 (setq timezone (string-to-int timezone)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
340 (/ timezone 100))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
341 (error "(htz:zone-to-hour): Nil timezone sent as argument")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
342
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
343
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
344 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
345 ;;; Private variables
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
346 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
347
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
348 (defvar htz:local
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
349 (or (getenv "TZ") (getenv "TIMEZONE")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
350 (hypb:call-process-p
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
351 "date" nil '(if (re-search-backward
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
352 " \\([-+a-zA-Z0-9]+\\) [0-9]+$" nil t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
353 (buffer-substring (match-beginning 1) (match-end 1)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
354 "Holds string giving the timezone for the local machine.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
355
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
356 (defvar htz:world-timezones
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
357 '(("PST" . -800)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
358 ("PDT" . -700)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
359 ("MST" . -700)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
360 ("MDT" . -600)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
361 ("CST" . -600)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
362 ("CDT" . -500)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
363 ("EST" . -500)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
364 ("EDT" . -400)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
365 ("AST" . -400) ;by <clamen@CS.CMU.EDU>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
366 ("NST" . -330) ;by <clamen@CS.CMU.EDU>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
367 ("GMT" . +000)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
368 ("BST" . +100)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
369 ("MET" . +100)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
370 ("EET" . +200)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
371 ("JST" . +900)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
372 ("GMT+1" . +100) ("GMT+2" . +200) ("GMT+3" . +300)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
373 ("GMT+4" . +400) ("GMT+5" . +500) ("GMT+6" . +600)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
374 ("GMT+7" . +700) ("GMT+8" . +800) ("GMT+9" . +900)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
375 ("GMT+10" . +1000) ("GMT+11" . +1100) ("GMT+12" . +1200) ("GMT+13" . +1300)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
376 ("GMT-1" . -100) ("GMT-2" . -200) ("GMT-3" . -300)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
377 ("GMT-4" . -400) ("GMT-5" . -500) ("GMT-6" . -600)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
378 ("GMT-7" . -700) ("GMT-8" . -800) ("GMT-9" . -900)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
379 ("GMT-10" . -1000) ("GMT-11" . -1100) ("GMT-12" . -1200))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
380 "*Time differentials of timezone from GMT in +-HHMM form.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
381 This list is obsolescent, and is present only for backwards compatibility,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
382 because time zone names are ambiguous in practice.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
383 Use `current-time-zone' instead.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
384
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
385 (defvar htz:months-assoc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
386 '(("JAN" . 1)("FEB" . 2)("MAR" . 3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
387 ("APR" . 4)("MAY" . 5)("JUN" . 6)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
388 ("JUL" . 7)("AUG" . 8)("SEP" . 9)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
389 ("OCT" . 10)("NOV" . 11)("DEC" . 12))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
390 "Alist of first three letters of a month and its numerical representation.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
391
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
392
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
393 (provide 'htz)