mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
0031037: Foundation Classes - add class Message_PrinterSystemLog for printing messages into system log
Added new class Message_PrinterSystemLog that can be used for logging messages into system log for debugging application in restricted environment.
This commit is contained in:
parent
cc99be369e
commit
a6a66c3a21
@ -108,6 +108,7 @@ else()
|
||||
elseif (ANDROID)
|
||||
set (CSF_ThreadLibs "c")
|
||||
set (CSF_OpenGlLibs "EGL GLESv2")
|
||||
set (CSF_androidlog "log")
|
||||
elseif (UNIX)
|
||||
set (CSF_ThreadLibs "pthread rt stdc++")
|
||||
if (USE_GLES2)
|
||||
|
@ -1419,6 +1419,9 @@ proc osutils:csfList { theOS theCsfLibsMap theCsfFrmsMap } {
|
||||
set aFrmsMap(CSF_TclTkLibs) "Tk"
|
||||
set aLibsMap(CSF_TclTkLibs) ""
|
||||
set aLibsMap(CSF_QT) "QtCore QtGui"
|
||||
} elseif { "$theOS" == "android" } {
|
||||
set aLibsMap(CSF_OpenGlLibs) "EGL GLESv2"
|
||||
set aLibsMap(CSF_androidlog) "log"
|
||||
} else {
|
||||
set aLibsMap(CSF_fontconfig) "fontconfig"
|
||||
if { "$theOS" == "qnx" } {
|
||||
|
@ -20,6 +20,8 @@ Message_Printer.cxx
|
||||
Message_Printer.hxx
|
||||
Message_PrinterOStream.cxx
|
||||
Message_PrinterOStream.hxx
|
||||
Message_PrinterSystemLog.cxx
|
||||
Message_PrinterSystemLog.hxx
|
||||
Message_ProgressIndicator.cxx
|
||||
Message_ProgressIndicator.hxx
|
||||
Message_ProgressIndicator.lxx
|
||||
|
190
src/Message/Message_PrinterSystemLog.cxx
Normal file
190
src/Message/Message_PrinterSystemLog.cxx
Normal file
@ -0,0 +1,190 @@
|
||||
// Copyright (c) 2019 OPEN CASCADE SAS
|
||||
//
|
||||
// This file is part of Open CASCADE Technology software library.
|
||||
//
|
||||
// This library is free software; you can redistribute it and/or modify it under
|
||||
// the terms of the GNU Lesser General Public License version 2.1 as published
|
||||
// by the Free Software Foundation, with special exception defined in the file
|
||||
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
||||
// distribution for complete text of the license and disclaimer of any warranty.
|
||||
//
|
||||
// Alternatively, this file may be used under the terms of Open CASCADE
|
||||
// commercial license or contractual agreement.
|
||||
|
||||
#ifdef _WIN32
|
||||
#include <windows.h>
|
||||
#endif
|
||||
|
||||
#include <Message_PrinterSystemLog.hxx>
|
||||
|
||||
#include <TCollection_ExtendedString.hxx>
|
||||
|
||||
#if defined(OCCT_UWP)
|
||||
//
|
||||
#elif defined(_WIN32)
|
||||
//! Convert message gravity into EventLog enumeration.
|
||||
static WORD getEventLogPriority (const Message_Gravity theGravity)
|
||||
{
|
||||
switch (theGravity)
|
||||
{
|
||||
case Message_Alarm:
|
||||
case Message_Fail:
|
||||
return EVENTLOG_ERROR_TYPE;
|
||||
case Message_Warning:
|
||||
return EVENTLOG_WARNING_TYPE;
|
||||
case Message_Info:
|
||||
case Message_Trace:
|
||||
return EVENTLOG_INFORMATION_TYPE;
|
||||
}
|
||||
return EVENTLOG_INFORMATION_TYPE;
|
||||
}
|
||||
#elif defined(__ANDROID__)
|
||||
#include <android/log.h>
|
||||
|
||||
//! Convert message gravity into Android log enumeration.
|
||||
static android_LogPriority getAndroidLogPriority (const Message_Gravity theGravity)
|
||||
{
|
||||
switch (theGravity)
|
||||
{
|
||||
case Message_Trace: return ANDROID_LOG_DEBUG;
|
||||
case Message_Info: return ANDROID_LOG_INFO;
|
||||
case Message_Warning: return ANDROID_LOG_WARN;
|
||||
case Message_Alarm: return ANDROID_LOG_ERROR;
|
||||
case Message_Fail: return ANDROID_LOG_ERROR;
|
||||
}
|
||||
return ANDROID_LOG_DEBUG;
|
||||
}
|
||||
#else
|
||||
#include <syslog.h>
|
||||
|
||||
//! Convert message gravity into syslog() enumeration.
|
||||
static int getSysLogPriority (const Message_Gravity theGravity)
|
||||
{
|
||||
switch (theGravity)
|
||||
{
|
||||
case Message_Trace: return LOG_DEBUG;
|
||||
case Message_Info: return LOG_INFO;
|
||||
case Message_Warning: return LOG_WARNING;
|
||||
case Message_Alarm: return LOG_ERR;
|
||||
case Message_Fail: return LOG_ERR;
|
||||
}
|
||||
return LOG_DEBUG;
|
||||
}
|
||||
#endif
|
||||
|
||||
IMPLEMENT_STANDARD_RTTIEXT(Message_PrinterSystemLog, Message_Printer)
|
||||
|
||||
//=======================================================================
|
||||
//function : Constructor
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
Message_PrinterSystemLog::Message_PrinterSystemLog (const TCollection_AsciiString& theEventSourceName,
|
||||
const Message_Gravity theTraceLevel)
|
||||
: myEventSourceName (theEventSourceName)
|
||||
{
|
||||
myTraceLevel = theTraceLevel;
|
||||
#if defined(OCCT_UWP)
|
||||
myEventSource = NULL;
|
||||
#elif defined(_WIN32)
|
||||
const TCollection_ExtendedString aWideSrcName (theEventSourceName);
|
||||
myEventSource = (Standard_Address )RegisterEventSourceW (NULL, aWideSrcName.ToWideString());
|
||||
#elif defined(__ANDROID__)
|
||||
//
|
||||
#else
|
||||
openlog (myEventSourceName.ToCString(), LOG_PID | LOG_NDELAY, LOG_USER);
|
||||
#endif
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : ~Message_PrinterSystemLog
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
Message_PrinterSystemLog::~Message_PrinterSystemLog()
|
||||
{
|
||||
#if defined(_WIN32)
|
||||
if (myEventSource != NULL)
|
||||
{
|
||||
#if !defined(OCCT_UWP)
|
||||
DeregisterEventSource ((HANDLE )myEventSource);
|
||||
#endif
|
||||
}
|
||||
#elif defined(__ANDROID__)
|
||||
//
|
||||
#else
|
||||
closelog();
|
||||
#endif
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : Send
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
void Message_PrinterSystemLog::Send (const Standard_CString theString,
|
||||
const Message_Gravity theGravity,
|
||||
const Standard_Boolean ) const
|
||||
{
|
||||
if (theGravity < myTraceLevel)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
#if defined(_WIN32)
|
||||
Send (TCollection_ExtendedString (theString), theGravity, true);
|
||||
#elif defined(__ANDROID__)
|
||||
__android_log_write (getAndroidLogPriority (theGravity), myEventSourceName.ToCString(), theString);
|
||||
#else
|
||||
syslog (getSysLogPriority (theGravity), "%s", theString);
|
||||
#endif
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : Send
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
void Message_PrinterSystemLog::Send (const TCollection_AsciiString& theString,
|
||||
const Message_Gravity theGravity,
|
||||
const Standard_Boolean ) const
|
||||
{
|
||||
if (theGravity < myTraceLevel)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
#if defined(_WIN32)
|
||||
Send (TCollection_ExtendedString (theString), theGravity, true);
|
||||
#elif defined(__ANDROID__)
|
||||
__android_log_write (getAndroidLogPriority (theGravity), myEventSourceName.ToCString(), theString.ToCString());
|
||||
#else
|
||||
syslog (getSysLogPriority (theGravity), "%s", theString.ToCString());
|
||||
#endif
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : Send
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
void Message_PrinterSystemLog::Send (const TCollection_ExtendedString& theString,
|
||||
const Message_Gravity theGravity,
|
||||
const Standard_Boolean ) const
|
||||
{
|
||||
if (theGravity < myTraceLevel)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
#if defined(_WIN32)
|
||||
if (myEventSource != NULL)
|
||||
{
|
||||
#if !defined(OCCT_UWP)
|
||||
const WORD aLogType = getEventLogPriority (theGravity);
|
||||
const wchar_t* aMessage[1] = { theString.ToWideString() };
|
||||
ReportEventW ((HANDLE )myEventSource, aLogType, 0, 0, NULL,
|
||||
1, 0, aMessage, NULL);
|
||||
#else
|
||||
(void )theString;
|
||||
#endif
|
||||
}
|
||||
#else
|
||||
Send (TCollection_AsciiString (theString), theGravity, true);
|
||||
#endif
|
||||
}
|
63
src/Message/Message_PrinterSystemLog.hxx
Normal file
63
src/Message/Message_PrinterSystemLog.hxx
Normal file
@ -0,0 +1,63 @@
|
||||
// Copyright (c) 2019 OPEN CASCADE SAS
|
||||
//
|
||||
// This file is part of Open CASCADE Technology software library.
|
||||
//
|
||||
// This library is free software; you can redistribute it and/or modify it under
|
||||
// the terms of the GNU Lesser General Public License version 2.1 as published
|
||||
// by the Free Software Foundation, with special exception defined in the file
|
||||
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
||||
// distribution for complete text of the license and disclaimer of any warranty.
|
||||
//
|
||||
// Alternatively, this file may be used under the terms of Open CASCADE
|
||||
// commercial license or contractual agreement.
|
||||
|
||||
#ifndef _Message_PrinterSystemLog_HeaderFile
|
||||
#define _Message_PrinterSystemLog_HeaderFile
|
||||
|
||||
#include <Message_Printer.hxx>
|
||||
#include <TCollection_AsciiString.hxx>
|
||||
|
||||
DEFINE_STANDARD_HANDLE(Message_PrinterSystemLog, Message_Printer)
|
||||
|
||||
//! Implementation of a message printer associated with system log.
|
||||
//! Implemented for the following systems:
|
||||
//! - Windows, through ReportEventW().
|
||||
//! - Android, through __android_log_write().
|
||||
//! - UNIX/Linux, through syslog().
|
||||
class Message_PrinterSystemLog : public Message_Printer
|
||||
{
|
||||
DEFINE_STANDARD_RTTIEXT(Message_PrinterSystemLog, Message_Printer)
|
||||
public:
|
||||
|
||||
//! Main constructor.
|
||||
Standard_EXPORT Message_PrinterSystemLog (const TCollection_AsciiString& theEventSourceName,
|
||||
const Message_Gravity theTraceLevel = Message_Info);
|
||||
|
||||
//! Destructor.
|
||||
Standard_EXPORT virtual ~Message_PrinterSystemLog();
|
||||
|
||||
//! Puts a message to the system log.
|
||||
Standard_EXPORT virtual void Send (const Standard_CString theString,
|
||||
const Message_Gravity theGravity,
|
||||
const Standard_Boolean theToPutEndl) const Standard_OVERRIDE;
|
||||
|
||||
//! Puts a message to the system log.
|
||||
Standard_EXPORT virtual void Send (const TCollection_AsciiString& theString,
|
||||
const Message_Gravity theGravity,
|
||||
const Standard_Boolean theToPutEndl) const Standard_OVERRIDE;
|
||||
|
||||
//! Puts a message to the system log.
|
||||
Standard_EXPORT virtual void Send (const TCollection_ExtendedString& theString,
|
||||
const Message_Gravity theGravity,
|
||||
const Standard_Boolean theToPutEndl) const Standard_OVERRIDE;
|
||||
|
||||
private:
|
||||
|
||||
TCollection_AsciiString myEventSourceName;
|
||||
#ifdef _WIN32
|
||||
Standard_Address myEventSource;
|
||||
#endif
|
||||
|
||||
};
|
||||
|
||||
#endif // _Message_PrinterSystemLog_HeaderFile
|
@ -6,3 +6,4 @@ CSF_TBB
|
||||
CSF_dl
|
||||
CSF_wsock32
|
||||
CSF_psapi
|
||||
CSF_androidlog
|
||||
|
Loading…
x
Reference in New Issue
Block a user