Loading...
--- Libc/Libc-583/locale/FreeBSD/localeconv.c.patch
+++ Libc/Libc-391/locale/FreeBSD/localeconv.c.patch
@@ -1,6 +1,6 @@
---- localeconv.c.orig 2008-10-09 11:37:42.000000000 -0700
-+++ localeconv.c 2008-10-10 01:37:33.000000000 -0700
-@@ -38,11 +38,71 @@ static char sccsid[] = "@(#)localeconv.c
+--- localeconv.c.orig 2004-11-25 11:38:18.000000000 -0800
++++ localeconv.c 2005-02-17 23:35:43.000000000 -0800
+@@ -38,11 +38,69 @@
#include <sys/cdefs.h>
__FBSDID("$FreeBSD: src/lib/libc/locale/localeconv.c,v 1.13 2003/06/26 10:46:16 phantom Exp $");
@@ -12,7 +12,6 @@
#include "lmonetary.h"
#include "lnumeric.h"
-+#ifdef __APPLE_PR3417676_HACK__
+/*------------------------------------------------------------------------
+ * PR-3417676: We need to provide a way to force "C" locale style number
+ * formatting independent of the locale setting. We provide private
@@ -67,12 +66,11 @@
+ _onlyClocaleconv = val;
+ return prev;
+}
-+#endif /* __APPLE_PR3417676_HACK__ */
+
/*
* The localeconv() function constructs a struct lconv from the current
* monetary and numeric locales.
-@@ -52,25 +112,28 @@ __FBSDID("$FreeBSD: src/lib/libc/locale/
+@@ -52,25 +110,37 @@
* lconv structure are computed only when the monetary or numeric
* locale has been changed.
*/
@@ -87,48 +85,52 @@
+localeconv_l(locale_t loc)
{
- static struct lconv ret;
-+ struct lconv *lc;
++ struct __xlocale_st_localeconv *lc;
+
+ NORMALIZE_LOCALE(loc);
++ if (loc->__lc_localeconv && !loc->__mlocale_changed && !loc->__nlocale_changed)
++ return &loc->__lc_localeconv->__ret;
++
++ lc = (struct __xlocale_st_localeconv *)malloc(sizeof(struct __xlocale_st_localeconv));
++ lc->__refcount = 1;
++ lc->__free_extra = NULL;
++ if (loc->__lc_localeconv)
++ lc->__ret = loc->__lc_localeconv->__ret;
++ else {
++ loc->__mlocale_changed = 1;
++ loc->__nlocale_changed = 1;
++ }
- if (__mlocale_changed) {
+ if (loc->__mlocale_changed) {
-+ XL_LOCK(loc);
-+ if (loc->__mlocale_changed) {
/* LC_MONETARY part */
struct lc_monetary_T * mptr;
-+ struct lconv *lc = &loc->__lc_localeconv;
-#define M_ASSIGN_STR(NAME) (ret.NAME = (char*)mptr->NAME)
-#define M_ASSIGN_CHAR(NAME) (ret.NAME = mptr->NAME[0])
-+#define M_ASSIGN_STR(NAME) (lc->NAME = (char*)mptr->NAME)
-+#define M_ASSIGN_CHAR(NAME) (lc->NAME = mptr->NAME[0])
++#define M_ASSIGN_STR(NAME) (lc->__ret.NAME = (char*)mptr->NAME)
++#define M_ASSIGN_CHAR(NAME) (lc->__ret.NAME = mptr->NAME[0])
- mptr = __get_current_monetary_locale();
+ mptr = __get_current_monetary_locale(loc);
M_ASSIGN_STR(int_curr_symbol);
M_ASSIGN_STR(currency_symbol);
M_ASSIGN_STR(mon_decimal_point);
-@@ -92,21 +155,45 @@ localeconv()
+@@ -92,21 +162,39 @@
M_ASSIGN_CHAR(int_n_sep_by_space);
M_ASSIGN_CHAR(int_p_sign_posn);
M_ASSIGN_CHAR(int_n_sign_posn);
- __mlocale_changed = 0;
+ loc->__mlocale_changed = 0;
-+ }
-+ XL_UNLOCK(loc);
}
- if (__nlocale_changed) {
+ if (loc->__nlocale_changed) {
-+ XL_LOCK(loc);
-+ if (loc->__nlocale_changed) {
/* LC_NUMERIC part */
struct lc_numeric_T * nptr;
-+ struct lconv *lc = &loc->__lc_localeconv;
-#define N_ASSIGN_STR(NAME) (ret.NAME = (char*)nptr->NAME)
-+#define N_ASSIGN_STR(NAME) (lc->NAME = (char*)nptr->NAME)
++#define N_ASSIGN_STR(NAME) (lc->__ret.NAME = (char*)nptr->NAME)
- nptr = __get_current_numeric_locale();
+ nptr = __get_current_numeric_locale(loc);
@@ -137,12 +139,13 @@
N_ASSIGN_STR(grouping);
- __nlocale_changed = 0;
+ loc->__nlocale_changed = 0;
-+ }
-+ XL_UNLOCK(loc);
}
- return (&ret);
-+ return &loc->__lc_localeconv;
++ XL_RELEASE(loc->__lc_localeconv);
++ loc->__lc_localeconv = lc;
++
++ return (&lc->__ret);
+}
+
+/*
@@ -151,13 +154,11 @@
+struct lconv *
+localeconv()
+{
-+#ifdef __APPLE_PR3417676_HACK__
+ /*--------------------------------------------------------------------
+ * If _onlyClocaleconv is non-zero, just return __lconv, which is a "C"
+ * struct lconv *. Otherwise, do the normal thing.
+ *--------------------------------------------------------------------*/
+ if (_onlyClocaleconv)
+ return &_C_lconv;
-+#endif /* __APPLE_PR3417676_HACK__ */
+ return localeconv_l(__current_locale());
}