8354 sync regcomp(3C) with upstream (fix make catalog)
[unleashed/tickless.git] / usr / src / lib / libast / common / man / tmx.3
blob268d40a9e5337a9ecc63684e8cb777ad2a038558
1 .fp 5 CW
2 .de Af
3 .ds ;G \\*(;G\\f\\$1\\$3\\f\\$2
4 .if !\a\\$4\a\a .Af \\$2 \\$1 "\\$4" "\\$5" "\\$6" "\\$7" "\\$8" "\\$9"
5 ..
6 .de aF
7 .ie \a\\$3\a\a .ft \\$1
8 .el \{\
9 .ds ;G \&
10 .nr ;G \\n(.f
11 .Af "\\$1" "\\$2" "\\$3" "\\$4" "\\$5" "\\$6" "\\$7" "\\$8" "\\$9"
12 \\*(;G
13 .ft \\n(;G \}
15 .de L
16 .aF 5 \\n(.f "\\$1" "\\$2" "\\$3" "\\$4" "\\$5" "\\$6" "\\$7"
18 .de LR
19 .aF 5 1 "\\$1" "\\$2" "\\$3" "\\$4" "\\$5" "\\$6" "\\$7"
21 .de RL
22 .aF 1 5 "\\$1" "\\$2" "\\$3" "\\$4" "\\$5" "\\$6" "\\$7"
24 .de EX          \" start example
25 .ta 1i 2i 3i 4i 5i 6i
26 .PP
27 .RS 
28 .PD 0
29 .ft 5
30 .nf
32 .de EE          \" end example
33 .fi
34 .ft
35 .PD
36 .RE
37 .PP
39 .TH TM 3
40 .SH NAME
41 tm \- time conversion support
42 .SH SYNOPSIS
43 .L "#include <tm.h>"
44 .SH DESCRIPTION
45 The
46 .I tm
47 library supports conversion between
48 string date specifications,
49 .L time_t
50 clock values and
51 .L "struct tm"
52 values.
53 .L localtime()
54 and
55 .L gmtime()
56 (see
57 .IR ctime (3))
58 are used to determine local time zone information.
59 .PP
60 .L time_t
61 values are the number of seconds since the epoch,
62 .BR "Jan 1 00:00:00 GMT 1970" ,
63 with leap seconds omitted.
64 .PP
65 The global variable
66 .L "int tm_info.flags"
67 contains flags that allow all programs using the library
68 to be controlled in a consistent manner.
69 .L tm_info.flags
70 is initialized by the
71 .L tminit()
72 routine described below, and may be explicitly reset after
73 .L tminit()
74 is called.
75 The flags are:
76 .TP
77 .L TM_ADJUST
78 Set by
79 .L tminit()
81 .L localtime()
82 and
83 .L gmtime()
84 do not compensate for leap seconds.
85 .TP
86 .L TM_LEAP
87 .L time_t
88 values are interpreted as if they include leap seconds.
89 Set by
90 .L tminit()
91 if the
92 .L leap
93 option is set in the
94 .L TM_OPTIONS
95 environment variable.
96 .TP
97 .L TM_UTC
98 Times are relative to
99 .B UTC
100 (universal coordinated time, i.e.,
101 .BR GMT ).
102 Otherwise times are relative to the local time zone.
103 Set by
104 .L tminit()
105 if the time zone name matches one of
106 .L tm_info.format[43]
107 through
108 .L tm_info.format[46]
109 described below.
110 If the time zone name is not determined by
111 .L localtime()
112 then the environment variables
113 .L TZNAME
114 (as described in BSD 4.3) and
115 .L TZ
116 (as described in System V)
117 are checked, in order.
118 If this fails then the time zone name is constructed using
119 the local time zone offset.
121 The routines are:
123 .L "time_t tmdate(const char* date, char** end, time_t* clock)"
124 Parses the date specification
125 .L date
126 using the
127 .L tm_info.format
128 string table (described below)
129 and returns the equivalent
130 .L time_t
131 value.
133 .RL non- NULL ,
134 .L end
135 is set to the position of the first unrecognized character in
136 .LR date .
137 .L clock
138 is used to provide default values for omitted components in
139 .LR date .
141 .L clock
143 .L NULL
144 then the current time is used.
146 .L "struct tm* tmfix(struct tm* tp)"
147 Corrects any out of bounds fields in
148 .L tp
149 and returns
150 .L tp
151 as its value.
152 The corrections start with
153 .L tp->tm_sec
154 and propagate down to
155 .LR tp->tm_year .
156 For example, if
157 .L tp->tm_sec
158 were 61 then it would change to 1 and
159 .L tp->tm_min
160 would be incremented by 1, and so on.
161 .LR tp->tm_wday ,
162 .LR tp->tm_yday
164 .L tp->tm_isdst
165 are not changed as these can be computed from the other fields.
167 .L "char* tmfmt(char* buf, size_t len, const char* format, time_t* clock)"
168 Formats the date pointed to by
169 .L clock
170 into the buffer
171 .L buf
172 with size
173 .L len
174 bytes according to the format specification
175 .LR format .
177 .L format
179 .L NULL
180 or empty then the string
181 .L tm_info.format[40]
182 is used.
184 .L clock
186 .L NULL
187 then the current time is used.
188 A pointer to the end of
189 .L buf
190 (i.e., the terminating
191 .LR "'\e0'" )
192 is returned.
195 .L format
196 is in the style of
197 .IR printf (3),
198 where
199 .BI % field
200 causes the corresponding fixed size field to be placed in
201 .LR buf ,
202 zero padded if necessary, and \e\fIc\fP and \e\fInnn\fP
203 sequences are interpreted as in the C language.
204 Otherwise invalid
205 .BI % field
206 specifications and all other characters in
207 .L format
208 are copied into
209 .L buf
210 without change.
211 String field values are taken from the
212 .L tm_info.format
213 string table.
215 .I fields
216 are:
218 .PD 0
219 .B %
220 .B %
221 character.
223 .B a
224 Abbreviated weekday name.
226 .B A
227 Full weekday name.
229 .B b
230 Abbreviated month name.
232 .B c
233 .IR ctime (3)
234 style date without the trailing
235 .BR newline .
237 .B C
238 .IR date (1)
239 style date.
241 .B d
242 Day of month number.
244 .B D
245 Date as
246 .IR mm / dd / yy .
248 .B e
249 Blank padded day of month number.
251 .B E
252 Unpadded day of month number.
254 .B h
255 Abbreviated month name.
257 .B H
258 24-hour clock hour.
260 .B i
261 International
262 .IR date (1)
263 date that includes the time zone type name.
265 .B I
266 12-hour clock hour.
268 .B j
269 1-offset Julian date.
271 .B J
272 0-offset Julian date.
274 .B l
275 .IR ls (1)
276 .B \-l
277 date that lists recent dates with
278 .IR hh : mm
279 and distant dates with
280 .IR yyyy .
282 .B m
283 Month number.
285 .B M
286 Minutes.
288 .B n
289 .B newline
290 character.
292 .B p
293 Meridian (e.g.,
294 .B AM
296 .BR PM ).
298 .B r
299 12-hour time as
300 .IR hh : mm : ss
301 .IR meridian .
303 .B R
304 24-hour time as
305 .IR hh : mm .
307 .B S
308 Seconds.
310 .B t
311 .B tab
312 character.
314 .B T
315 24-hour time as
316 .IR hh : mm : ss .
318 .B U
319 Week number with Sunday as the first day.
321 .B w
322 Weekday number.
324 .B W
325 Week number with Monday as the first day.
327 .B x
328 Local date style, using
329 .LR tm_info.format[39] ,
330 that includes the month, day and year.
332 .B X
333 Local time style, using
334 .LR tm_info.format[38] ,
335 that includes the hours and minutes.
337 .B y
338 2-digit year.
340 .B Y
341 4-digit year.
343 .B z
344 Time zone type name.
346 .B Z
347 Time zone name.
349 .BI + flag
351 .BI \- flag
352 Temporarily (until
353 .L tmform()
354 returns) sets (+) or clears (\-) the
355 .L tm_info.flags
356 flags specified by
357 .IR flag :
360 .B l
361 .L TM_LEAP
363 .B u
364 .L TM_UTC
367 .B #
368 Number of seconds since the epoch.
372 .L "void tminit(Tm_zone_t* zone)"
373 Implicitly called by the other
374 .I tm
375 library routines to initialize global data, including the
376 .L tm_info.format
377 table and the
378 .L tm_info.flags
379 global flags.
380 Global data should only be modified after an explicit call to
381 .LR tminit .
383 .L "zone != 0"
384 then it specifies a time zone other that the local time zone.
386 .L "void tmset(Tm_zone_t* zone);"
387 .L tmset
388 sets the reference timezoe to
389 .LR zone .
390 .L tm_info.local 
391 points to the local timezone and
392 .L tm_info.zone
393 points to the current reference timezone.
395 .L "time_t tmleap(time_t* clock)"
396 Returns a
397 .L time_t
398 value for the time pointed to by
399 .L clock
400 with leap seconds adjusted for external
401 routines that do not handle leap seconds.
403 .L clock
405 .L NULL
406 then the current time is used.
407 Adjustments are only done if the
408 .L TM_ADJUST
409 flag is set in
410 .LR tm_info.flags .
412 .L "struct tm* tmmake(time_t* clock)"
413 Returns a pointer to the
414 .L tm
415 struct corresponding to the time pointed to by
416 .LR clock .
418 .L clock
420 .L NULL
421 then the current time is used.
423 .L "time_t tmtime(struct tm* tp, int west)"
424 Returns the
425 .L time_t
426 value corresponding to
427 .LR tp .
429 .L west
431 .L TM_LOCALZONE
432 then
433 .L tm
434 is relative to the local time zone,
435 otherwise
436 .L west
437 is the number of minutes west of
438 .B UTC
439 with daylight savings time taken into account.
440 .LR tp->tm_wday ,
441 .LR tp->tm_yday
443 .L tp->tm_isdst
444 are ignored in the conversion.
446 The library routines use a table of date strings pointed to by
447 .LR "char** tm_info.format" .
448 The indices in
449 .L tm_info.format
450 are fixed by category.
451 .L tm_info.format
452 may be changed to point to other tables
453 according to local language and date conventions.
454 The contents by index (showing the USA English values) are:
457 .PD 0
458 .B 0-11
459 3-character abbreviated month names.
461 .B 12-23
462 Full month names.
464 .B 24-30
465 3-character abbreviated weekday names.
467 .B 31-37
468 Full weekday names.
470 .B 38
471 .L tmform()
472 local time format used by the
473 .B %X
474 field.
476 .B 39
477 .L tmform()
478 local date format used by the
479 .B %x
480 field.
482 .B 40
483 .L tmform()
484 format used if the
485 .L format
486 argument is
487 .L NULL
488 or empty.
490 .B 41-42
491 Meridian names: AM, PM.
493 .B 43-46
494 .B UTC
495 time zone names: GMT, UTC, UCT, CUT.
497 .B 47-50
498 Daylight savings time suffix names: DST.
500 .B 51-54
501 Suffixes to be ignored when matching strings in
502 .LR tmform() .
504 .B 55-61
505 Time part names: second, hour, minute, day, week, month, year.
507 .B 62-65
508 Hours of the day names: midnight, morning, noon, evening.
510 .B 66-68
511 Relative day names: yesterday, today, tomorrow.
513 .B 69-71
514 Past relative time references: last, ago, past.
516 .B 72-75
517 Current relative time references: this, now, current.
519 .B 75-77
520 Future relative time references: next, hence, coming.
522 .B 78-80
523 Exact relative time references: exactly.
525 .B 81-85
526 Noise words to be ignored: at, in, on.
530 Low level support functions and data are described in
531 .LR <tm.h> .
532 .SH EXAMPLES
534 #include <tm.h>
535 main() {
536     int       i;
537     time_t    t;
538     char      buf[128];
539     struct {
540         char* date;
541         char* format;
542     }         x[] = {
543         "now",                 "%i",
544         "2 months ago",        "%C",
545         "this Wednesday noon", "%x %I:%M %p",
546         "last December 25",    "%A",
547         0,                     0
548     };
549     for (i = 0; x[i].date; i++) {
550         t = tmdate(x[i].date, (char*)0, (time_t*)0);
551         (void)tmform(buf, x[i].format, &t);
552         puts(buf);
553     }
556 produces
558 Fri Sep 30 12:10:14 USA EDT 1988
559 Fri Jul  1 00:00:00 EDT 1988
560 10/05/88 12:00 PM
561 Friday
563 .SH "SEE ALSO"
564 date(1), time(2), ctime(3)
565 .SH BUGS
566 .L "struct tm"
567 values may get clobbered by the
568 .I tm
569 library routines as the
570 .IR ctime (3)
571 routines typically return pointers to a single static
572 .L "struct tm"
573 area.
574 .L tmdate()
575 uses an internal international time zone name table that will
576 probably always be incomplete.