aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBenjamin Kosnik <bkoz@redhat.com>2003-10-02 19:02:58 +0000
committerBenjamin Kosnik <bkoz@gcc.gnu.org>2003-10-02 19:02:58 +0000
commit5c109a17584d2a2d2126faabb0db2979635365dc (patch)
tree96d3b51677789265c4a94aebe9121a35f7083829
parentb59b5081384b68e33c1a50ef4d047f95e171c05d (diff)
downloadgcc-5c109a17584d2a2d2126faabb0db2979635365dc.zip
gcc-5c109a17584d2a2d2126faabb0db2979635365dc.tar.gz
gcc-5c109a17584d2a2d2126faabb0db2979635365dc.tar.bz2
locale.cc (locale::_S_initialize): Use __gthread_active_p.
2003-10-02 Benjamin Kosnik <bkoz@redhat.com> * src/locale.cc (locale::_S_initialize): Use __gthread_active_p. (locale::facet::_S_get_c_locale): Same. From-SVN: r72045
-rw-r--r--libstdc++-v3/ChangeLog5
-rw-r--r--libstdc++-v3/src/locale.cc22
2 files changed, 19 insertions, 8 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index 59b6bff..7224004 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,5 +1,10 @@
2003-10-02 Benjamin Kosnik <bkoz@redhat.com>
+ * src/locale.cc (locale::_S_initialize): Use __gthread_active_p.
+ (locale::facet::_S_get_c_locale): Same.
+
+2003-10-02 Benjamin Kosnik <bkoz@redhat.com>
+
* config/linker-map.gnu: Export _S_get_c_locale instead of
_S_c_locale object.
diff --git a/libstdc++-v3/src/locale.cc b/libstdc++-v3/src/locale.cc
index b37b30c..1ba83d1 100644
--- a/libstdc++-v3/src/locale.cc
+++ b/libstdc++-v3/src/locale.cc
@@ -385,11 +385,14 @@ namespace std
locale::_S_initialize()
{
#ifdef __GTHREADS
- __gthread_once(&_S_once, _S_initialize_once);
-#else
- if (!_S_classic)
- _S_initialize_once();
+ if (__gthread_active_p())
+ __gthread_once(&_S_once, _S_initialize_once);
+ else
#endif
+ {
+ if (!_S_classic)
+ _S_initialize_once();
+ }
}
void
@@ -472,11 +475,14 @@ namespace std
locale::facet::_S_get_c_locale()
{
#ifdef __GHTREADS
- __gthread_once(&_S_once, _S_initialize_once);
-#else
- if (!_S_c_locale)
- _S_initialize_once();
+ if (__gthread_active_p())
+ __gthread_once(&_S_once, _S_initialize_once);
+ else
#endif
+ {
+ if (!_S_c_locale)
+ _S_initialize_once();
+ }
return _S_c_locale;
}