Refactoring: Changed all check parameters starting with a 'p' to the new rulespec...
[check_mk.git] / livestatus / src / DoubleColumn.h
blob0a64ae88a11f5e115e2cc9c7d302955fb6aeaa47
1 // +------------------------------------------------------------------+
2 // | ____ _ _ __ __ _ __ |
3 // | / ___| |__ ___ ___| | __ | \/ | |/ / |
4 // | | | | '_ \ / _ \/ __| |/ / | |\/| | ' / |
5 // | | |___| | | | __/ (__| < | | | | . \ |
6 // | \____|_| |_|\___|\___|_|\_\___|_| |_|_|\_\ |
7 // | |
8 // | Copyright Mathias Kettner 2014 mk@mathias-kettner.de |
9 // +------------------------------------------------------------------+
11 // This file is part of Check_MK.
12 // The official homepage is at http://mathias-kettner.de/check_mk.
14 // check_mk is free software; you can redistribute it and/or modify it
15 // under the terms of the GNU General Public License as published by
16 // the Free Software Foundation in version 2. check_mk is distributed
17 // in the hope that it will be useful, but WITHOUT ANY WARRANTY; with-
18 // out even the implied warranty of MERCHANTABILITY or FITNESS FOR A
19 // PARTICULAR PURPOSE. See the GNU General Public License for more de-
20 // tails. You should have received a copy of the GNU General Public
21 // License along with GNU Make; see the file COPYING. If not, write
22 // to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
23 // Boston, MA 02110-1301 USA.
25 #ifndef DoubleColumn_h
26 #define DoubleColumn_h
28 #include "config.h" // IWYU pragma: keep
29 #include <chrono>
30 #include <memory>
31 #include <string>
32 #include "Column.h"
33 #include "Filter.h"
34 #include "contact_fwd.h"
35 #include "opids.h"
36 class Aggregator;
37 class Row;
38 class RowRenderer;
40 class DoubleColumn : public Column {
41 public:
42 DoubleColumn(const std::string &name, const std::string &description,
43 int indirect_offset, int extra_offset, int extra_extra_offset,
44 int offset)
45 : Column(name, description, indirect_offset, extra_offset,
46 extra_extra_offset, offset) {}
47 virtual double getValue(Row row) const = 0;
48 void output(Row row, RowRenderer &r, const contact *auth_user,
49 std::chrono::seconds timezone_offset) const override;
50 ColumnType type() const override { return ColumnType::double_; }
51 std::unique_ptr<Filter> createFilter(
52 Filter::Kind kind, RelationalOperator relOp,
53 const std::string &value) const override;
54 std::unique_ptr<Aggregator> createAggregator(
55 AggregationFactory factory) const override;
58 #endif // DoubleColumn_h