blob: 805ebdf81c7c2ef2468f0bf1223eb8db1f6389d2 [file] [log] [blame]
Junxiao Shi57df2882015-11-11 06:12:35 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesavento2cae8ca2019-04-18 20:48:05 -04002/*
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -04003 * Copyright (c) 2014-2022, Regents of the University of California,
Junxiao Shi57df2882015-11-11 06:12:35 -07004 * Arizona Board of Regents,
5 * Colorado State University,
6 * University Pierre & Marie Curie, Sorbonne University,
7 * Washington University in St. Louis,
8 * Beijing Institute of Technology,
9 * The University of Memphis.
10 *
11 * This file is part of NFD (Named Data Networking Forwarding Daemon).
12 * See AUTHORS.md for complete list of NFD authors and contributors.
13 *
14 * NFD is free software: you can redistribute it and/or modify it under the terms
15 * of the GNU General Public License as published by the Free Software Foundation,
16 * either version 3 of the License, or (at your option) any later version.
17 *
18 * NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20 * PURPOSE. See the GNU General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License along with
23 * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24 */
25
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040026#ifndef NFD_DAEMON_COMMON_COUNTER_HPP
27#define NFD_DAEMON_COMMON_COUNTER_HPP
Junxiao Shi57df2882015-11-11 06:12:35 -070028
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040029#include "core/common.hpp"
Junxiao Shi57df2882015-11-11 06:12:35 -070030
31namespace nfd {
32
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040033/**
34 * \brief Represents a counter that encloses an integer value.
Junxiao Shi57df2882015-11-11 06:12:35 -070035 *
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040036 * SimpleCounter is noncopyable, because increment should be called on the counter,
37 * not a copy of it; it's implicitly convertible to an integral type to be observed.
Junxiao Shi57df2882015-11-11 06:12:35 -070038 */
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040039class SimpleCounter : noncopyable
Junxiao Shi57df2882015-11-11 06:12:35 -070040{
41public:
42 typedef uint64_t rep;
43
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040044 /**
45 * \brief Observe the counter's value.
Junxiao Shi57df2882015-11-11 06:12:35 -070046 */
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040047 operator rep() const noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -070048 {
49 return m_value;
50 }
51
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040052 /**
53 * \brief Replace the counter's value.
Junxiao Shi57df2882015-11-11 06:12:35 -070054 */
55 void
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040056 set(rep value) noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -070057 {
58 m_value = value;
59 }
60
61protected:
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040062 rep m_value = 0;
Junxiao Shi57df2882015-11-11 06:12:35 -070063};
64
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040065/** \brief Represents a counter of number of packets.
Junxiao Shi57df2882015-11-11 06:12:35 -070066 *
67 * \warning The counter value may wrap after exceeding the range of underlying integer type.
68 */
69class PacketCounter : public SimpleCounter
70{
71public:
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040072 /** \brief Increment the counter by one.
Junxiao Shi57df2882015-11-11 06:12:35 -070073 */
74 PacketCounter&
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040075 operator++() noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -070076 {
77 ++m_value;
78 return *this;
79 }
80 // postfix ++ operator is not provided because it's not needed
81};
82
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040083/** \brief Represents a counter of number of bytes.
Junxiao Shi57df2882015-11-11 06:12:35 -070084 *
85 * \warning The counter value may wrap after exceeding the range of underlying integer type.
86 */
87class ByteCounter : public SimpleCounter
88{
89public:
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040090 /** \brief Increase the counter.
Junxiao Shi57df2882015-11-11 06:12:35 -070091 */
92 ByteCounter&
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040093 operator+=(rep n) noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -070094 {
95 m_value += n;
96 return *this;
97 }
98};
99
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -0400100/** \brief Provides a counter that observes the size of a table.
Junxiao Shi57df2882015-11-11 06:12:35 -0700101 * \tparam T a type that provides a size() const member function
Eric Newberry73bcad32017-04-25 17:57:35 -0700102 *
103 * if table not specified in constructor, it can be added later by invoking observe()
Junxiao Shi57df2882015-11-11 06:12:35 -0700104 */
105template<typename T>
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400106class SizeCounter : noncopyable
Junxiao Shi57df2882015-11-11 06:12:35 -0700107{
108public:
Eric Newberry73bcad32017-04-25 17:57:35 -0700109 typedef size_t Rep;
Junxiao Shi57df2882015-11-11 06:12:35 -0700110
Eric Newberry73bcad32017-04-25 17:57:35 -0700111 explicit constexpr
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400112 SizeCounter(const T* table = nullptr) noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -0700113 : m_table(table)
114 {
115 }
116
Eric Newberry73bcad32017-04-25 17:57:35 -0700117 void
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400118 observe(const T* table) noexcept
Eric Newberry73bcad32017-04-25 17:57:35 -0700119 {
120 m_table = table;
121 }
122
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -0400123 /** \brief Observe the counter.
Junxiao Shi57df2882015-11-11 06:12:35 -0700124 */
Eric Newberry73bcad32017-04-25 17:57:35 -0700125 operator Rep() const
Junxiao Shi57df2882015-11-11 06:12:35 -0700126 {
Eric Newberry73bcad32017-04-25 17:57:35 -0700127 BOOST_ASSERT(m_table != nullptr);
128 return m_table->size();
Junxiao Shi57df2882015-11-11 06:12:35 -0700129 }
130
131private:
Eric Newberry73bcad32017-04-25 17:57:35 -0700132 const T* m_table;
Junxiao Shi57df2882015-11-11 06:12:35 -0700133};
134
135} // namespace nfd
136
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400137#endif // NFD_DAEMON_COMMON_COUNTER_HPP