From 3950ffe2a485479f6561c27364d3d7df5a21d124 Mon Sep 17 00:00:00 2001 From: Igor Pashev Date: Sun, 24 Jun 2012 22:28:35 +0000 Subject: Imported Upstream version 93u+ --- src/lib/libast/comp/localeconv.c | 100 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 100 insertions(+) create mode 100644 src/lib/libast/comp/localeconv.c (limited to 'src/lib/libast/comp/localeconv.c') diff --git a/src/lib/libast/comp/localeconv.c b/src/lib/libast/comp/localeconv.c new file mode 100644 index 0000000..8cdc841 --- /dev/null +++ b/src/lib/libast/comp/localeconv.c @@ -0,0 +1,100 @@ +/*********************************************************************** +* * +* This software is part of the ast package * +* Copyright (c) 1985-2011 AT&T Intellectual Property * +* and is licensed under the * +* Eclipse Public License, Version 1.0 * +* by AT&T Intellectual Property * +* * +* A copy of the License is available at * +* http://www.eclipse.org/org/documents/epl-v10.html * +* (with md5 checksum b35adb5213ca9657e911e9befb180842) * +* * +* Information and Software Systems Research * +* AT&T Research * +* Florham Park NJ * +* * +* Glenn Fowler * +* David Korn * +* Phong Vo * +* * +***********************************************************************/ +#pragma prototyped + +/* + * localeconv() intercept + */ + +#include "lclib.h" + +#undef localeconv + +static char null[] = ""; + +static struct lconv debug_lconv = +{ + ",", + ".", + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, +}; + +static struct lconv default_lconv = +{ + ".", + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + &null[0], + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, + CHAR_MAX, +}; + +#if !_lib_localeconv + +struct lconv* +localeconv(void) +{ + return &default_lconv; +} + +#endif + +/* + * localeconv() intercept + */ + +struct lconv* +_ast_localeconv(void) +{ + if ((locales[AST_LC_MONETARY]->flags | locales[AST_LC_NUMERIC]->flags) & LC_debug) + return &debug_lconv; + if ((locales[AST_LC_NUMERIC]->flags & (LC_default|LC_local)) == LC_local) + return locales[AST_LC_NUMERIC]->territory == &lc_territories[0] ? &default_lconv : &debug_lconv; + return localeconv(); +} -- cgit v1.2.3