blob: 834cd798fcedfba63339db9929ef7bf79bf46429 [file] [log] [blame]
Shawn McCarney66332cd2020-07-13 19:14:18 -05001/**
2 * Copyright © 2020 IBM Corporation
3 *
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 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#pragma once
17
18#include <cstddef>
19#include <cstdint>
20
21namespace phosphor::power::regulators
22{
23
24/**
25 * @class ErrorHistory
26 *
27 * This class represents the history of an error.
28 *
29 * ErrorHistory tracks the error count and whether the error has been logged.
30 *
31 * This class is often used to limit the number of journal messages and error
32 * logs created by code that runs repeatedly, such as sensor monitoring.
33 */
34class ErrorHistory
35{
36 public:
37 // Specify which compiler-generated methods we want
38 ErrorHistory() = default;
39 ErrorHistory(const ErrorHistory&) = default;
40 ErrorHistory(ErrorHistory&&) = default;
41 ErrorHistory& operator=(const ErrorHistory&) = default;
42 ErrorHistory& operator=(ErrorHistory&&) = default;
43 ~ErrorHistory() = default;
44
45 /**
46 * Clears the error history.
47 */
48 void clear()
49 {
50 count = 0;
51 wasLogged = false;
52 }
53
54 /**
55 * Increments the error count.
56 *
57 * Does nothing if the error count is already at the maximum. This avoids
58 * wrapping back to 0 again.
59 */
60 void incrementCount()
61 {
62 if (count < SIZE_MAX)
63 {
64 ++count;
65 }
66 }
67
68 /**
69 * Error count.
70 */
71 std::size_t count{0};
72
73 /**
74 * Indicates whether this error was logged, resulting in an error log entry.
75 */
76 bool wasLogged{false};
77};
78
79} // namespace phosphor::power::regulators