diff options
author | Andrey Fomichev <andrey.fomichev@gmail.com> | 2022-02-10 16:49:12 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:49:12 +0300 |
commit | e542cc14db4240643a06bb0dde87ecf361f101ab (patch) | |
tree | 3b03a4b94acd11a4eca042532035806e5fa08ad1 /library/cpp/monlib | |
parent | e2ac73225f30f7fcf7df3cb225cba257f56144c1 (diff) | |
download | ydb-e542cc14db4240643a06bb0dde87ecf361f101ab.tar.gz |
Restoring authorship annotation for Andrey Fomichev <andrey.fomichev@gmail.com>. Commit 1 of 2.
Diffstat (limited to 'library/cpp/monlib')
-rw-r--r-- | library/cpp/monlib/counters/counters.cpp | 40 | ||||
-rw-r--r-- | library/cpp/monlib/counters/counters.h | 4 | ||||
-rw-r--r-- | library/cpp/monlib/dynamic_counters/counters.cpp | 26 | ||||
-rw-r--r-- | library/cpp/monlib/dynamic_counters/page.h | 2 | ||||
-rw-r--r-- | library/cpp/monlib/dynamic_counters/percentile/percentile_base.h | 12 | ||||
-rw-r--r-- | library/cpp/monlib/service/monservice.cpp | 2 | ||||
-rw-r--r-- | library/cpp/monlib/service/pages/html_mon_page.cpp | 16 | ||||
-rw-r--r-- | library/cpp/monlib/service/pages/index_mon_page.cpp | 28 | ||||
-rw-r--r-- | library/cpp/monlib/service/pages/pre_mon_page.cpp | 6 | ||||
-rw-r--r-- | library/cpp/monlib/service/pages/pre_mon_page.h | 2 | ||||
-rw-r--r-- | library/cpp/monlib/service/pages/templates.cpp | 36 | ||||
-rw-r--r-- | library/cpp/monlib/service/pages/templates.h | 116 |
12 files changed, 145 insertions, 145 deletions
diff --git a/library/cpp/monlib/counters/counters.cpp b/library/cpp/monlib/counters/counters.cpp index 50dca4c577..318c99ad38 100644 --- a/library/cpp/monlib/counters/counters.cpp +++ b/library/cpp/monlib/counters/counters.cpp @@ -1,31 +1,31 @@ - -#include "counters.h" - -namespace NMonitoring { + +#include "counters.h" + +namespace NMonitoring { char* PrettyNumShort(i64 val, char* buf, size_t size) { static const char shorts[] = {' ', 'K', 'M', 'G', 'T', 'P', 'E'}; - unsigned i = 0; - i64 major = val; - i64 minor = 0; + unsigned i = 0; + i64 major = val; + i64 minor = 0; const unsigned imax = sizeof(shorts) / sizeof(char); for (i = 0; i < imax; i++) { - if (major >> 10 == 0) - break; - else { + if (major >> 10 == 0) + break; + else { minor = major - (major >> 10 << 10); - major = major >> 10; - } - } + major = major >> 10; + } + } minor = (minor * 10) >> 10; - + if (i == 0 || i >= imax) - *buf = '\0'; - else + *buf = '\0'; + else snprintf(buf, size, "%" PRId64 ".%" PRId64 "%c", major, minor, shorts[i]); - - return buf; - } - + + return buf; + } + char* PrettyNum(i64 val, char* buf, size_t size) { Y_ASSERT(buf); if (size < 4) { diff --git a/library/cpp/monlib/counters/counters.h b/library/cpp/monlib/counters/counters.h index 038b55f0c8..3492231282 100644 --- a/library/cpp/monlib/counters/counters.h +++ b/library/cpp/monlib/counters/counters.h @@ -21,7 +21,7 @@ namespace NMonitoring { #define BEGIN_OUTPUT_COUNTERS \ void OutputImpl(IOutputStream& out) { \ - char prettyBuf[32]; + char prettyBuf[32]; #define END_OUTPUT_COUNTERS \ out.Flush(); \ } @@ -31,7 +31,7 @@ namespace NMonitoring { char* PrettyNumShort(i64 val, char* buf, size_t size); char* PrettyNum(i64 val, char* buf, size_t size); - + // This class is deprecated. Please consider to use // library/cpp/monlib/metrics instead. See more info at // https://wiki.yandex-team.ru/solomon/libs/monlib_cpp/ diff --git a/library/cpp/monlib/dynamic_counters/counters.cpp b/library/cpp/monlib/dynamic_counters/counters.cpp index 3635d87d0d..2d7d0954d6 100644 --- a/library/cpp/monlib/dynamic_counters/counters.cpp +++ b/library/cpp/monlib/dynamic_counters/counters.cpp @@ -127,13 +127,13 @@ TIntrusivePtr<TDynamicCounters> TDynamicCounters::GetSubgroup(const TString& nam } return res; } - + TIntrusivePtr<TDynamicCounters> TDynamicCounters::FindSubgroup(const TString& name, const TString& value) const { TReadGuard g(Lock); const auto it = Counters.find({name, value}); return it != Counters.end() ? AsDynamicCounters(it->second) : nullptr; -} - +} + void TDynamicCounters::RemoveSubgroup(const TString& name, const TString& value) { auto g = LockForUpdate("RemoveSubgroup", name, value); if (const auto it = Counters.find({name, value}); it != Counters.end() && AsDynamicCounters(it->second)) { @@ -189,8 +189,8 @@ void TDynamicCounters::OutputHtml(IOutputStream& os) const { OutputPlainText(os); } } -} - +} + void TDynamicCounters::EnumerateSubgroups(const std::function<void(const TString& name, const TString& value)>& output) const { TReadGuard g(Lock); for (const auto& [key, value] : Counters) { @@ -202,24 +202,24 @@ void TDynamicCounters::EnumerateSubgroups(const std::function<void(const TString void TDynamicCounters::OutputPlainText(IOutputStream& os, const TString& indent) const { auto snap = ReadSnapshot(); - // mark private records in plain text output - auto outputVisibilityMarker = [] (EVisibility vis) { - return vis == EVisibility::Private ? "\t[PRIVATE]" : ""; - }; + // mark private records in plain text output + auto outputVisibilityMarker = [] (EVisibility vis) { + return vis == EVisibility::Private ? "\t[PRIVATE]" : ""; + }; for (const auto& [key, value] : snap) { if (const auto counter = AsCounter(value)) { os << indent << key.LabelName << '=' << key.LabelValue << ": " << counter->Val() - << outputVisibilityMarker(counter->Visibility()) + << outputVisibilityMarker(counter->Visibility()) << '\n'; } else if (const auto histogram = AsHistogram(value)) { os << indent << key.LabelName << '=' << key.LabelValue - << ":" - << outputVisibilityMarker(histogram->Visibility()) - << "\n"; + << ":" + << outputVisibilityMarker(histogram->Visibility()) + << "\n"; auto snapshot = histogram->Snapshot(); for (ui32 i = 0, count = snapshot->Count(); i < count; i++) { diff --git a/library/cpp/monlib/dynamic_counters/page.h b/library/cpp/monlib/dynamic_counters/page.h index 1f0ef6a5ea..0f1091360a 100644 --- a/library/cpp/monlib/dynamic_counters/page.h +++ b/library/cpp/monlib/dynamic_counters/page.h @@ -31,7 +31,7 @@ namespace NMonitoring { const TString& title, TIntrusivePtr<TDynamicCounters> counters, TOutputCallback outputCallback = nullptr) - : TPreMonPage(path, title) + : TPreMonPage(path, title) , Counters(counters) , OutputCallback(outputCallback) { diff --git a/library/cpp/monlib/dynamic_counters/percentile/percentile_base.h b/library/cpp/monlib/dynamic_counters/percentile/percentile_base.h index d3c825c43d..1500ab4c9a 100644 --- a/library/cpp/monlib/dynamic_counters/percentile/percentile_base.h +++ b/library/cpp/monlib/dynamic_counters/percentile/percentile_base.h @@ -16,20 +16,20 @@ struct TPercentileBase : public TThrRefBase { TPercentiles Percentiles; - void Initialize(const TIntrusivePtr<NMonitoring::TDynamicCounters> &counters, const TVector<float> &thresholds, - TCountableBase::EVisibility visibility = TCountableBase::EVisibility::Public) { + void Initialize(const TIntrusivePtr<NMonitoring::TDynamicCounters> &counters, const TVector<float> &thresholds, + TCountableBase::EVisibility visibility = TCountableBase::EVisibility::Public) { Percentiles.reserve(thresholds.size()); for (size_t i = 0; i < thresholds.size(); ++i) { Percentiles.emplace_back(thresholds[i], - counters->GetNamedCounter("percentile", Sprintf("%.1f", thresholds[i] * 100.f), false, visibility)); + counters->GetNamedCounter("percentile", Sprintf("%.1f", thresholds[i] * 100.f), false, visibility)); } } void Initialize(const TIntrusivePtr<NMonitoring::TDynamicCounters> &counters, TString group, TString subgroup, - TString name, const TVector<float> &thresholds, - TCountableBase::EVisibility visibility = TCountableBase::EVisibility::Public) { + TString name, const TVector<float> &thresholds, + TCountableBase::EVisibility visibility = TCountableBase::EVisibility::Public) { auto subCounters = counters->GetSubgroup(group, subgroup)->GetSubgroup("sensor", name); - Initialize(subCounters, thresholds, visibility); + Initialize(subCounters, thresholds, visibility); } }; diff --git a/library/cpp/monlib/service/monservice.cpp b/library/cpp/monlib/service/monservice.cpp index d1b9cda1d2..13d64c2937 100644 --- a/library/cpp/monlib/service/monservice.cpp +++ b/library/cpp/monlib/service/monservice.cpp @@ -113,7 +113,7 @@ void TMonService2::Register(TMonPagePtr page) { } TIndexMonPage* TMonService2::RegisterIndexPage(const TString& path, const TString& title) { - return IndexMonPage->RegisterIndexPage(path, title); + return IndexMonPage->RegisterIndexPage(path, title); } IMonPage* TMonService2::FindPage(const TString& relativePath) { diff --git a/library/cpp/monlib/service/pages/html_mon_page.cpp b/library/cpp/monlib/service/pages/html_mon_page.cpp index eb4eb3b66c..26c9a69334 100644 --- a/library/cpp/monlib/service/pages/html_mon_page.cpp +++ b/library/cpp/monlib/service/pages/html_mon_page.cpp @@ -24,14 +24,14 @@ void THtmlMonPage::Output(NMonitoring::IMonHttpRequest& request) { out << "<script language='javascript' type='text/javascript' src='/jquery.tablesorter.js'></script>\n"; } - out << "<style type=\"text/css\">\n"; - out << ".table-nonfluid { width: auto; }\n"; - out << ".narrow-line50 {line-height: 50%}\n"; - out << ".narrow-line60 {line-height: 60%}\n"; - out << ".narrow-line70 {line-height: 70%}\n"; - out << ".narrow-line80 {line-height: 80%}\n"; - out << ".narrow-line90 {line-height: 90%}\n"; - out << "</style>\n"; + out << "<style type=\"text/css\">\n"; + out << ".table-nonfluid { width: auto; }\n"; + out << ".narrow-line50 {line-height: 50%}\n"; + out << ".narrow-line60 {line-height: 60%}\n"; + out << ".narrow-line70 {line-height: 70%}\n"; + out << ".narrow-line80 {line-height: 80%}\n"; + out << ".narrow-line90 {line-height: 90%}\n"; + out << "</style>\n"; } BODY() { OutputNavBar(out); diff --git a/library/cpp/monlib/service/pages/index_mon_page.cpp b/library/cpp/monlib/service/pages/index_mon_page.cpp index 83ff8b529a..fb41f468a6 100644 --- a/library/cpp/monlib/service/pages/index_mon_page.cpp +++ b/library/cpp/monlib/service/pages/index_mon_page.cpp @@ -67,19 +67,19 @@ void TIndexMonPage::OutputIndex(IOutputStream& out, bool pathEndsWithSlash) { void TIndexMonPage::Register(TMonPagePtr page) { TGuard<TMutex> g(Mtx); - auto insres = PagesByPath.insert(std::make_pair("/" + page->GetPath(), page)); - if (insres.second) { - // new unique page just inserted, update Pages - Pages.push_back(page); - } else { - // a page with the given path is already present, replace it with the new page - - // find old page, sorry for O(n) - auto it = std::find(Pages.begin(), Pages.end(), insres.first->second); - *it = page; - // this already present, replace it - insres.first->second = page; - } + auto insres = PagesByPath.insert(std::make_pair("/" + page->GetPath(), page)); + if (insres.second) { + // new unique page just inserted, update Pages + Pages.push_back(page); + } else { + // a page with the given path is already present, replace it with the new page + + // find old page, sorry for O(n) + auto it = std::find(Pages.begin(), Pages.end(), insres.first->second); + *it = page; + // this already present, replace it + insres.first->second = page; + } page->Parent = this; } @@ -90,7 +90,7 @@ TIndexMonPage* TIndexMonPage::RegisterIndexPage(const TString& path, const TStri return page; } page = new TIndexMonPage(path, title); - Register(page); + Register(page); return VerifyDynamicCast<TIndexMonPage*>(page); } diff --git a/library/cpp/monlib/service/pages/pre_mon_page.cpp b/library/cpp/monlib/service/pages/pre_mon_page.cpp index fc03a19b80..6db90243ee 100644 --- a/library/cpp/monlib/service/pages/pre_mon_page.cpp +++ b/library/cpp/monlib/service/pages/pre_mon_page.cpp @@ -4,14 +4,14 @@ using namespace NMonitoring; void TPreMonPage::OutputContent(NMonitoring::IMonHttpRequest& request) { auto& out = request.Output(); - if (PreTag) { + if (PreTag) { BeforePre(request); out << "<pre>\n"; OutputText(out, request); out << "</pre>\n"; - } else { + } else { OutputText(out, request); - } + } } void TPreMonPage::BeforePre(NMonitoring::IMonHttpRequest&) { diff --git a/library/cpp/monlib/service/pages/pre_mon_page.h b/library/cpp/monlib/service/pages/pre_mon_page.h index c9a923d39a..281e625de3 100644 --- a/library/cpp/monlib/service/pages/pre_mon_page.h +++ b/library/cpp/monlib/service/pages/pre_mon_page.h @@ -23,5 +23,5 @@ namespace NMonitoring { const bool PreTag; }; - + } diff --git a/library/cpp/monlib/service/pages/templates.cpp b/library/cpp/monlib/service/pages/templates.cpp index ece12bea71..281f9c9c68 100644 --- a/library/cpp/monlib/service/pages/templates.cpp +++ b/library/cpp/monlib/service/pages/templates.cpp @@ -1,35 +1,35 @@ -#include "templates.h" - -namespace NMonitoring { +#include "templates.h" + +namespace NMonitoring { extern const char HtmlTag[] = "html"; extern const char HeadTag[] = "head"; extern const char BodyTag[] = "body"; - extern const char DivTag[] = "div"; - extern const char TableTag[] = "table"; - extern const char TableHeadTag[] = "thead"; - extern const char TableBodyTag[] = "tbody"; - extern const char TableRTag[] = "tr"; - extern const char TableDTag[] = "td"; - extern const char TableHTag[] = "th"; - extern const char FormTag[] = "form"; - extern const char LabelTag[] = "label"; - extern const char SpanTag[] = "span"; - extern const char CaptionTag[] = "caption"; + extern const char DivTag[] = "div"; + extern const char TableTag[] = "table"; + extern const char TableHeadTag[] = "thead"; + extern const char TableBodyTag[] = "tbody"; + extern const char TableRTag[] = "tr"; + extern const char TableDTag[] = "td"; + extern const char TableHTag[] = "th"; + extern const char FormTag[] = "form"; + extern const char LabelTag[] = "label"; + extern const char SpanTag[] = "span"; + extern const char CaptionTag[] = "caption"; extern const char PreTag[] = "pre"; - extern const char ParaTag[] = "p"; + extern const char ParaTag[] = "p"; extern const char H1Tag[] = "h1"; extern const char H2Tag[] = "h2"; extern const char H3Tag[] = "h3"; extern const char H4Tag[] = "h4"; extern const char H5Tag[] = "h5"; extern const char H6Tag[] = "h6"; - extern const char SmallTag[] = "small"; - extern const char StrongTag[] = "strong"; + extern const char SmallTag[] = "small"; + extern const char StrongTag[] = "strong"; extern const char ListTag[] = "li"; extern const char UListTag[] = "ul"; extern const char OListTag[] = "ol"; extern const char DListTag[] = "dl"; extern const char DTermTag[] = "dt"; extern const char DDescTag[] = "dd"; - + } diff --git a/library/cpp/monlib/service/pages/templates.h b/library/cpp/monlib/service/pages/templates.h index b4656f059f..dba4e8a11a 100644 --- a/library/cpp/monlib/service/pages/templates.h +++ b/library/cpp/monlib/service/pages/templates.h @@ -1,10 +1,10 @@ -#pragma once - -#include <util/stream/output.h> +#pragma once + +#include <util/stream/output.h> #include <util/system/defaults.h> - + #define WITH_SCOPED(var, value) WITH_SCOPED_I(var, value, Y_GENERATE_UNIQUE_ID(WITH_SCOPED_LABEL_)) - + #define WITH_SCOPED_I(var, value, label) \ if (auto var = (value)) { \ Y_UNUSED(var); \ @@ -12,7 +12,7 @@ } else \ label \ : - + #define TAG(name) WITH_SCOPED(tmp, NMonitoring::name(__stream)) #define TAG_CLASS(name, cls) WITH_SCOPED(tmp, NMonitoring::name(__stream, cls)) #define TAG_CLASS_STYLE(name, cls, style) WITH_SCOPED(tmp, NMonitoring::name(__stream, {{"class", cls}, {"style", style}})) @@ -21,7 +21,7 @@ #define TAG_ATTRS(name, ...) WITH_SCOPED(tmp, NMonitoring::name(__stream, ##__VA_ARGS__)) #define HTML(str) WITH_SCOPED(__stream, NMonitoring::TOutputStreamRef(str)) - + #define HEAD() TAG(THead) #define BODY() TAG(TBody) #define HTML_TAG() TAG(THtml) @@ -51,7 +51,7 @@ #define LABEL_CLASS_FOR(cls, for0) TAG_CLASS_FOR(TLabelC, cls, for0) #define SPAN_CLASS(cls) TAG_CLASS(TSpanC, cls) #define SPAN_CLASS_STYLE(cls, style) TAG_CLASS_STYLE(TSpanC, cls, style) - + #define PARA() TAG(TPara) #define PARA_CLASS(cls) TAG_CLASS(TPara, cls) @@ -67,7 +67,7 @@ #define H5_CLASS(cls) TAG_CLASS(TH5, cls) #define H6() TAG(TH6) #define H6_CLASS(cls) TAG_CLASS(TH6, cls) - + #define SMALL() TAG(TSMALL) #define STRONG() TAG(TSTRONG) @@ -77,7 +77,7 @@ #define UL_CLASS(cls) TAG_CLASS(TULIST, cls) #define OL() TAG(TOLIST) #define OL_CLASS(cls) TAG_CLASS(TOLIST, cls) - + #define DL() TAG(DLIST) #define DL_CLASS(cls) TAG_CLASS(DLIST, cls) #define DT() TAG(DTERM) @@ -88,16 +88,16 @@ #define CAPTION() TAG(TCaption) #define CAPTION_CLASS(cls) CAPTION_CLASS(TCaption, cls) -#define HTML_OUTPUT_PARAM(str, param) str << #param << ": " << param << "<br/>" -#define HTML_OUTPUT_TIME_PARAM(str, param) str << #param << ": " << ToStringLocalTimeUpToSeconds(param) << "<br/>" - +#define HTML_OUTPUT_PARAM(str, param) str << #param << ": " << param << "<br/>" +#define HTML_OUTPUT_TIME_PARAM(str, param) str << #param << ": " << ToStringLocalTimeUpToSeconds(param) << "<br/>" + #define COLLAPSED_BUTTON_CONTENT(targetId, buttonText) \ WITH_SCOPED(tmp, NMonitoring::TCollapsedButton(__stream, targetId, buttonText)) - + #define HREF(path) \ WITH_SCOPED(tmp, NMonitoring::THref(__stream, path)) -namespace NMonitoring { +namespace NMonitoring { struct THref { THref(IOutputStream& str, TStringBuf path) : Str(str) @@ -117,16 +117,16 @@ namespace NMonitoring { }; template <const char* tag> - struct TTag { + struct TTag { TTag(IOutputStream& str, TStringBuf cls = "", TStringBuf for0 = "", TStringBuf id = "") - : Str(str) - { + : Str(str) + { Str << "<" << tag; - + if (!cls.empty()) { Str << " class=\"" << cls << "\""; } - + if (!for0.empty()) { Str << " for=\"" << for0 << "\""; } @@ -135,8 +135,8 @@ namespace NMonitoring { Str << "id=\"" << id << "\""; } Str << ">"; - } - + } + TTag(IOutputStream& str, std::initializer_list<std::pair<TStringBuf, TStringBuf>> attributes) : Str(str) { @@ -149,44 +149,44 @@ namespace NMonitoring { Str << ">"; } - ~TTag() { + ~TTag() { try { Str << "</" << tag << ">"; } catch (...) { } - } - + } + explicit inline operator bool() const noexcept { return true; // just to work with WITH_SCOPED } IOutputStream& Str; - }; - - // a nice class for creating collapsable regions of html output - struct TCollapsedButton { + }; + + // a nice class for creating collapsable regions of html output + struct TCollapsedButton { TCollapsedButton(IOutputStream& str, const TString& targetId, const TString& buttonText) - : Str(str) - { - Str << "<button type='button' class='btn' data-toggle='collapse' data-target='#" << targetId << "'>" - << buttonText << "</button>"; - Str << "<div id='" << targetId << "' class='collapse'>"; - } - - ~TCollapsedButton() { - try { - Str << "</div>"; + : Str(str) + { + Str << "<button type='button' class='btn' data-toggle='collapse' data-target='#" << targetId << "'>" + << buttonText << "</button>"; + Str << "<div id='" << targetId << "' class='collapse'>"; + } + + ~TCollapsedButton() { + try { + Str << "</div>"; } catch (...) { } - } - + } + explicit inline operator bool() const noexcept { return true; // just to work with WITH_SCOPED } IOutputStream& Str; - }; - + }; + struct TOutputStreamRef { TOutputStreamRef(IOutputStream& str) : Str(str) @@ -234,31 +234,31 @@ namespace NMonitoring { extern const char DListTag[3]; extern const char DTermTag[3]; extern const char DDescTag[3]; - + typedef TTag<HtmlTag> THtml; typedef TTag<HeadTag> THead; typedef TTag<BodyTag> TBody; - typedef TTag<DivTag> TDiv; - typedef TTag<TableTag> TTable; - typedef TTag<TableHeadTag> TTableHead; - typedef TTag<TableBodyTag> TTableBody; - typedef TTag<TableRTag> TTableR; - typedef TTag<TableDTag> TTableD; - typedef TTag<TableHTag> TTableH; - typedef TTag<FormTag> TFormC; - typedef TTag<LabelTag> TLabelC; - typedef TTag<SpanTag> TSpanC; - typedef TTag<CaptionTag> TCaption; + typedef TTag<DivTag> TDiv; + typedef TTag<TableTag> TTable; + typedef TTag<TableHeadTag> TTableHead; + typedef TTag<TableBodyTag> TTableBody; + typedef TTag<TableRTag> TTableR; + typedef TTag<TableDTag> TTableD; + typedef TTag<TableHTag> TTableH; + typedef TTag<FormTag> TFormC; + typedef TTag<LabelTag> TLabelC; + typedef TTag<SpanTag> TSpanC; + typedef TTag<CaptionTag> TCaption; typedef TTag<PreTag> TPre; - typedef TTag<ParaTag> TPara; + typedef TTag<ParaTag> TPara; typedef TTag<H1Tag> TH1; typedef TTag<H2Tag> TH2; typedef TTag<H3Tag> TH3; typedef TTag<H4Tag> TH4; typedef TTag<H5Tag> TH5; typedef TTag<H6Tag> TH6; - typedef TTag<SmallTag> TSMALL; - typedef TTag<StrongTag> TSTRONG; + typedef TTag<SmallTag> TSMALL; + typedef TTag<StrongTag> TSTRONG; typedef TTag<ListTag> TLIST; typedef TTag<UListTag> TULIST; typedef TTag<OListTag> TOLIST; |