| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * This file is part of Adblock Plus <https://adblockplus.org/>, | 2  * This file is part of Adblock Plus <https://adblockplus.org/>, | 
| 3  * Copyright (C) 2006-2017 eyeo GmbH | 3  * Copyright (C) 2006-2017 eyeo GmbH | 
| 4  * | 4  * | 
| 5  * Adblock Plus is free software: you can redistribute it and/or modify | 5  * Adblock Plus is free software: you can redistribute it and/or modify | 
| 6  * it under the terms of the GNU General Public License version 3 as | 6  * it under the terms of the GNU General Public License version 3 as | 
| 7  * published by the Free Software Foundation. | 7  * published by the Free Software Foundation. | 
| 8  * | 8  * | 
| 9  * Adblock Plus is distributed in the hope that it will be useful, | 9  * Adblock Plus is distributed in the hope that it will be useful, | 
| 10  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
| 11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
| 12  * GNU General Public License for more details. | 12  * GNU General Public License for more details. | 
| 13  * | 13  * | 
| 14  * You should have received a copy of the GNU General Public License | 14  * You should have received a copy of the GNU General Public License | 
| 15  * along with Adblock Plus.  If not, see <http://www.gnu.org/licenses/>. | 15  * along with Adblock Plus.  If not, see <http://www.gnu.org/licenses/>. | 
| 16  */ | 16  */ | 
| 17 | 17 | 
| 18 #ifndef ADBLOCK_PLUS_LOG_SYSTEM_H | 18 #ifndef ADBLOCK_PLUS_TIMER_H | 
| 19 #define ADBLOCK_PLUS_LOG_SYSTEM_H | 19 #define ADBLOCK_PLUS_TIMER_H | 
| 20 | 20 | 
| 21 #include <string> | 21 #include <functional> | 
|  | 22 #include <chrono> | 
| 22 #include <memory> | 23 #include <memory> | 
| 23 | 24 | 
| 24 namespace AdblockPlus | 25 namespace AdblockPlus | 
| 25 { | 26 { | 
| 26   /** | 27   /** | 
| 27    * Logging interface. | 28    * Timer manager interface. | 
| 28    */ | 29    */ | 
| 29   class LogSystem | 30   struct ITimer | 
| 30   { | 31   { | 
| 31   public: |  | 
| 32     /** | 32     /** | 
| 33      * Log level. | 33     * Callback type invoked after elapsing of timer timeout. | 
| 34      */ | 34     */ | 
| 35     enum LogLevel {LOG_LEVEL_TRACE, LOG_LEVEL_LOG, LOG_LEVEL_INFO, LOG_LEVEL_WAR
    N, LOG_LEVEL_ERROR}; | 35     typedef std::function<void()> TimerCallback; | 
| 36 | 36     virtual ~ITimer() {}; | 
| 37     virtual ~LogSystem() {} |  | 
| 38 | 37 | 
| 39     /** | 38     /** | 
| 40      * Writes a log message. | 39      * Sets a timer. | 
| 41      * @param logLevel Log level. | 40      * @param timeout A timer callback will be called after that interval. | 
| 42      * @param message Log message. | 41      * @param timeCallback The callback which is called after timeout. | 
| 43      * @param source Source of the message, e.g. file name and line. |  | 
| 44      *        Ignored when empty. |  | 
| 45      */ | 42      */ | 
| 46     virtual void operator()(LogLevel logLevel, const std::string& message, | 43     virtual void SetTimer(const std::chrono::milliseconds& timeout, const TimerC
    allback& timerCallback) = 0; | 
| 47           const std::string& source) = 0; |  | 
| 48   }; | 44   }; | 
| 49 | 45 | 
| 50   /** | 46   /** | 
| 51    * Shared smart pointer to a `LogSystem` instance. | 47    * Unique smart pointer to an instance of `ITimer` implementation. | 
| 52    */ | 48    */ | 
| 53   typedef std::shared_ptr<LogSystem> LogSystemPtr; | 49   typedef std::unique_ptr<ITimer> TimerPtr; | 
| 54 } | 50 } | 
| 55 | 51 | 
| 56 #endif | 52 #endif | 
| OLD | NEW | 
|---|