X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmCommon.h;h=0af21208d3643698614776e408519bed1d07d5fb;hb=c5618e6b8276e1b21bbea354fe8bcba3c78eb4bd;hp=5647a486f3ab2d61b46ce586e5fb786057394fc9;hpb=45bf98d79625d7efdb227b07c8746a918b49568b;p=gdcm.git diff --git a/src/gdcmCommon.h b/src/gdcmCommon.h index 5647a486..0af21208 100644 --- a/src/gdcmCommon.h +++ b/src/gdcmCommon.h @@ -3,6 +3,9 @@ #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 @@ -21,15 +24,19 @@ // 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 -// Mmmmmm ! -// It reminds me the formerly well known LibIDO's idproto.h - //----------------------------------------------------------------------------- #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 @@ -37,8 +44,8 @@ #else 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 //HAVE_NO_STDINT_H #endif @@ -46,17 +53,37 @@ typedef int gint32; #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 +// 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"; @@ -66,15 +93,11 @@ typedef std::string TagName; enum FileType { Unknown = 0, - ExplicitVR, + ExplicitVR, // gdcmDicomDir is in this case ImplicitVR, ACR, - ACR_LIBIDO, - DICOMDIR + ACR_LIBIDO }; -//For now gdcm is not willing cmake, try to be more quiet -//#cmakedefine GDCM_NO_ANSI_STRING_STREAM - //----------------------------------------------------------------------------- #endif