diff options
author | Benjamin Kosnik <bkoz@redhat.com> | 2003-10-02 19:02:58 +0000 |
---|---|---|
committer | Benjamin Kosnik <bkoz@gcc.gnu.org> | 2003-10-02 19:02:58 +0000 |
commit | 5c109a17584d2a2d2126faabb0db2979635365dc (patch) | |
tree | 96d3b51677789265c4a94aebe9121a35f7083829 | |
parent | b59b5081384b68e33c1a50ef4d047f95e171c05d (diff) | |
download | gcc-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/ChangeLog | 5 | ||||
-rw-r--r-- | libstdc++-v3/src/locale.cc | 22 |
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; } |