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 |