X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmCommon.h;h=0af21208d3643698614776e408519bed1d07d5fb;hb=0b36f4932e894a1dde4a80e614755816b4b29218;hp=a93fb998583583100ee9a05c567d29b734780c0b;hpb=153db29d779f82893684c6aac08b0a565dd84334;p=gdcm.git diff --git a/src/gdcmCommon.h b/src/gdcmCommon.h index a93fb998..0af21208 100644 --- a/src/gdcmCommon.h +++ b/src/gdcmCommon.h @@ -1,36 +1,103 @@ //gdcmCommon.h - +//----------------------------------------------------------------------------- #ifndef GDCMCOMMON_H #define GDCMCOMMON_H +#include "gdcmConfigure.h" + +//----------------------------------------------------------------------------- +//This is needed when compiling in debug mode +#ifdef _MSC_VER +// 'identifier' : class 'type' needs to have dll-interface to be used by +// clients of class 'type2' +#pragma warning ( disable : 4251 ) +// 'identifier' : identifier was truncated to 'number' characters in the +// debug information +#pragma warning ( disable : 4786 ) +//'identifier' : decorated name length exceeded, name was truncated +#pragma warning ( disable : 4503 ) +// C++ exception specification ignored except to indicate a +// function is not __declspec(nothrow) +#pragma warning ( disable : 4290 ) +// signed/unsigned mismatch +#pragma warning ( disable : 4018 ) +// return type for 'identifier' is '' (ie; not a UDT or reference to UDT. Will +// produce errors if applied using infix notation +#pragma warning ( disable : 4284 ) +// 'type' : forcing value to bool 'true' or 'false' (performance warning) +// //#pragma warning ( disable : 4800 ) +#endif //_MSC_VER + +//----------------------------------------------------------------------------- #ifdef __GNUC__ +#ifndef HAVE_NO_STDINT_H +//#if defined __STDC_LIMIT_MACROS +//#endif #include +//#ifdef UINT32_MAX +//#error hehrehhehehehe2 +//#endif #define guint16 uint16_t #define guint32 uint32_t #define gint16 int16_t #define gint32 int32_t +#else +typedef unsigned short guint16; +typedef unsigned int guint32; +typedef short gint16; +typedef int gint32; +#define UINT32_MAX (4294967295U) +#endif //HAVE_NO_STDINT_H #endif #ifdef _MSC_VER typedef unsigned short guint16; typedef unsigned int guint32; -typedef short gint16; -typedef int gint32; +typedef short gint16; +typedef int gint32; #define UINT32_MAX (4294967295U) #endif #ifdef _MSC_VER #define GDCM_EXPORT __declspec( dllexport ) +#define getcwd _getcwd #else #define GDCM_EXPORT #endif -#include -#ifdef _MSC_VER -using namespace std; // string type lives in the std namespace on VC++ +// ifdef for old gcc / broken compiler +#ifdef GDCM_NO_ANSI_STRING_STREAM +# include +# define ostringstream ostrstream +# else +# include +#endif + + +// Centralize information about the gdcm dictionary in only one file: +#ifndef PUB_DICT_PATH +# define PUB_DICT_PATH "../Dicts/" #endif +#define PUB_DICT_NAME "DicomV3Dict" +#define PUB_DICT_FILENAME "dicomV3.dic" +#define DICT_ELEM "DicomDir.dic" +#define DICT_TS "dicomTS.dic" +#define DICT_VR "dicomVR.dic" + +#include + +const std::string GDCM_UNFOUND = "gdcm::Unfound"; + +typedef std::string TagKey; +typedef std::string TagName; -typedef string TagKey; -typedef string TagName; +enum FileType { + Unknown = 0, + ExplicitVR, // gdcmDicomDir is in this case + ImplicitVR, + ACR, + ACR_LIBIDO +}; +//----------------------------------------------------------------------------- #endif