ctkErrorLogModel.h 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. /*=========================================================================
  2. Library: CTK
  3. Copyright (c) Kitware Inc.
  4. Licensed under the Apache License, Version 2.0 (the "License");
  5. you may not use this file except in compliance with the License.
  6. You may obtain a copy of the License at
  7. http://www.apache.org/licenses/LICENSE-2.0.txt
  8. Unless required by applicable law or agreed to in writing, software
  9. distributed under the License is distributed on an "AS IS" BASIS,
  10. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. See the License for the specific language governing permissions and
  12. limitations under the License.
  13. =========================================================================*/
  14. #ifndef __ctkErrorLogModel_h
  15. #define __ctkErrorLogModel_h
  16. // Qt includes
  17. #include <QPointer>
  18. #include <QSortFilterProxyModel>
  19. // CTK includes
  20. #include "ctkCoreExport.h"
  21. //------------------------------------------------------------------------------
  22. /// \ingroup Core
  23. class CTK_CORE_EXPORT ctkErrorLogLevel : public QObject
  24. {
  25. Q_OBJECT
  26. Q_FLAGS(LogLevel)
  27. public:
  28. ctkErrorLogLevel();
  29. enum LogLevel
  30. {
  31. None = 0x0,
  32. Unknown = 0x1,
  33. Status = 0x2,
  34. Trace = 0x4,
  35. Debug = 0x8,
  36. Info = 0x10,
  37. Warning = 0x20,
  38. Error = 0x40,
  39. Critical = 0x80,
  40. Fatal = 0x100
  41. };
  42. Q_DECLARE_FLAGS(LogLevels, LogLevel)
  43. QString operator ()(LogLevel logLevel);
  44. QString logLevelAsString(ctkErrorLogLevel::LogLevel logLevel)const;
  45. };
  46. Q_DECLARE_OPERATORS_FOR_FLAGS(ctkErrorLogLevel::LogLevels)
  47. //------------------------------------------------------------------------------
  48. class ctkErrorLogTerminalOutputPrivate;
  49. //------------------------------------------------------------------------------
  50. /// \ingroup Core
  51. class CTK_CORE_EXPORT ctkErrorLogTerminalOutput
  52. {
  53. public:
  54. ctkErrorLogTerminalOutput();
  55. virtual ~ctkErrorLogTerminalOutput();
  56. bool enabled()const;
  57. void setEnabled(bool value);
  58. int fileDescriptor()const;
  59. void setFileDescriptor(int fd);
  60. void output(const QString& text);
  61. protected:
  62. QScopedPointer<ctkErrorLogTerminalOutputPrivate> d_ptr;
  63. private:
  64. Q_DECLARE_PRIVATE(ctkErrorLogTerminalOutput);
  65. Q_DISABLE_COPY(ctkErrorLogTerminalOutput);
  66. };
  67. //------------------------------------------------------------------------------
  68. class ctkErrorLogAbstractMessageHandler;
  69. class ctkErrorLogModelPrivate;
  70. //------------------------------------------------------------------------------
  71. /// \ingroup Core
  72. class CTK_CORE_EXPORT ctkErrorLogModel : public QSortFilterProxyModel
  73. {
  74. Q_OBJECT
  75. Q_FLAGS(TerminalOutput)
  76. Q_PROPERTY(bool logEntryGrouping READ logEntryGrouping WRITE setLogEntryGrouping)
  77. Q_PROPERTY(TerminalOutput terminalOutputs READ terminalOutputs WRITE setTerminalOutputs)
  78. Q_PROPERTY(bool asynchronousLogging READ asynchronousLogging WRITE setAsynchronousLogging)
  79. public:
  80. typedef QSortFilterProxyModel Superclass;
  81. typedef ctkErrorLogModel Self;
  82. explicit ctkErrorLogModel(QObject* parentObject = 0);
  83. virtual ~ctkErrorLogModel();
  84. enum ColumnsIds
  85. {
  86. TimeColumn = 0,
  87. ThreadIdColumn,
  88. LogLevelColumn,
  89. OriginColumn,
  90. DescriptionColumn
  91. };
  92. enum ItemDataRole{
  93. DescriptionTextRole = Qt::UserRole + 1
  94. };
  95. /// Register a message handler.
  96. bool registerMsgHandler(ctkErrorLogAbstractMessageHandler * msgHandler);
  97. QStringList msgHandlerNames()const;
  98. /// Return True if the handler identified by \a handlerName is enabled
  99. bool msgHandlerEnabled(const QString& handlerName) const;
  100. /// Enable a specific handler given its name
  101. void setMsgHandlerEnabled(const QString& handlerName, bool enabled);
  102. /// Return names of the enabled message handlers
  103. QStringList msgHandlerEnabled()const;
  104. /// Enable handler identified by their names
  105. void setMsgHandlerEnabled(const QStringList& handlerNames);
  106. void enableAllMsgHandler();
  107. void disableAllMsgHandler();
  108. void setAllMsgHandlerEnabled(bool enabled);
  109. enum TerminalOutput
  110. {
  111. None = 0x0,
  112. StandardError = 0x1,
  113. StandardOutput = 0x2,
  114. All = StandardError | StandardOutput
  115. };
  116. Q_DECLARE_FLAGS(TerminalOutputs, TerminalOutput)
  117. /// Return if messages are both printed into the terminal and added to ctkErrorLogModel.
  118. /// \note If TerminalOutput::None is returned, message will only be added to the model.
  119. TerminalOutputs terminalOutputs()const;
  120. /// Set terminal output mode
  121. /// \sa terminalOutputs()
  122. /// \sa TerminalOutput
  123. void setTerminalOutputs(const TerminalOutputs& terminalOutput);
  124. /// Remove all message from model
  125. void clear();
  126. ctkErrorLogLevel::LogLevels logLevelFilter()const;
  127. void filterEntry(const ctkErrorLogLevel::LogLevels& logLevel = ctkErrorLogLevel::Unknown, bool disableFilter = false);
  128. bool logEntryGrouping()const;
  129. void setLogEntryGrouping(bool value);
  130. bool asynchronousLogging()const;
  131. void setAsynchronousLogging(bool value);
  132. public Q_SLOTS:
  133. void addEntry(const QDateTime& currentDateTime, const QString& threadId,
  134. ctkErrorLogLevel::LogLevel logLevel, const QString& origin, const QString& text);
  135. Q_SIGNALS:
  136. void logLevelFilterChanged();
  137. protected:
  138. QScopedPointer<ctkErrorLogModelPrivate> d_ptr;
  139. private:
  140. Q_DECLARE_PRIVATE(ctkErrorLogModel);
  141. Q_DISABLE_COPY(ctkErrorLogModel);
  142. };
  143. Q_DECLARE_OPERATORS_FOR_FLAGS(ctkErrorLogModel::TerminalOutputs)
  144. //------------------------------------------------------------------------------
  145. class ctkErrorLogAbstractMessageHandlerPrivate;
  146. //------------------------------------------------------------------------------
  147. /// \ingroup Core
  148. class CTK_CORE_EXPORT ctkErrorLogAbstractMessageHandler : public QObject
  149. {
  150. Q_OBJECT
  151. public:
  152. typedef QObject Superclass;
  153. /// Disabled by default.
  154. ctkErrorLogAbstractMessageHandler();
  155. virtual ~ctkErrorLogAbstractMessageHandler();
  156. virtual QString handlerName()const = 0;
  157. QString handlerPrettyName()const;
  158. bool enabled()const;
  159. void setEnabled(bool value);
  160. void handleMessage(const QString& threadId, ctkErrorLogLevel::LogLevel logLevel,
  161. const QString& origin, const QString& text);
  162. ctkErrorLogTerminalOutput* terminalOutput(ctkErrorLogModel::TerminalOutput terminalOutputType)const;
  163. void setTerminalOutput(ctkErrorLogModel::TerminalOutput terminalOutputType,
  164. ctkErrorLogTerminalOutput * terminalOutput);
  165. Q_SIGNALS:
  166. void messageHandled(const QDateTime& currentDateTime, const QString& threadId,
  167. ctkErrorLogLevel::LogLevel logLevel, const QString& origin,
  168. const QString& text);
  169. protected:
  170. void setHandlerPrettyName(const QString& newHandlerPrettyName);
  171. virtual void setEnabledInternal(bool value) = 0;
  172. protected:
  173. QScopedPointer<ctkErrorLogAbstractMessageHandlerPrivate> d_ptr;
  174. private:
  175. Q_DECLARE_PRIVATE(ctkErrorLogAbstractMessageHandler);
  176. Q_DISABLE_COPY(ctkErrorLogAbstractMessageHandler);
  177. };
  178. #endif