M1M3 Support System
Loading...
Searching...
No Matches
LimitLog.h
1/*
2 * This file is part of LSST M1M3 support system package.
3 *
4 * Developed for the Vera C. Rubin Telescope and Site System.
5 * This product includes software developed by the LSST Project
6 * (https://www.lsst.org).
7 * See the COPYRIGHT file at the top-level directory of this distribution
8 * for details of code ownership.
9 *
10 * This program is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 */
23
24#ifndef LIMITLOG_H_
25#define LIMITLOG_H_
26
33#define TG_LOG_ERROR(tg, ...) \
34 { \
35 static auto last_executed = \
36 std::chrono::steady_clock::now() - std::chrono::duration_cast<std::chrono::seconds>(tg * 2); \
37 if ((std::chrono::steady_clock::now() - last_executed) > tg) { \
38 SPDLOG_ERROR(__VA_ARGS__); \
39 last_executed = std::chrono::steady_clock::now(); \
40 } \
41 }
42
49#define TG_LOG_WARN(tg, ...) \
50 { \
51 static auto last_executed = \
52 std::chrono::steady_clock::now() - std::chrono::duration_cast<std::chrono::seconds>(tg * 2); \
53 if ((std::chrono::steady_clock::now() - last_executed) > tg) { \
54 SPDLOG_WARN(__VA_ARGS__); \
55 last_executed = std::chrono::steady_clock::now(); \
56 } \
57 }
58
59#endif // !LIMITLOG_H_