]> Creatis software - gdcm.git/commitdiff
BUG: Hopefully fix the bug on MacOSX and static global initialization. This is the...
authormalaterre <malaterre>
Mon, 10 Jan 2005 19:23:31 +0000 (19:23 +0000)
committermalaterre <malaterre>
Mon, 10 Jan 2005 19:23:31 +0000 (19:23 +0000)
src/gdcmCommon.h
src/gdcmGlobal.cxx

index 6f7b60054329a79e5d460af5476a3035efc21c3a..bbccb6b002dd482030a2ffcf8b867812899fd139 100644 (file)
@@ -3,8 +3,8 @@
   Program:   gdcm
   Module:    $RCSfile: gdcmCommon.h,v $
   Language:  C++
-  Date:      $Date: 2005/01/10 18:09:07 $
-  Version:   $Revision: 1.47 $
+  Date:      $Date: 2005/01/10 19:23:31 $
+  Version:   $Revision: 1.48 $
                                                                                 
   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
   l'Image). All rights reserved. See Doc/License.txt or
@@ -78,11 +78,27 @@ namespace gdcm
 #define DICT_TS           "dicomTS.dic"
 #define DICT_VR           "dicomVR.dic"
 
-GDCM_EXPORT extern const std::string GDCM_UNKNOWN;
-GDCM_EXPORT extern const std::string GDCM_UNFOUND;
-GDCM_EXPORT extern const std::string GDCM_BINLOADED;
-GDCM_EXPORT extern const std::string GDCM_NOTLOADED;
-GDCM_EXPORT extern const std::string GDCM_UNREAD;
+struct Dummy {};
+template<typename T>
+struct Strings_
+{
+    static std::string const UNKNOWN;
+    static std::string const UNFOUND;
+    static std::string const BINLOADED;
+    static std::string const NOTLOADED;
+    static std::string const UNREAD;
+};
+template<typename T> std::string const Strings_<T>::UNKNOWN   = "gdcm::Unknown";
+template<typename T> std::string const Strings_<T>::UNFOUND   = "gdcm::Unfound";
+template<typename T> std::string const Strings_<T>::BINLOADED = "gdcm::Binary data loaded";
+template<typename T> std::string const Strings_<T>::NOTLOADED = "gdcm::NotLoaded";
+template<typename T> std::string const Strings_<T>::UNREAD    = "gdcm::UnRead";
+typedef Strings_<Dummy> Strings;
+#define GDCM_UNKNOWN   Strings::UNKNOWN
+#define GDCM_UNFOUND   Strings::UNFOUND
+#define GDCM_BINLOADED Strings::BINLOADED
+#define GDCM_NOTLOADED Strings::NOTLOADED
+#define GDCM_UNREAD    Strings::UNREAD
 
 /// \brief TagKey is made to hold an "universal" (as in URL, Universal
 ///        Ressource Locator)  key to a DocEntry i.e. a dicom tag.
index e5597cb93db998d1a0cfd12ff98ad4400d29a0ab..d3dc6da82f04727cb14830b51df240a18f0da4c6 100644 (file)
@@ -3,8 +3,8 @@
   Program:   gdcm
   Module:    $RCSfile: gdcmGlobal.cxx,v $
   Language:  C++
-  Date:      $Date: 2005/01/09 00:13:26 $
-  Version:   $Revision: 1.11 $
+  Date:      $Date: 2005/01/10 19:23:31 $
+  Version:   $Revision: 1.12 $
                                                                                 
   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
   l'Image). All rights reserved. See Doc/License.txt or
 namespace gdcm 
 {
 
-// Those global string that are return by reference everywhere in gdcm code
-// used to be in gdcmCommon.h but due to a 'bug' in gcc/MacOSX
-// you cannot have static initialization in a multithreaded environment
-// since there is a lazy construction everything got skrew up somehow
-// Therefore the actual initiliazation is done in a cxx file (avoid
-// duplicated symbol), and an extern is used in gdcmCommon.h
-const std::string GDCM_UNKNOWN   = "gdcm::Unknown";
-const std::string GDCM_UNFOUND   = "gdcm::Unfound";
-const std::string GDCM_BINLOADED = "gdcm::Binary data loaded";
-const std::string GDCM_NOTLOADED = "gdcm::NotLoaded";
-const std::string GDCM_UNREAD    = "gdcm::UnRead";
-  
 /**
  * \ingroup Globals
  * \brief Pointer to a container, holding _all_ the Dicom Dictionaries.