| 
									
										
										
										
											2017-11-11 10:29:32 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |   @file | 
					
						
							|  |  |  |   @author Stefan Frings | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef DUALFILELOGGER_H
 | 
					
						
							|  |  |  | #define DUALFILELOGGER_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <QString>
 | 
					
						
							|  |  |  | #include <QSettings>
 | 
					
						
							|  |  |  | #include <QtGlobal>
 | 
					
						
							|  |  |  | #include "logglobal.h"
 | 
					
						
							|  |  |  | #include "logger.h"
 | 
					
						
							|  |  |  | #include "filelogger.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 13:49:21 +01:00
										 |  |  | #include "export.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-03 20:23:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-11 10:29:32 +01:00
										 |  |  | namespace qtwebapp { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |   Logs messages into two log files simultaneously. | 
					
						
							|  |  |  |   May be used to create two logfiles with different configuration settings. | 
					
						
							|  |  |  |   @see FileLogger for a description of the two underlying loggers. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-03 20:23:38 +01:00
										 |  |  | class LOGGING_API DualFileLogger : public Logger { | 
					
						
							| 
									
										
										
										
											2017-11-11 10:29:32 +01:00
										 |  |  |     Q_OBJECT | 
					
						
							|  |  |  |     Q_DISABLE_COPY(DualFileLogger) | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |       Constructor. | 
					
						
							|  |  |  |       @param firstSettings Configuration settings for the first log file, usually stored in an INI file. | 
					
						
							|  |  |  |       Must not be 0. | 
					
						
							|  |  |  |       Settings are read from the current group, so the caller must have called settings->beginGroup(). | 
					
						
							|  |  |  |       Because the group must not change during runtime, it is recommended to provide a | 
					
						
							|  |  |  |       separate QSettings instance to the logger that is not used by other parts of the program. | 
					
						
							|  |  |  |       @param secondSettings Same as firstSettings, but for the second log file. | 
					
						
							|  |  |  |       @param refreshInterval Interval of checking for changed config settings in msec, or 0=disabled | 
					
						
							|  |  |  |       @param parent Parent object. | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     DualFileLogger(QSettings* firstSettings, QSettings* secondSettings, const int refreshInterval=10000, QObject *parent = 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |       Decorate and log the message, if type>=minLevel. | 
					
						
							|  |  |  |       This method is thread safe. | 
					
						
							|  |  |  |       @param type Message type (level) | 
					
						
							|  |  |  |       @param message Message text | 
					
						
							|  |  |  |       @param file Name of the source file where the message was generated (usually filled with the macro __FILE__) | 
					
						
							|  |  |  |       @param function Name of the function where the message was generated (usually filled with the macro __LINE__) | 
					
						
							|  |  |  |       @param line Line Number of the source file, where the message was generated (usually filles with the macro __func__ or __FUNCTION__) | 
					
						
							|  |  |  |       @see LogMessage for a description of the message decoration. | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     virtual void log(const QtMsgType type, const QString& message, const QString &file="", const QString &function="", const int line=0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |       Clear the thread-local data of the current thread. | 
					
						
							|  |  |  |       This method is thread safe. | 
					
						
							|  |  |  |       @param buffer Whether to clear the backtrace buffer | 
					
						
							|  |  |  |       @param variables Whether to clear the log variables | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     virtual void clear(const bool buffer=true, const bool variables=true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** First logger */ | 
					
						
							|  |  |  |     FileLogger* firstLogger; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Second logger */ | 
					
						
							|  |  |  |     FileLogger* secondLogger; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // end of namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // DUALFILELOGGER_H
 |