diff options
author | phantom <phantom@FreeBSD.org> | 2001-02-08 17:12:03 +0000 |
---|---|---|
committer | phantom <phantom@FreeBSD.org> | 2001-02-08 17:12:03 +0000 |
commit | 043f9a3fa125234f92fcc46997e94d02c4cd9a9f (patch) | |
tree | 76a58dfc4beba4e98f9dccbad732d03c494cd3b5 /lib/libc/locale | |
parent | 028f19b91babc2e886d672bba3c18a4bd2dc1362 (diff) | |
download | FreeBSD-src-043f9a3fa125234f92fcc46997e94d02c4cd9a9f.zip FreeBSD-src-043f9a3fa125234f92fcc46997e94d02c4cd9a9f.tar.gz |
Add SUSv2 compatible nl_langinfo() function. It still need some work, but
this is already usable one.
Diffstat (limited to 'lib/libc/locale')
-rw-r--r-- | lib/libc/locale/nl_langinfo.c | 130 |
1 files changed, 130 insertions, 0 deletions
diff --git a/lib/libc/locale/nl_langinfo.c b/lib/libc/locale/nl_langinfo.c new file mode 100644 index 0000000..f017d26 --- /dev/null +++ b/lib/libc/locale/nl_langinfo.c @@ -0,0 +1,130 @@ +/*- + * Copyright (c) 2001 Alexey Zelkin + * 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 AUTHOR AND CONTRIBUTORS ``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 AUTHOR OR CONTRIBUTORS 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. + * + * $FreeBSD$ + */ + +#include "langinfo.h" +#include "../stdtime/timelocal.h" +#include "lnumeric.h" +#include "lmonetary.h" +#include "lmessages.h" + +#define _REL(BASE) ((int)item-BASE) + +char * +nl_langinfo(nl_item item) { + + char *ret; + + switch (item) { + case CODESET: + ret = ""; /* XXX: need to be implemented */ + break; + case D_T_FMT: + /* XXX: ???, this is compatibility field for FreeBSD */ + ret = (char *) __get_current_time_locale()->c_fmt; + break; + case D_FMT: + ret = (char *) __get_current_time_locale()->x_fmt; + break; + case T_FMT: + ret = (char *) __get_current_time_locale()->X_fmt; + break; + case T_FMT_AMPM: + /* XXX: ??? */ + ret = ""; + break; + case AM_STR: + ret = (char *) __get_current_time_locale()->am; + break; + case PM_STR: + ret = (char *) __get_current_time_locale()->pm; + break; + case DAY_1: case DAY_2: case DAY_3: + case DAY_4: case DAY_5: case DAY_6: case DAY_7: + ret = (char*) __get_current_time_locale()->weekday[_REL(DAY_1)]; + break; + case ABDAY_1: case ABDAY_2: case ABDAY_3: + case ABDAY_4: case ABDAY_5: case ABDAY_6: case ABDAY_7: + ret = (char*) __get_current_time_locale()->wday[_REL(ABDAY_1)]; + break; + case MON_1: case MON_2: case MON_3: case MON_4: + case MON_5: case MON_6: case MON_7: case MON_8: + case MON_9: case MON_10: case MON_11: case MON_12: + ret = (char*) __get_current_time_locale()->month[_REL(MON_1)]; + break; + case ABMON_1: case ABMON_2: case ABMON_3: case ABMON_4: + case ABMON_5: case ABMON_6: case ABMON_7: case ABMON_8: + case ABMON_9: case ABMON_10: case ABMON_11: case ABMON_12: + ret = (char*) __get_current_time_locale()->mon[_REL(ABMON_1)]; + break; + case ERA: + /* XXX: ??? */ + ret = ""; + break; + case ERA_D_FMT: + /* XXX: ??? */ + ret = ""; + break; + case ERA_D_T_FMT: + /* XXX: ??? */ + ret = ""; + break; + case ERA_T_FMT: + /* XXX: ??? */ + ret = ""; + break; + case ALT_DIGITS: + /* XXX: ??? */ + ret = ""; + break; + case RADIXCHAR: + ret = (char*) __get_current_numeric_locale()->decimal_point; + break; + case THOUSEP: + ret = (char*) __get_current_numeric_locale()->thousands_sep; + break; + case YESEXPR: + ret = (char*) __get_current_messages_locale()->yesexpr; + break; + case NOEXPR: + ret = (char*) __get_current_messages_locale()->noexpr; + break; + case YESSTR: + ret = (char*) __get_current_messages_locale()->yesstr; + break; + case NOSTR: + ret = (char*) __get_current_messages_locale()->nostr; + break; + case CRNCYSTR: + /* XXX: ??? */ + ret = ""; + break; + default: + ret = ""; + } + return (ret); +} |