blob: 4619b355739581a835b7f0ce856e7200577c3b84 [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/*
3 * Copyright (c) 2014-2019, 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
33/** \brief represents a counter that encloses an integer value
34 *
35 * SimpleCounter is noncopyable, because increment should be called on the counter,
36 * not a copy of it; it's implicitly convertible to an integral type to be observed
37 */
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040038class SimpleCounter : noncopyable
Junxiao Shi57df2882015-11-11 06:12:35 -070039{
40public:
41 typedef uint64_t rep;
42
Junxiao Shi57df2882015-11-11 06:12:35 -070043 /** \brief observe the counter
44 */
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040045 operator rep() const noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -070046 {
47 return m_value;
48 }
49
50 /** \brief replace the counter value
51 */
52 void
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040053 set(rep value) noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -070054 {
55 m_value = value;
56 }
57
58protected:
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040059 rep m_value = 0;
Junxiao Shi57df2882015-11-11 06:12:35 -070060};
61
62/** \brief represents a counter of number of packets
63 *
64 * \warning The counter value may wrap after exceeding the range of underlying integer type.
65 */
66class PacketCounter : public SimpleCounter
67{
68public:
69 /** \brief increment the counter by one
70 */
71 PacketCounter&
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040072 operator++() noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -070073 {
74 ++m_value;
75 return *this;
76 }
77 // postfix ++ operator is not provided because it's not needed
78};
79
80/** \brief represents a counter of number of bytes
81 *
82 * \warning The counter value may wrap after exceeding the range of underlying integer type.
83 */
84class ByteCounter : public SimpleCounter
85{
86public:
87 /** \brief increase the counter
88 */
89 ByteCounter&
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040090 operator+=(rep n) noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -070091 {
92 m_value += n;
93 return *this;
94 }
95};
96
97/** \brief provides a counter that observes the size of a table
98 * \tparam T a type that provides a size() const member function
Eric Newberry73bcad32017-04-25 17:57:35 -070099 *
100 * if table not specified in constructor, it can be added later by invoking observe()
Junxiao Shi57df2882015-11-11 06:12:35 -0700101 */
102template<typename T>
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400103class SizeCounter : noncopyable
Junxiao Shi57df2882015-11-11 06:12:35 -0700104{
105public:
Eric Newberry73bcad32017-04-25 17:57:35 -0700106 typedef size_t Rep;
Junxiao Shi57df2882015-11-11 06:12:35 -0700107
Eric Newberry73bcad32017-04-25 17:57:35 -0700108 explicit constexpr
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400109 SizeCounter(const T* table = nullptr) noexcept
Junxiao Shi57df2882015-11-11 06:12:35 -0700110 : m_table(table)
111 {
112 }
113
Eric Newberry73bcad32017-04-25 17:57:35 -0700114 void
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400115 observe(const T* table) noexcept
Eric Newberry73bcad32017-04-25 17:57:35 -0700116 {
117 m_table = table;
118 }
119
Junxiao Shi57df2882015-11-11 06:12:35 -0700120 /** \brief observe the counter
121 */
Eric Newberry73bcad32017-04-25 17:57:35 -0700122 operator Rep() const
Junxiao Shi57df2882015-11-11 06:12:35 -0700123 {
Eric Newberry73bcad32017-04-25 17:57:35 -0700124 BOOST_ASSERT(m_table != nullptr);
125 return m_table->size();
Junxiao Shi57df2882015-11-11 06:12:35 -0700126 }
127
128private:
Eric Newberry73bcad32017-04-25 17:57:35 -0700129 const T* m_table;
Junxiao Shi57df2882015-11-11 06:12:35 -0700130};
131
132} // namespace nfd
133
Davide Pesavento2cae8ca2019-04-18 20:48:05 -0400134#endif // NFD_DAEMON_COMMON_COUNTER_HPP