X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmGlobal.cxx;h=7ae08b6e0a16ed5277aad44ba21e2a28c9188dcc;hb=bd7bec4c367d671a9da358584e98a8ec29bb641e;hp=6411383e263f1013340426c33d55824ff3a8f6cf;hpb=ff8631dd8488e6604df635faf472ee85f5b8a4b6;p=gdcm.git diff --git a/src/gdcmGlobal.cxx b/src/gdcmGlobal.cxx index 6411383e..7ae08b6e 100644 --- a/src/gdcmGlobal.cxx +++ b/src/gdcmGlobal.cxx @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmGlobal.cxx,v $ Language: C++ - Date: $Date: 2005/02/02 15:07:41 $ - Version: $Revision: 1.18 $ + Date: $Date: 2007/09/17 12:20:01 $ + Version: $Revision: 1.37 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -21,29 +21,44 @@ #include "gdcmDebug.h" #include "gdcmVR.h" #include "gdcmTS.h" +#include "gdcmDictGroupName.h" #include "gdcmDictSet.h" #include "gdcmDicomDirElement.h" -namespace gdcm +namespace GDCM_NAME_SPACE { //----------------------------------------------------------------------------- -// 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 initialization 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"; +/// \brief Those global string that are returned 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 initialization 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"; +const std::string GDCM_NOTLOADED = "GDCM::NotLoaded"; +const std::string GDCM_UNREAD = "GDCM::UnRead"; +const std::string GDCM_NOTASCII = "GDCM::NotAscii"; +const std::string GDCM_PIXELDATA = "GDCM::Pixel Data to be loaded"; + +const char GDCM_VRUNKNOWN[2] = {' ',' '}; // avoid useless std::string stuff + +#ifdef _WIN32 +const char GDCM_FILESEPARATOR = '\\'; +#else +const char GDCM_FILESEPARATOR = '/'; +#endif //----------------------------------------------------------------------------- -DictSet *Global::Dicts = (DictSet *)0; -VR *Global::ValRes = (VR *)0; -TS *Global::TranSyn = (TS *)0; -DicomDirElement *Global::ddElem = (DicomDirElement *)0; +DictSet *Global::Dicts = (DictSet *)0; +VR *Global::ValRes = (VR *)0; +TS *Global::TranSyn = (TS *)0; +DictGroupName *Global::GroupName = (DictGroupName *)0; +DicomDirElement *Global::ddElem = (DicomDirElement *)0; + +Dict *Global::DefaultPubDict = (Dict *)0; //----------------------------------------------------------------------------- /** @@ -58,15 +73,16 @@ Global Glob; */ Global::Global() { - if (ValRes || TranSyn || Dicts || ddElem) + if (ValRes || TranSyn || Dicts || ddElem || GroupName ) { - gdcmVerboseMacro( "VR or TS or Dicts already allocated"); + gdcmStaticWarningMacro( "VR or TS or Dicts or ... already allocated"); return; } - Dicts = new DictSet(); - ValRes = new VR(); - TranSyn = new TS(); - ddElem = new DicomDirElement(); + Dicts = DictSet::New(); + ValRes = VR::New(); + TranSyn = TS::New(); + GroupName = DictGroupName::New(); + ddElem = DicomDirElement::New(); } /** @@ -74,45 +90,15 @@ Global::Global() */ Global::~Global() { - delete Dicts; - delete ValRes; - delete TranSyn; - delete ddElem; + Dicts->Delete(); + ValRes->Delete(); + TranSyn->Delete(); + GroupName->Delete(); + ddElem->Delete(); } //----------------------------------------------------------------------------- // Public -/** - * \brief returns a pointer to Dictionaries Table - */ -DictSet *Global::GetDicts() -{ - return Dicts; -} - -/** - * \brief returns a pointer to the 'Value Representation Table' - */ -VR *Global::GetVR() -{ - return ValRes; -} - -/** - * \brief returns a pointer to the 'Transfer Syntax Table' - */ -TS *Global::GetTS() -{ - return TranSyn; -} - -/** - * \brief returns a pointer to the DicomDir related elements Table - */ -DicomDirElement *Global::GetDicomDirElements() -{ - return ddElem; -} //----------------------------------------------------------------------------- // Protected