ORE Studio 0.0.4
Loading...
Searching...
No Matches
telemetry_batch.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2025 Marco Craveiro <marco.craveiro@gmail.com>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License as published by the Free Software
7 * Foundation; either version 3 of the License, or (at your option) any later
8 * version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13 * details.
14 *
15 * You should have received a copy of the GNU General Public License along with
16 * this program; if not, write to the Free Software Foundation, Inc., 51
17 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 *
19 */
20#ifndef ORES_TELEMETRY_DOMAIN_TELEMETRY_BATCH_HPP
21#define ORES_TELEMETRY_DOMAIN_TELEMETRY_BATCH_HPP
22
23#include <vector>
24#include <string>
25#include "ores.telemetry/domain/telemetry_source.hpp"
26#include "ores.telemetry/domain/telemetry_log_entry.hpp"
27
29
37struct telemetry_batch final {
42
49 std::string source_name;
50
54 std::vector<telemetry_log_entry> entries;
55
59 [[nodiscard]] std::size_t size() const noexcept {
60 return entries.size();
61 }
62
66 [[nodiscard]] bool empty() const noexcept {
67 return entries.empty();
68 }
69
73 void clear() noexcept {
74 entries.clear();
75 }
76};
77
78}
79
80#endif
Domain types for telemetry and observability.
Definition attribute_value.hpp:29
telemetry_source
Source type for telemetry log entries.
Definition telemetry_source.hpp:33
@ client
Log entry from a client application.
A batch of telemetry log entries from a single source.
Definition telemetry_batch.hpp:37
void clear() noexcept
Clears all entries from the batch.
Definition telemetry_batch.hpp:73
telemetry_source source
Source type (client or server).
Definition telemetry_batch.hpp:41
bool empty() const noexcept
Returns true if the batch is empty.
Definition telemetry_batch.hpp:66
std::size_t size() const noexcept
Returns the number of entries in the batch.
Definition telemetry_batch.hpp:59
std::vector< telemetry_log_entry > entries
The log entries in this batch.
Definition telemetry_batch.hpp:54
std::string source_name
Name of the source application.
Definition telemetry_batch.hpp:49