Классы и пример для журналирования (простой вывод и в syslog)
This commit is contained in:
parent
b21def5945
commit
347ef3d46d
53
examples/qt/03_message-logger/CMakeLists.txt
Normal file
53
examples/qt/03_message-logger/CMakeLists.txt
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
# Название основной цели в текущем каталоге
|
||||||
|
set(TRGT example-qt-message-logger)
|
||||||
|
|
||||||
|
# Список файлов исходных текстов
|
||||||
|
set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/message_logger.cpp)
|
||||||
|
|
||||||
|
if(MYXLIB_BUILD_EXAMPLES)
|
||||||
|
# Путь поиска библиотек внутри проекта
|
||||||
|
link_directories(${CMAKE_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR})
|
||||||
|
|
||||||
|
# Цель для создания исполняемого файла
|
||||||
|
add_executable(${TRGT} ${TRGT_cpp})
|
||||||
|
common_target_properties(${TRGT})
|
||||||
|
|
||||||
|
# Создание цели для проверки утилитой clang-tidy
|
||||||
|
add_clang_tidy_check(${TRGT} ${TRGT_cpp})
|
||||||
|
|
||||||
|
# Создание цели для проверки утилитой clang-analyze
|
||||||
|
add_clang_analyze_check(${TRGT} ${TRGT_cpp})
|
||||||
|
|
||||||
|
# Создание цели для проверки утилитой clazy
|
||||||
|
add_clazy_check(${TRGT} ${TRGT_cpp})
|
||||||
|
|
||||||
|
# Создание цели для проверки утилитой pvs-studio
|
||||||
|
add_pvs_check(${TRGT})
|
||||||
|
|
||||||
|
# Создание цели для автоматического форматирования кода
|
||||||
|
add_format_sources(${TRGT} ${TRGT_cpp})
|
||||||
|
|
||||||
|
# Qt5
|
||||||
|
target_include_directories(${TRGT} PRIVATE ${CMAKE_SOURCE_DIR}/src)
|
||||||
|
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
|
||||||
|
|
||||||
|
target_include_directories(${TRGT} SYSTEM PRIVATE ${CMAKE_SOURCE_DIR}/src)
|
||||||
|
add_dependencies(${TRGT} core qt)
|
||||||
|
|
||||||
|
target_link_libraries(${TRGT} qt_static)
|
||||||
|
|
||||||
|
target_link_libraries(${TRGT} Qt5::Core)
|
||||||
|
target_link_libraries(${TRGT} Threads::Threads)
|
||||||
|
|
||||||
|
# Имя выходного файла для цели
|
||||||
|
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME qt-message-logger)
|
||||||
|
|
||||||
|
add_sanitizers(${TRGT})
|
||||||
|
|
||||||
|
cotire(${TRGT})
|
||||||
|
|
||||||
|
add_dependencies(${TRGT} create_auxilary_symlinks)
|
||||||
|
|
||||||
|
# Правила для установки
|
||||||
|
# install(TARGETS ${TRGT} COMPONENT examples RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
|
||||||
|
endif()
|
29
examples/qt/03_message-logger/message_logger.cpp
Normal file
29
examples/qt/03_message-logger/message_logger.cpp
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
#include <myx/qt/message_logger_default.hpp>
|
||||||
|
#include <myx/qt/message_logger_handler.hpp>
|
||||||
|
#include <myx/qt/message_logger_syslog.hpp>
|
||||||
|
|
||||||
|
#include <QCoreApplication>
|
||||||
|
#include <QDebug>
|
||||||
|
|
||||||
|
namespace MQ = myx::qt;
|
||||||
|
int main( int argc, char* argv[] )
|
||||||
|
{
|
||||||
|
QCoreApplication app( argc, argv );
|
||||||
|
|
||||||
|
auto mld = QSharedPointer< MQ::MessageLoggerDefault >( new MQ::MessageLoggerDefault );
|
||||||
|
MQ::messageLoggersList.append( mld );
|
||||||
|
MQ::messageLoggersList.append( mld );
|
||||||
|
auto mls = QSharedPointer< MQ::MessageLoggerSyslog >( new MQ::MessageLoggerSyslog );
|
||||||
|
MQ::messageLoggersList.append( mls );
|
||||||
|
qInstallMessageHandler( MQ::message_logger_handler );
|
||||||
|
|
||||||
|
qDebug() << "Hello from process:" << QCoreApplication::applicationPid();
|
||||||
|
qWarning() << "Warning";
|
||||||
|
|
||||||
|
qInstallMessageHandler( 0 );
|
||||||
|
|
||||||
|
qDebug() << "Reset user handlers";
|
||||||
|
qWarning() << "Goodbye";
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
|
}
|
@ -1,2 +1,3 @@
|
|||||||
add_subdirectory(01_translators)
|
add_subdirectory(01_translators)
|
||||||
add_subdirectory(02_posix-signal-watcher)
|
add_subdirectory(02_posix-signal-watcher)
|
||||||
|
add_subdirectory(03_message-logger)
|
||||||
|
@ -6,6 +6,9 @@ set(TRGT qt)
|
|||||||
set(TRGT_cpp
|
set(TRGT_cpp
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/posix_signal_watcher.cpp
|
${CMAKE_CURRENT_SOURCE_DIR}/posix_signal_watcher.cpp
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/translators.cpp
|
${CMAKE_CURRENT_SOURCE_DIR}/translators.cpp
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_default.cpp
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_handler.cpp
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_syslog.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
set(TRGT_moc_hpp
|
set(TRGT_moc_hpp
|
||||||
@ -18,6 +21,10 @@ set(TRGT_moc_private_hpp
|
|||||||
|
|
||||||
set(TRGT_hpp
|
set(TRGT_hpp
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/translators.hpp
|
${CMAKE_CURRENT_SOURCE_DIR}/translators.hpp
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/message_logger.hpp
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_default.hpp
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_handler.hpp
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_syslog.hpp
|
||||||
)
|
)
|
||||||
|
|
||||||
set(TRGT_headers ${TRGT_moc_hpp} ${TRGT_hpp})
|
set(TRGT_headers ${TRGT_moc_hpp} ${TRGT_hpp})
|
||||||
|
44
src/myx/qt/message_logger.hpp
Normal file
44
src/myx/qt/message_logger.hpp
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
#ifndef MYX_QT_MESSAGE_LOGGER_HPP_
|
||||||
|
#define MYX_QT_MESSAGE_LOGGER_HPP_
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <myx/backports/qt/common.hpp>
|
||||||
|
#include <myx/core/config.hpp>
|
||||||
|
|
||||||
|
#include <QList>
|
||||||
|
#include <QMessageLogContext>
|
||||||
|
#include <QSharedPointer>
|
||||||
|
#include <QString>
|
||||||
|
|
||||||
|
|
||||||
|
namespace myx {
|
||||||
|
|
||||||
|
namespace qt {
|
||||||
|
|
||||||
|
class MessageLogger
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual ~MessageLogger() = default;
|
||||||
|
|
||||||
|
virtual void debug( const QMessageLogContext& context, const QString& ) = 0;
|
||||||
|
virtual void info( const QMessageLogContext& context, const QString& ) = 0;
|
||||||
|
virtual void warning( const QMessageLogContext& context, const QString& ) = 0;
|
||||||
|
virtual void critical( const QMessageLogContext& context, const QString& ) = 0;
|
||||||
|
virtual void fatal( const QMessageLogContext& context, const QString& ) = 0;
|
||||||
|
|
||||||
|
void setEnabled( bool v = true ) { m_enabled = v; }
|
||||||
|
bool isEnabled() { return( m_enabled ); }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool m_enabled { true };
|
||||||
|
};
|
||||||
|
|
||||||
|
using MessageLoggersList = QList< QSharedPointer< MessageLogger > >;
|
||||||
|
extern MessageLoggersList messageLoggersList;
|
||||||
|
|
||||||
|
} // namespace qt
|
||||||
|
|
||||||
|
} // namespace myx
|
||||||
|
|
||||||
|
#endif // ifndef MYX_QT_MESSAGE_LOGGER_HPP_
|
46
src/myx/qt/message_logger_default.cpp
Normal file
46
src/myx/qt/message_logger_default.cpp
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
#include <myx/backports/qt/common.hpp>
|
||||||
|
#include <myx/core/config.hpp>
|
||||||
|
|
||||||
|
#include <myx/qt/message_logger_default.hpp>
|
||||||
|
|
||||||
|
#include <QtDebug>
|
||||||
|
|
||||||
|
namespace myx {
|
||||||
|
|
||||||
|
namespace qt {
|
||||||
|
|
||||||
|
void MessageLoggerDefault::debug( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
fprintf( stderr, "D: %s\n", msg.toUtf8().data() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerDefault::info( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
fprintf( stderr, "I: %s\n", msg.toUtf8().data() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerDefault::warning( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
fprintf( stderr, "W: %s\n", msg.toUtf8().data() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerDefault::critical( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerDefault::fatal( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace qt
|
||||||
|
|
||||||
|
} // namespace myx
|
31
src/myx/qt/message_logger_default.hpp
Normal file
31
src/myx/qt/message_logger_default.hpp
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
#ifndef MYX_QT_MESSAGE_LOGGER_DEFAULT_HPP_
|
||||||
|
#define MYX_QT_MESSAGE_LOGGER_DEFAULT_HPP_
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <myx/backports/qt/common.hpp>
|
||||||
|
#include <myx/core/config.hpp>
|
||||||
|
#include <myx/qt/message_logger.hpp>
|
||||||
|
|
||||||
|
|
||||||
|
namespace myx {
|
||||||
|
|
||||||
|
namespace qt {
|
||||||
|
|
||||||
|
class MessageLoggerDefault : public MessageLogger
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
~MessageLoggerDefault() = default;
|
||||||
|
|
||||||
|
void debug( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
void info( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
void warning( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
void critical( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
void fatal( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace qt
|
||||||
|
|
||||||
|
} // namespace myx
|
||||||
|
|
||||||
|
#endif // ifndef MYX_QT_MESSAGE_LOGGER_DEFAULT_HPP_
|
81
src/myx/qt/message_logger_handler.cpp
Normal file
81
src/myx/qt/message_logger_handler.cpp
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
#include <myx/backports/qt/common.hpp>
|
||||||
|
#include <myx/core/config.hpp>
|
||||||
|
|
||||||
|
#include <myx/qt/message_logger.hpp>
|
||||||
|
|
||||||
|
#include <QtDebug>
|
||||||
|
|
||||||
|
namespace myx {
|
||||||
|
|
||||||
|
namespace qt {
|
||||||
|
|
||||||
|
MessageLoggersList messageLoggersList;
|
||||||
|
|
||||||
|
void message_logger_handler( QtMsgType type, const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
if ( messageLoggersList.isEmpty() )
|
||||||
|
{
|
||||||
|
QByteArray localMsg = msg.toLocal8Bit();
|
||||||
|
const char* file = context.file ? context.file : "";
|
||||||
|
const char* function = context.function ? context.function : "";
|
||||||
|
switch ( type )
|
||||||
|
{
|
||||||
|
case QtDebugMsg:
|
||||||
|
#ifndef QT_NO_DEBUG_OUTPUT
|
||||||
|
// fprintf( stderr, "Debug: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
|
||||||
|
fprintf( stderr, "%s\n", localMsg.constData() );
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case QtInfoMsg:
|
||||||
|
#ifndef QT_NO_INFO_OUTPUT
|
||||||
|
// fprintf( stderr, "Info: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
|
||||||
|
fprintf( stderr, "%s\n", localMsg.constData() );
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case QtWarningMsg:
|
||||||
|
#ifndef QT_NO_WARNING_OUTPUT
|
||||||
|
// fprintf( stderr, "Warning: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
|
||||||
|
fprintf( stderr, "%s\n", localMsg.constData() );
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case QtCriticalMsg:
|
||||||
|
// fprintf( stderr, "Critical: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
|
||||||
|
fprintf( stderr, "%s\n", localMsg.constData() );
|
||||||
|
break;
|
||||||
|
case QtFatalMsg:
|
||||||
|
// fprintf( stderr, "Fatal: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
|
||||||
|
fprintf( stderr, "%s\n", localMsg.constData() );
|
||||||
|
break;
|
||||||
|
} // switch
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch ( type )
|
||||||
|
{
|
||||||
|
case QtDebugMsg:
|
||||||
|
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||||
|
{ if ( m->isEnabled() ) { m->debug( context, msg ); } }
|
||||||
|
break;
|
||||||
|
case QtInfoMsg:
|
||||||
|
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||||
|
{ if ( m->isEnabled() ) { m->info( context, msg ); } }
|
||||||
|
break;
|
||||||
|
case QtWarningMsg:
|
||||||
|
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||||
|
{ if ( m->isEnabled() ) { m->warning( context, msg ); } }
|
||||||
|
break;
|
||||||
|
case QtCriticalMsg:
|
||||||
|
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||||
|
{ if ( m->isEnabled() ) { m->critical( context, msg ); } }
|
||||||
|
break;
|
||||||
|
case QtFatalMsg:
|
||||||
|
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||||
|
{ if ( m->isEnabled() ) { m->fatal( context, msg ); } }
|
||||||
|
break;
|
||||||
|
} // switch
|
||||||
|
}
|
||||||
|
} // message_logger_handler
|
||||||
|
|
||||||
|
} // namespace qt
|
||||||
|
|
||||||
|
} // namespace myx
|
20
src/myx/qt/message_logger_handler.hpp
Normal file
20
src/myx/qt/message_logger_handler.hpp
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
#ifndef MYX_QT_MESSAGE_LOGGER_HANDLER_HPP_
|
||||||
|
#define MYX_QT_MESSAGE_LOGGER_HANDLER_HPP_
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <myx/backports/qt/common.hpp>
|
||||||
|
#include <myx/core/config.hpp>
|
||||||
|
#include <myx/qt/message_logger.hpp>
|
||||||
|
|
||||||
|
namespace myx {
|
||||||
|
|
||||||
|
namespace qt {
|
||||||
|
|
||||||
|
void message_logger_handler( QtMsgType type, const QMessageLogContext& context, const QString& msg );
|
||||||
|
|
||||||
|
} // namespace qt
|
||||||
|
|
||||||
|
} // namespace myx
|
||||||
|
|
||||||
|
#endif // ifndef MYX_QT_MESSAGE_LOGGER_HANDLER_HPP_
|
55
src/myx/qt/message_logger_syslog.cpp
Normal file
55
src/myx/qt/message_logger_syslog.cpp
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
#include <myx/backports/qt/common.hpp>
|
||||||
|
#include <myx/core/config.hpp>
|
||||||
|
|
||||||
|
#include <myx/qt/message_logger_syslog.hpp>
|
||||||
|
|
||||||
|
#include <syslog.h>
|
||||||
|
|
||||||
|
namespace myx {
|
||||||
|
|
||||||
|
namespace qt {
|
||||||
|
|
||||||
|
MessageLoggerSyslog::MessageLoggerSyslog() :
|
||||||
|
MessageLogger()
|
||||||
|
{
|
||||||
|
// openlog( nullptr, LOG_ODELAY, LOG_USER );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerSyslog::debug( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
syslog( LOG_DEBUG, "%s\n", msg.toUtf8().data() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerSyslog::info( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
syslog( LOG_INFO, "%s\n", msg.toUtf8().data() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerSyslog::warning( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
syslog( LOG_WARNING, "%s\n", msg.toUtf8().data() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerSyslog::critical( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
syslog( LOG_CRIT, "%s\n", msg.toUtf8().data() );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void MessageLoggerSyslog::fatal( const QMessageLogContext& context, const QString& msg )
|
||||||
|
{
|
||||||
|
Q_UNUSED( context )
|
||||||
|
syslog( LOG_EMERG, "%s\n", msg.toUtf8().data() );
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace qt
|
||||||
|
|
||||||
|
} // namespace myx
|
32
src/myx/qt/message_logger_syslog.hpp
Normal file
32
src/myx/qt/message_logger_syslog.hpp
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
#ifndef MYX_QT_MESSAGE_LOGGER_SYSLOG_HPP_
|
||||||
|
#define MYX_QT_MESSAGE_LOGGER_SYSLOG_HPP_
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <myx/backports/qt/common.hpp>
|
||||||
|
#include <myx/core/config.hpp>
|
||||||
|
#include <myx/qt/message_logger.hpp>
|
||||||
|
|
||||||
|
|
||||||
|
namespace myx {
|
||||||
|
|
||||||
|
namespace qt {
|
||||||
|
|
||||||
|
class MessageLoggerSyslog : public MessageLogger
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
MessageLoggerSyslog();
|
||||||
|
~MessageLoggerSyslog() = default;
|
||||||
|
|
||||||
|
void debug( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
void info( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
void warning( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
void critical( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
void fatal( const QMessageLogContext& context, const QString& msg ) override;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace qt
|
||||||
|
|
||||||
|
} // namespace myx
|
||||||
|
|
||||||
|
#endif // ifndef MYX_QT_MESSAGE_LOGGER_SYSLOG_HPP_
|
Loading…
Reference in New Issue
Block a user