mirror of
https://github.com/ruby/ruby.git
synced 2025-08-15 13:39:04 +02:00
strftime.c: fix locale modifier
partially borrowed from ext/date. * strftime.c (rb_strftime_with_timespec): check conversion with locale modifier. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@35835 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
60683816be
commit
241902e709
3 changed files with 28 additions and 5 deletions
10
strftime.c
10
strftime.c
|
@ -187,7 +187,7 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi
|
|||
long y;
|
||||
int precision, flags, colons;
|
||||
char padding;
|
||||
enum {LEFT, CHCASE, LOWER, UPPER, LOCALE_O, LOCALE_E};
|
||||
enum {LEFT, CHCASE, LOWER, UPPER};
|
||||
#define BIT_OF(n) (1U<<(n))
|
||||
#ifdef MAILHEADER_EXT
|
||||
int sign;
|
||||
|
@ -222,7 +222,7 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi
|
|||
|
||||
for (; *format && s < endp - 1; format++) {
|
||||
#define FLAG_FOUND() do { \
|
||||
if (precision > 0 || flags & (BIT_OF(LOCALE_E)|BIT_OF(LOCALE_O))) \
|
||||
if (precision > 0) \
|
||||
goto unknown; \
|
||||
} while (0)
|
||||
#define NEEDS(n) do if (s >= endp || (n) >= endp - s - 1) goto err; while (0)
|
||||
|
@ -608,11 +608,13 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi
|
|||
|
||||
case 'E':
|
||||
/* POSIX locale extensions, ignored for now */
|
||||
flags |= BIT_OF(LOCALE_E);
|
||||
if (!format[1] || !strchr("cCxXyY", format[1]))
|
||||
goto unknown;
|
||||
goto again;
|
||||
case 'O':
|
||||
/* POSIX locale extensions, ignored for now */
|
||||
flags |= BIT_OF(LOCALE_O);
|
||||
if (!format[1] || !strchr("deHkIlmMSuUVwWy", format[1]))
|
||||
goto unknown;
|
||||
goto again;
|
||||
|
||||
case 'V': /* week of year according ISO 8601 */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue