+ static std::string Format(const char *format, ...);
+ static void Tokenize (const std::string &str,
+ std::vector<std::string> &tokens,
+ const std::string &delimiters = " ");
+ static int CountSubstring (const std::string &str,
+ const std::string &subStr);
+
+ static std::string CreateCleanString(std::string const &s);
+ static std::string CreateCleanString(uint8_t *s, int l);
+ static bool IsCleanString(std::string const &s);
+ static bool IsCleanArea(uint8_t *s, int l);
+ static void ReplaceSpecChar(std::string &s, std::string &rep);
+ static std::string NormalizePath(std::string const &name);
+ static std::string GetPath(std::string const &fullName);
+ static std::string GetName(std::string const &fullName);
+ static std::string GetCurrentDate();
+ static std::string GetCurrentTime();
+ static std::string GetCurrentDateTime();
+ /// Provides a simple static GetVersion() function
+ static std::string GetVersion()
+ { return GDCM_VERSION;}
+ static unsigned int GetCurrentThreadID();
+ static unsigned int GetCurrentProcessID();
+ static bool IsCurrentProcessorBigEndian();
+
+ static std::string DicomString(const char *s, size_t l);
+ static std::string DicomString(const char *s);
+ static bool DicomStringEqual(const std::string &s1, const char *s2);
+ static bool CompareDicomString(const std::string &s1,
+ const char *s2, int op);
+ static std::string GetMACAddress();
+
+ static std::string CreateUniqueUID(const std::string &root = "");
+ static void SetRootUID(const std::string &root = "");
+ static const std::string &GetRootUID();
+
+ static const uint8_t *GetFileMetaInformationVersion()
+ { return FileMetaInformationVersion;}
+ static void SetFileMetaInformationVersion( uint16_t fmiv )
+ { FileMetaInformationVersion = (uint8_t *)&fmiv; }
+
+// ----------------- to be removed later --------------------------
+//To perform a full check of inline functions on all the platforms,
+// we put here the two 'static' functions
+// hifpswap and hNoifpswap in a .h
+// They will be remove ASAP
+
+ inline void hifpswap(double *a, double *b)
+ {
+ double tmp;
+ tmp = *a;
+ *a = *b;
+ *b = tmp;
+ }
+ void hNoifpswap(double *a, double *b)
+ {
+ double tmp;
+ tmp = *a;
+ *a = *b;
+ *b = tmp;
+ }
+ void hfpswap(double *a, double *b);
+
+ static inline void sthifpswap(double *a, double *b)
+ {
+ double tmp;
+ tmp = *a;
+ *a = *b;
+ *b = tmp;
+ }
+ static void sthNoifpswap(double *a, double *b)
+ {
+ double tmp;
+ tmp = *a;
+ *a = *b;
+ *b = tmp;
+ }
+// ------------ end of functions to remove --------------------
+
+// For MD5
+static std::string ConvertToMD5 (std::string &stringToCrypt);