X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/7d8f69bd16c0e415d771a29c367519f26184ffae..085c36723242f7bd1e0fd9bf49b950da6cb96039:/include/stg/user_traff.h diff --git a/include/stg/user_traff.h b/include/stg/user_traff.h index f186d00a..af5a0b64 100644 --- a/include/stg/user_traff.h +++ b/include/stg/user_traff.h @@ -18,86 +18,85 @@ * Author : Boris Mikhailenko */ -/* - $Revision: 1.7 $ - $Date: 2010/10/07 19:48:52 $ - $Author: faust $ - */ +#pragma once -#ifndef USER_TRAFF_H -#define USER_TRAFF_H +#include "const.h" -#include +#include #include +#include +#include -#include "const.h" -#include "os_int.h" +namespace STG +{ -enum TRAFF_DIRECTION {TRAFF_UPLOAD, TRAFF_DOWNLOAD}; +enum TraffDirection {TRAFF_UPLOAD, TRAFF_DOWNLOAD}; -class DIR_TRAFF +class DirTraff { - friend std::ostream & operator<< (std::ostream & o, const DIR_TRAFF & traff); - -public: - typedef std::vector ContainerType; - typedef ContainerType::size_type IndexType; - - DIR_TRAFF() {} - DIR_TRAFF(const DIR_TRAFF & ts) : traff(ts.traff) {} - DIR_TRAFF & operator=(const DIR_TRAFF & ts) { traff = ts.traff; return *this; } - const uint64_t & operator[](IndexType idx) const { return traff[idx]; } - uint64_t & operator[](IndexType idx) { return traff[idx]; } - DIR_TRAFF operator+(const DIR_TRAFF & ts); - IndexType size() const { return traff.size(); } - -private: - ContainerType traff; + friend std::ostream& operator<< (std::ostream& stream, const DirTraff& traff); + + public: + using ContainerType = std::vector; + using IndexType = ContainerType::size_type; + + DirTraff() noexcept : traff(DIR_NUM) {} + const uint64_t & operator[](IndexType idx) const noexcept { return traff[idx]; } + uint64_t & operator[](IndexType idx) noexcept { return traff[idx]; } + IndexType size() const noexcept { return traff.size(); } + + void reset() noexcept + { + for (IndexType i = 0; i < traff.size(); ++i) + traff[i] = 0; + } + + private: + ContainerType traff; }; //----------------------------------------------------------------------------- inline -DIR_TRAFF DIR_TRAFF::operator+(const DIR_TRAFF & ts) +std::ostream& operator<<(std::ostream& stream, const DirTraff& traff) { -for (IndexType i = 0; i < DIR_NUM; i++) + bool first = true; + for (DirTraff::IndexType i = 0; i < traff.size(); ++i) { - traff[i] = traff[i] + ts.traff[i]; + if (first) + first = false; + else + stream << ","; + stream << traff[i]; } -return *this; -} -//----------------------------------------------------------------------------- -inline std::ostream & operator<<(std::ostream & o, const DIR_TRAFF & traff) -{ -bool first = true; -for (DIR_TRAFF::IndexType i = 0; i < DIR_NUM; ++i) - { - if (first) - first = false; - else - o << ","; - o << traff[i]; - } -return o; + return stream; } -class DIR_TRAFF_RES +class DirTraffOpt { -public: - typedef RESETABLE ValueType; - typedef std::vector ContainerType; - typedef ContainerType::size_type IndexType; + public: + using ValueType = std::optional; + using ContainerType = std::vector; + using IndexType = ContainerType::size_type; - DIR_TRAFF_RES(const DIR_TRAFF & ts) - : traff(ts.size()) - { - for (IndexType i = 0; i < ts.size(); ++i) - traff[i] = ts[i]; - } - const ValueType & operator[](IndexType idx) const { return traff[idx]; } - ValueType & operator[](IndexType idx) { return traff[idx]; } + DirTraffOpt() noexcept: traff(DIR_NUM) {} + explicit DirTraffOpt(const DirTraff & ts) noexcept + : traff(ts.size()) + { + for (IndexType i = 0; i < ts.size(); ++i) + traff[i] = ts[i]; + } + DirTraffOpt& operator=(const DirTraff& ts) noexcept + { + for (IndexType i = 0; i < ts.size(); ++i) + traff[i] = ts[i]; + return *this; + } + const ValueType & operator[](IndexType idx) const noexcept { return traff[idx]; } + ValueType & operator[](IndexType idx) noexcept { return traff[idx]; } + IndexType size() const noexcept { return traff.size(); } -private: - ContainerType traff; + private: + ContainerType traff; }; -#endif +}