X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmCommon.h;h=0af21208d3643698614776e408519bed1d07d5fb;hb=ccc795ae220f0d14496d0ef2473f66d8eae48c7a;hp=cc80d9e9e7cf87a04170d965ab7e74f1d733116c;hpb=29bdd1e88a28b6267618f633f304e1154537ce7b;p=gdcm.git diff --git a/src/gdcmCommon.h b/src/gdcmCommon.h index cc80d9e9..0af21208 100644 --- a/src/gdcmCommon.h +++ b/src/gdcmCommon.h @@ -1,8 +1,11 @@ //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 @@ -13,30 +16,74 @@ #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 +// 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"; @@ -46,11 +93,11 @@ typedef std::string TagName; enum FileType { Unknown = 0, - ExplicitVR, + ExplicitVR, // gdcmDicomDir is in this case ImplicitVR, ACR, ACR_LIBIDO }; - +//----------------------------------------------------------------------------- #endif