Date: Sun, 18 Mar 2001 14:19:13 +0900 From: Makoto MATSUSHITA <matusita@jp.FreeBSD.org> To: current@freebsd.org, stable@freebsd.org Cc: ache@freebsd.org, kjm@rins.ryukoku.ac.jp Subject: Our strptime(3) doesn't conform to other standards/implementations Message-ID: <20010318141913L.matusita@jp.FreeBSD.org>
next in thread | raw e-mail | index | archive | help
Summary: Our strptime(3) format string '%A' does not conform to Single UNIX Specification v2, Solaris2, NetBSD, and maybe other implementation. This comes from the changes of src/lib/libc/stdtime/strptime.c rev 1.13, which is commited by ache. Backout this changes (and apply to 4-stable) should fix the problem, but we also modify the manapage of strptime(3) which isn't also conform to other spec/implementation. *** Our strptime(3) implementation distinguishs '%A' and '%a', just like strftime(3) does. However, the Single UNIX Specification v2 doesn't say that '%A' and '%a' is different. <URL:http://www.opengroup.org/onlinepubs/007908799/xsh/strptime.html> is a spec of strptime(3) of SUSv2. It says: %a is the day of week, using the locale's weekday names; either the abbreviated or full name may be specified. %A is the same as %a. Note that strftime(3) specification says that '%'a and '%A' is different. <URL:http://www.opengroup.org/onlinepubs/007908799/xsh/strftime.html> says: %a is replaced by the locale's abbreviated weekday name. %A is replaced by the locale's full weekday name. You can easily check that strptime(3) implementation of Solaris2 and NetBSD are conformed to this standard. FreeBSD's implementation is different from others. I've asked via IRC, and told from eivind that this is because the changes of src/lib/libc/stdtime/strptime.c rev 1.13 (by ache) causes this misimplementation. <URL:http://www.freebsd.org/cgi/cvsweb.cgi/src/lib/libc/stdtime/strptime.c#rev1.13> The commitlog apprantly say that he misunderstands that '%A' and '%a' is different operation. But we cannot beat him, since our strptime(3) manpage, <URL:http://www.freebsd.org/cgi/cvsweb.cgi/src/lib/libc/stdtime/strptime.3> says: The 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 identi- cal to those described in strftime(3). It's true in the viewpoint of 'the manual should describe its implementation', but completely wrong in the view point of SUSv2 specification and/or other implementations. NetBSD, the one of implementation of strptime(3), have a correct manpages of strptime(3): <URL:http://cvsweb.netbsd.org/cgi-bin/cvsweb.cgi/basesrc/lib/libc/time/strptime.3> So.. there are two bugs in our strptime(3): - Our implementation of strptime(3) distingush '%A' and '%a'. We can fix this with backouting rev 1.13. It can be easily MFCed to 4-stable. - Our manpage of strptime(3) says its format string is the same of strftime(3). We can fix strptime(3) manpage, importing most of description from strftime(3) and modify it. We can also refer NetBSD's manpage to how to describe strptime(3). *** Acknowledgement: This problem is first reported to japanaese list, by Kojima-san (this is why I cc:-ed to him). We also says that without this GNU wget does misunderstands Date: format defined by RFC850. If you wanna check what he says first (and understand japanese), check <URL:http://home.jp.freebsd.org/cgi-bin/showmail/FreeBSD-users-jp/59521>. Kojima-san, can I describe all your problems? -- - Makoto `MAR' MATSUSHITA To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20010318141913L.matusita>