mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-01-19 23:41:31 +01:00
85 lines
3.1 KiB
Text
85 lines
3.1 KiB
Text
COMMENT(!MOD!zsh/datetime
|
|
Some date/time commands and parameters.
|
|
!MOD!)
|
|
The tt(zsh/datetime) module makes available one builtin command:
|
|
|
|
startitem()
|
|
findex(strftime)
|
|
cindex(date string, printing)
|
|
xitem(tt(strftime) [ tt(-s) var(scalar) ] var(format) var(epochtime) )
|
|
item(tt(strftime) tt(-r) [ tt(-q) ] [ tt(-s) var(scalar) ] var(format) var(timestring) )(
|
|
Output the date denoted by var(epochtime) in the var(format) specified.
|
|
See manref(strftime)(3) for details. The zsh extensions described in
|
|
ifzman(the section EXPANSION OF PROMPT SEQUENCES in zmanref(zshmisc))\
|
|
ifnzman(noderef(Prompt Expansion)) are also available.
|
|
|
|
startitem()
|
|
item(tt(-q))(
|
|
Run quietly; suppress printing of all error messages described below.
|
|
Errors for invalid var(epochtime) values are always printed.
|
|
)
|
|
item(tt(-r))(
|
|
With the option tt(-r) (reverse), use var(format) to parse the input
|
|
string var(timestring) and output the number of seconds since the epoch at
|
|
which the time occurred. The parsing is implemented by the system
|
|
function tt(strptime); see manref(strptime)(3). This means that zsh
|
|
format extensions are not available, but for reverse lookup they are not
|
|
required.
|
|
|
|
In most implementations of tt(strftime) any timezone in the
|
|
var(timestring) is ignored and the local timezone declared by the tt(TZ)
|
|
environment variable is used; other parameters are set to zero if not
|
|
present.
|
|
|
|
If var(timestring) does not match var(format) the command returns status 1
|
|
and prints an error message. If var(timestring) matches var(format) but
|
|
not all characters in var(timestring) were used, the conversion succeeds
|
|
but also prints an error message.
|
|
|
|
If either of the system functions tt(strptime) or tt(mktime) is not
|
|
available, status 2 is returned and an error message is printed.
|
|
)
|
|
item(tt(-s) var(scalar))(
|
|
Assign the date string (or epoch time in seconds if tt(-r) is given) to
|
|
var(scalar) instead of printing it.
|
|
)
|
|
enditem()
|
|
|
|
Note that depending on the system's declared integral time type,
|
|
tt(strftime) may produce incorrect results for epoch times greater than
|
|
2147483647 which corresponds to 2038-01-19 03:14:07 +0000.
|
|
)
|
|
enditem()
|
|
|
|
The tt(zsh/datetime) module makes available several parameters;
|
|
all are readonly:
|
|
|
|
startitem()
|
|
vindex(EPOCHREALTIME)
|
|
item(tt(EPOCHREALTIME))(
|
|
A floating point value representing the number of seconds since
|
|
the epoch. The notional accuracy is to nanoseconds if the
|
|
tt(clock_gettime) call is available and to microseconds otherwise,
|
|
but in practice the range of double precision floating point and
|
|
shell scheduling latencies may be significant effects.
|
|
)
|
|
vindex(EPOCHSECONDS)
|
|
item(tt(EPOCHSECONDS))(
|
|
An integer value representing the number of seconds since the
|
|
epoch.
|
|
)
|
|
vindex(epochtime)
|
|
item(tt(epochtime))(
|
|
An array value containing the number of seconds since the epoch
|
|
in the first element and the remainder of the time since the epoch
|
|
in nanoseconds in the second element. To ensure the two elements
|
|
are consistent the array should be copied or otherwise referenced
|
|
as a single substitution before the values are used. The following
|
|
idiom may be used:
|
|
|
|
example(for secs nsecs in $epochtime; do
|
|
...
|
|
done)
|
|
|
|
)
|
|
enditem()
|