]> SALOME platform Git repositories - modules/kernel.git/blob - src/Basics/Basics_Utils.hxx
Salome HOME
Merge from V6_main_20120808 08Aug12
[modules/kernel.git] / src / Basics / Basics_Utils.hxx
1 // Copyright (C) 2007-2012  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License.
7 //
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 // Lesser General Public License for more details.
12 //
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
16 //
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
18 //
19
20 //  SALOME Utils : general SALOME's definitions and tools
21 //  File   : Basics_DirUtils.hxx
22 //  Autor  : Alexander A. BORODIN
23 //  Module : SALOME
24 //
25 #ifndef _Basics_UTILS_HXX_
26 #define _Basics_UTILS_HXX_
27
28 #include "SALOME_Basics.hxx"
29 #include <string>
30 #include <iostream>
31
32 #ifndef WIN32
33 #include <sys/time.h>
34 #else
35 #include <winsock2.h>
36 #include <windows.h>
37 #pragma comment(lib,"winmm.lib")
38 #endif
39
40
41 namespace Kernel_Utils
42 {
43   BASICS_EXPORT std::string GetHostname();
44
45   class BASICS_EXPORT Localizer
46   {
47   public:
48     Localizer();
49     ~Localizer();
50   private:
51     std::string myCurLocale;
52   };
53   
54   //! GUID type
55   enum GUIDtype {
56     DefUserID = 1,  //!< Default user attribute ID
57     ObjectdID       //!< Global usage object identifier ID
58   };
59
60   //! Get predefined GUID
61   BASICS_EXPORT std::string GetGUID( GUIDtype );
62 #ifndef WIN32
63   BASICS_EXPORT void print_traceback();
64 #endif
65 }
66
67
68 //
69 // =============================================================
70 // Helper macro for time analysis
71 // =============================================================
72 //
73 #ifndef WIN32
74 #define START_TIMING(name) static long name##tcount=0;static long name##cumul;long name##tt0; timeval name##tv; gettimeofday(&name##tv,0); \
75                            name##tt0=name##tv.tv_usec+name##tv.tv_sec*1000000; \
76                            if(name##tcount==0)std::cerr<<__FILE__<<":"<<__LINE__<<":"<<#name<<std::endl;
77
78 #define END_TIMING(name,NUMBER) name##tcount=name##tcount+1;gettimeofday(&name##tv,0); \
79                                 name##cumul=name##cumul+name##tv.tv_usec+name##tv.tv_sec*1000000 -name##tt0; \
80                                 if(name##tcount==NUMBER){ \
81                                   std::cerr <<__FILE__<<":"<<__LINE__<<":"<<#name<<" temps CPU(mus): "<< name##cumul<<std::endl; \
82                                   name##tcount=0;name##cumul=0;}
83 #else
84
85 #define START_TIMING(name) static long name##tcount=0;static DWORD name##cumul;DWORD  name##tv;DWORD  name##tt0 = timeGetTime(); \
86                            if(name##tcount==0)std::cerr<<__FILE__<<":"<<__LINE__<<":"<<#name<<std::endl;
87
88 #define END_TIMING(name,NUMBER) name##tcount=name##tcount+1; name##tv = timeGetTime(); \
89                                 name##cumul=name##cumul+name##tv - name##tt0; \
90                                 if(name##tcount==NUMBER){ \
91                                   std::cerr <<__FILE__<<":"<<__LINE__<<":"<<#name<<" temps CPU(mus): "<< name##cumul<<std::endl; \
92                                   name##tcount=0;name##cumul=0;}
93 #endif
94
95
96
97 //
98 // =============================================================
99 // Macro and template functions for type conversions.
100 // =============================================================
101 //
102 #include <string>
103 #include <sstream>
104 #include <stdlib.h>
105
106 template < class T >
107 std::string ToString(const T &arg)
108 {
109   std::stringstream out;
110   out << arg;
111   return(out.str());
112 }
113
114 template < class T >
115 double ToDouble(const T &arg) {
116   std::stringstream out;
117   out << arg;
118   double value = atof(out.str().c_str());
119   return value;
120 }
121
122 //
123 // =============================================================
124 // Simple Logger macros (no dependency with SALOME)
125 // =============================================================
126 //
127 #define STDLOG(msg) {std::cerr<<std::flush<<__FILE__<<" ["<<__LINE__<<"] : "<<msg<<std::endl<<std::flush;}
128 #ifdef LOG
129 #undef LOG
130 #endif
131 #define LOG STDLOG
132
133
134 #endif //_Basics_UTILS_HXX_