X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=src%2FgdcmCommon.h;h=5647a486f3ab2d61b46ce586e5fb786057394fc9;hb=4a07b1470f68d316f570fef1f07b9f9c77e90ee1;hp=f243d8421bd2bb09dedd3441cadd6822cd6d8760;hpb=ee65673385a2d6192d7d64ed0339bd47515de805;p=gdcm.git diff --git a/src/gdcmCommon.h b/src/gdcmCommon.h index f243d842..5647a486 100644 --- a/src/gdcmCommon.h +++ b/src/gdcmCommon.h @@ -1,14 +1,46 @@ //gdcmCommon.h - +//----------------------------------------------------------------------------- #ifndef GDCMCOMMON_H #define GDCMCOMMON_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 ) +#endif //_MSC_VER + +// Mmmmmm ! +// It reminds me the formerly well known LibIDO's idproto.h + +//----------------------------------------------------------------------------- #ifdef __GNUC__ +#ifndef HAVE_NO_STDINT_H #include #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 @@ -26,20 +58,23 @@ typedef int gint32; #endif #include -#ifdef _MSC_VER -using namespace std; // string type lives in the std namespace on VC++ -#endif -typedef string TagKey; -typedef string TagName; +const std::string GDCM_UNFOUND = "gdcm::Unfound"; + +typedef std::string TagKey; +typedef std::string TagName; enum FileType { Unknown = 0, ExplicitVR, ImplicitVR, ACR, - ACR_LIBIDO -}; // CLEANME + ACR_LIBIDO, + DICOMDIR +}; +//For now gdcm is not willing cmake, try to be more quiet +//#cmakedefine GDCM_NO_ANSI_STRING_STREAM +//----------------------------------------------------------------------------- #endif