aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/monlib
diff options
context:
space:
mode:
authorAndrey Fomichev <andrey.fomichev@gmail.com>2022-02-10 16:49:12 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:49:12 +0300
commite542cc14db4240643a06bb0dde87ecf361f101ab (patch)
tree3b03a4b94acd11a4eca042532035806e5fa08ad1 /library/cpp/monlib
parente2ac73225f30f7fcf7df3cb225cba257f56144c1 (diff)
downloadydb-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.cpp40
-rw-r--r--library/cpp/monlib/counters/counters.h4
-rw-r--r--library/cpp/monlib/dynamic_counters/counters.cpp26
-rw-r--r--library/cpp/monlib/dynamic_counters/page.h2
-rw-r--r--library/cpp/monlib/dynamic_counters/percentile/percentile_base.h12
-rw-r--r--library/cpp/monlib/service/monservice.cpp2
-rw-r--r--library/cpp/monlib/service/pages/html_mon_page.cpp16
-rw-r--r--library/cpp/monlib/service/pages/index_mon_page.cpp28
-rw-r--r--library/cpp/monlib/service/pages/pre_mon_page.cpp6
-rw-r--r--library/cpp/monlib/service/pages/pre_mon_page.h2
-rw-r--r--library/cpp/monlib/service/pages/templates.cpp36
-rw-r--r--library/cpp/monlib/service/pages/templates.h116
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;