0031037: Foundation Classes - add class Message_PrinterSystemLog for printing message...
[occt.git] / src / Message / Message_PrinterSystemLog.cxx
1 // Copyright (c) 2019 OPEN CASCADE SAS
2 //
3 // This file is part of Open CASCADE Technology software library.
4 //
5 // This library is free software; you can redistribute it and/or modify it under
6 // the terms of the GNU Lesser General Public License version 2.1 as published
7 // by the Free Software Foundation, with special exception defined in the file
8 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9 // distribution for complete text of the license and disclaimer of any warranty.
10 //
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
13
14 #ifdef _WIN32
15   #include <windows.h>
16 #endif
17
18 #include <Message_PrinterSystemLog.hxx>
19
20 #include <TCollection_ExtendedString.hxx>
21
22 #if defined(OCCT_UWP)
23   //
24 #elif defined(_WIN32)
25   //! Convert message gravity into EventLog enumeration.
26   static WORD getEventLogPriority (const Message_Gravity theGravity)
27   {
28     switch (theGravity)
29     {
30       case Message_Alarm:
31       case Message_Fail:
32         return EVENTLOG_ERROR_TYPE;
33       case Message_Warning:
34         return EVENTLOG_WARNING_TYPE;
35       case Message_Info:
36       case Message_Trace:
37         return EVENTLOG_INFORMATION_TYPE;
38     }
39     return EVENTLOG_INFORMATION_TYPE;
40   }
41 #elif defined(__ANDROID__)
42   #include <android/log.h>
43
44   //! Convert message gravity into Android log enumeration.
45   static android_LogPriority getAndroidLogPriority (const Message_Gravity theGravity)
46   {
47     switch (theGravity)
48     {
49       case Message_Trace:   return ANDROID_LOG_DEBUG;
50       case Message_Info:    return ANDROID_LOG_INFO;
51       case Message_Warning: return ANDROID_LOG_WARN;
52       case Message_Alarm:   return ANDROID_LOG_ERROR;
53       case Message_Fail:    return ANDROID_LOG_ERROR;
54     }
55     return ANDROID_LOG_DEBUG;
56   }
57 #else
58   #include <syslog.h>
59
60   //! Convert message gravity into syslog() enumeration.
61   static int getSysLogPriority (const Message_Gravity theGravity)
62   {
63     switch (theGravity)
64     {
65       case Message_Trace:   return LOG_DEBUG;
66       case Message_Info:    return LOG_INFO;
67       case Message_Warning: return LOG_WARNING;
68       case Message_Alarm:   return LOG_ERR;
69       case Message_Fail:    return LOG_ERR;
70     }
71     return LOG_DEBUG;
72   }
73 #endif
74
75 IMPLEMENT_STANDARD_RTTIEXT(Message_PrinterSystemLog, Message_Printer)
76
77 //=======================================================================
78 //function : Constructor
79 //purpose  :
80 //=======================================================================
81 Message_PrinterSystemLog::Message_PrinterSystemLog (const TCollection_AsciiString& theEventSourceName,
82                                                     const Message_Gravity theTraceLevel)
83 : myEventSourceName (theEventSourceName)
84 {
85   myTraceLevel = theTraceLevel;
86 #if defined(OCCT_UWP)
87   myEventSource = NULL;
88 #elif defined(_WIN32)
89   const TCollection_ExtendedString aWideSrcName (theEventSourceName);
90   myEventSource = (Standard_Address )RegisterEventSourceW (NULL, aWideSrcName.ToWideString());
91 #elif defined(__ANDROID__)
92   //
93 #else
94   openlog (myEventSourceName.ToCString(), LOG_PID | LOG_NDELAY, LOG_USER);
95 #endif
96 }
97
98 //=======================================================================
99 //function : ~Message_PrinterSystemLog
100 //purpose  :
101 //=======================================================================
102 Message_PrinterSystemLog::~Message_PrinterSystemLog()
103 {
104 #if defined(_WIN32)
105   if (myEventSource != NULL)
106   {
107   #if !defined(OCCT_UWP)
108     DeregisterEventSource ((HANDLE )myEventSource);
109   #endif
110   }
111 #elif defined(__ANDROID__)
112   //
113 #else
114   closelog();
115 #endif
116 }
117
118 //=======================================================================
119 //function : Send
120 //purpose  :
121 //=======================================================================
122 void Message_PrinterSystemLog::Send (const Standard_CString theString,
123                                      const Message_Gravity theGravity,
124                                      const Standard_Boolean ) const
125 {
126   if (theGravity < myTraceLevel)
127   {
128     return;
129   }
130
131 #if defined(_WIN32)
132   Send (TCollection_ExtendedString (theString), theGravity, true);
133 #elif defined(__ANDROID__)
134   __android_log_write (getAndroidLogPriority (theGravity), myEventSourceName.ToCString(), theString);
135 #else
136   syslog (getSysLogPriority (theGravity), "%s", theString);
137 #endif
138 }
139
140 //=======================================================================
141 //function : Send
142 //purpose  :
143 //=======================================================================
144 void Message_PrinterSystemLog::Send (const TCollection_AsciiString& theString,
145                                      const Message_Gravity theGravity,
146                                      const Standard_Boolean ) const
147 {
148   if (theGravity < myTraceLevel)
149   {
150     return;
151   }
152
153 #if defined(_WIN32)
154   Send (TCollection_ExtendedString (theString), theGravity, true);
155 #elif defined(__ANDROID__)
156   __android_log_write (getAndroidLogPriority (theGravity), myEventSourceName.ToCString(), theString.ToCString());
157 #else
158   syslog (getSysLogPriority (theGravity), "%s", theString.ToCString());
159 #endif
160 }
161
162 //=======================================================================
163 //function : Send
164 //purpose  :
165 //=======================================================================
166 void Message_PrinterSystemLog::Send (const TCollection_ExtendedString& theString,
167                                      const Message_Gravity theGravity,
168                                      const Standard_Boolean ) const
169 {
170   if (theGravity < myTraceLevel)
171   {
172     return;
173   }
174
175 #if defined(_WIN32)
176   if (myEventSource != NULL)
177   {
178   #if !defined(OCCT_UWP)
179     const WORD aLogType = getEventLogPriority (theGravity);
180     const wchar_t* aMessage[1] = { theString.ToWideString() };
181     ReportEventW ((HANDLE )myEventSource, aLogType, 0, 0, NULL,
182                   1, 0, aMessage, NULL);
183   #else
184     (void )theString;
185   #endif
186   }
187 #else
188   Send (TCollection_AsciiString (theString), theGravity, true);
189 #endif
190 }