1997-08-09 15:43:59 +00:00
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1997 Joerg Wunsch
|
|
|
|
.\"
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
.\" IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
1999-08-28 00:22:10 +00:00
|
|
|
.\" $FreeBSD$
|
1997-08-09 15:43:59 +00:00
|
|
|
.\" "
|
2014-10-02 18:52:29 +00:00
|
|
|
.Dd October 2, 2014
|
1997-08-09 15:43:59 +00:00
|
|
|
.Dt STRPTIME 3
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm strptime
|
|
|
|
.Nd parse date and time string
|
2000-04-21 09:42:15 +00:00
|
|
|
.Sh LIBRARY
|
|
|
|
.Lb libc
|
1997-08-09 15:43:59 +00:00
|
|
|
.Sh SYNOPSIS
|
2001-10-01 16:09:29 +00:00
|
|
|
.In time.h
|
1998-09-12 21:13:29 +00:00
|
|
|
.Ft char *
|
2002-08-15 18:57:57 +00:00
|
|
|
.Fo strptime
|
2002-09-06 11:24:06 +00:00
|
|
|
.Fa "const char * restrict buf"
|
|
|
|
.Fa "const char * restrict format"
|
|
|
|
.Fa "struct tm * restrict timeptr"
|
2002-08-15 18:57:57 +00:00
|
|
|
.Fc
|
2012-06-25 21:51:40 +00:00
|
|
|
.In time.h
|
|
|
|
.In xlocale.h
|
|
|
|
.Ft char *
|
|
|
|
.Fn strptime_l "const char * restrict buf" "const char * restrict format" "struct tm * restrict timeptr" "locale_t loc"
|
1997-08-09 15:43:59 +00:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Fn strptime
|
|
|
|
function parses the string in the buffer
|
|
|
|
.Fa buf
|
|
|
|
according to the string pointed to by
|
|
|
|
.Fa format ,
|
|
|
|
and fills in the elements of the structure pointed to by
|
|
|
|
.Fa timeptr .
|
1999-07-04 08:54:26 +00:00
|
|
|
The resulting values will be relative to the local time zone.
|
1997-08-09 15:43:59 +00:00
|
|
|
Thus, it can be considered the reverse operation of
|
|
|
|
.Xr strftime 3 .
|
2012-06-25 21:51:40 +00:00
|
|
|
The
|
|
|
|
.Fn strptime_l
|
|
|
|
function does the same as
|
|
|
|
.Fn strptime ,
|
|
|
|
but takes an explicit locale rather than using the current locale.
|
1997-08-09 15:43:59 +00:00
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fa format
|
|
|
|
string consists of zero or more conversion specifications and
|
|
|
|
ordinary characters.
|
|
|
|
All ordinary characters are matched exactly with the buffer, where
|
|
|
|
white space in the format string will match any amount of white space
|
|
|
|
in the buffer.
|
|
|
|
All conversion specifications are identical to those described in
|
|
|
|
.Xr strftime 3 .
|
1999-04-25 01:42:18 +00:00
|
|
|
.Pp
|
|
|
|
Two-digit year values, including formats
|
1999-04-25 07:28:39 +00:00
|
|
|
.Fa %y
|
2001-07-15 07:53:42 +00:00
|
|
|
and
|
2000-12-29 14:08:20 +00:00
|
|
|
.Fa \&%D ,
|
1999-04-25 07:28:39 +00:00
|
|
|
are now interpreted as beginning at 1969 per POSIX requirements.
|
|
|
|
Years 69-00 are interpreted in the 20th century (1969-2000), years
|
2014-10-04 18:00:15 +00:00
|
|
|
01-68 in the 21st century (2001-2068).
|
|
|
|
The
|
2014-10-02 18:52:29 +00:00
|
|
|
.Fa \&%U
|
|
|
|
and
|
|
|
|
.Fa %W
|
|
|
|
format specifiers accept any value within the range 00 to 53.
|
2002-12-18 05:00:54 +00:00
|
|
|
.Pp
|
|
|
|
If the
|
|
|
|
.Fa format
|
|
|
|
string does not contain enough conversion specifications to completely
|
|
|
|
specify the resulting
|
|
|
|
.Vt struct tm ,
|
|
|
|
the unspecified members of
|
|
|
|
.Va timeptr
|
|
|
|
are left untouched.
|
|
|
|
For example, if
|
|
|
|
.Fa format
|
|
|
|
is
|
2002-12-19 08:13:27 +00:00
|
|
|
.Dq Li "%H:%M:%S" ,
|
2002-12-18 05:00:54 +00:00
|
|
|
only
|
|
|
|
.Va tm_hour ,
|
|
|
|
.Va tm_sec
|
|
|
|
and
|
|
|
|
.Va tm_min
|
|
|
|
will be modified.
|
|
|
|
If time relative to today is desired, initialize the
|
|
|
|
.Fa timeptr
|
|
|
|
structure with today's date before passing it to
|
|
|
|
.Fn strptime .
|
1997-08-09 15:43:59 +00:00
|
|
|
.Sh RETURN VALUES
|
|
|
|
Upon successful completion,
|
|
|
|
.Fn strptime
|
|
|
|
returns the pointer to the first character in
|
|
|
|
.Fa buf
|
|
|
|
that has not been required to satisfy the specified conversions in
|
|
|
|
.Fa format .
|
|
|
|
It returns
|
|
|
|
.Dv NULL
|
|
|
|
if one of the conversions failed.
|
2012-06-25 21:51:40 +00:00
|
|
|
.Fn strptime_l
|
|
|
|
returns the same values as
|
|
|
|
.Fn strptime .
|
1997-08-09 15:43:59 +00:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr date 1 ,
|
|
|
|
.Xr scanf 3 ,
|
|
|
|
.Xr strftime 3
|
2005-01-20 09:17:07 +00:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Fn strptime
|
|
|
|
function appeared in
|
|
|
|
.Fx 3.0 .
|
1997-08-09 15:43:59 +00:00
|
|
|
.Sh AUTHORS
|
|
|
|
The
|
|
|
|
.Fn strptime
|
|
|
|
function has been contributed by Powerdog Industries.
|
|
|
|
.Pp
|
|
|
|
This man page was written by
|
2000-11-10 17:46:15 +00:00
|
|
|
.An J\(:org Wunsch .
|
1999-07-04 08:54:26 +00:00
|
|
|
.Sh BUGS
|
1999-12-08 15:49:10 +00:00
|
|
|
Both the
|
|
|
|
.Fa %e
|
|
|
|
and
|
|
|
|
.Fa %l
|
|
|
|
format specifiers may incorrectly scan one too many digits
|
|
|
|
if the intended values comprise only a single digit
|
|
|
|
and that digit is followed immediately by another digit.
|
|
|
|
Both specifiers accept zero-padded values,
|
|
|
|
even though they are both defined as taking unpadded values.
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fa %p
|
|
|
|
format specifier has no effect unless it is parsed
|
|
|
|
.Em after
|
|
|
|
hour-related specifiers.
|
|
|
|
Specifying
|
|
|
|
.Fa %l
|
|
|
|
without
|
|
|
|
.Fa %p
|
|
|
|
will produce undefined results.
|
|
|
|
Note that 12AM
|
2001-08-07 15:48:51 +00:00
|
|
|
(ante meridiem)
|
1999-12-08 15:49:10 +00:00
|
|
|
is taken as midnight
|
|
|
|
and 12PM
|
2001-08-07 15:48:51 +00:00
|
|
|
(post meridiem)
|
1999-12-08 15:49:10 +00:00
|
|
|
is taken as noon.
|
|
|
|
.Pp
|
|
|
|
The
|
1999-07-04 08:54:26 +00:00
|
|
|
.Fa %Z
|
|
|
|
format specifier only accepts time zone abbreviations of the local time zone,
|
|
|
|
or the value "GMT".
|
|
|
|
This limitation is because of ambiguity due to of the over loading of time
|
2004-07-02 23:52:20 +00:00
|
|
|
zone abbreviations.
|
|
|
|
One such example is
|
1999-07-04 08:54:26 +00:00
|
|
|
.Fa EST
|
|
|
|
which is both Eastern Standard Time and Eastern Australia Summer Time.
|
2003-01-04 09:50:04 +00:00
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fn strptime
|
|
|
|
function does not correctly handle multibyte characters in the
|
|
|
|
.Fa format
|
|
|
|
argument.
|