aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/html
diff options
context:
space:
mode:
authorAnton Samokhvalov <pg83@yandex.ru>2022-02-10 16:45:17 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:45:17 +0300
commitd3a398281c6fd1d3672036cb2d63f842d2cb28c5 (patch)
treedd4bd3ca0f36b817e96812825ffaf10d645803f2 /library/cpp/html
parent72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff)
downloadydb-d3a398281c6fd1d3672036cb2d63f842d2cb28c5.tar.gz
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 2 of 2.
Diffstat (limited to 'library/cpp/html')
-rw-r--r--library/cpp/html/escape/escape.cpp78
-rw-r--r--library/cpp/html/escape/escape.h6
-rw-r--r--library/cpp/html/pcdata/pcdata.cpp108
-rw-r--r--library/cpp/html/pcdata/pcdata.h8
-rw-r--r--library/cpp/html/pcdata/pcdata_ut.cpp54
5 files changed, 127 insertions, 127 deletions
diff --git a/library/cpp/html/escape/escape.cpp b/library/cpp/html/escape/escape.cpp
index 4e38112ea1..5b8ed60f04 100644
--- a/library/cpp/html/escape/escape.cpp
+++ b/library/cpp/html/escape/escape.cpp
@@ -4,63 +4,63 @@
#include <util/generic/strbuf.h>
namespace NHtml {
- namespace {
- struct TReplace {
- char Char;
- bool ForText;
- TStringBuf Entity;
- };
+ namespace {
+ struct TReplace {
+ char Char;
+ bool ForText;
+ TStringBuf Entity;
+ };
TReplace Escapable[] = {
{'"', false, TStringBuf("&quot;")},
{'&', true, TStringBuf("&amp;")},
{'<', true, TStringBuf("&lt;")},
{'>', true, TStringBuf("&gt;")},
- };
+ };
TString EscapeImpl(const TString& value, bool isText) {
- auto ci = value.begin();
- // Looking for escapable characters.
- for (; ci != value.end(); ++ci) {
- for (size_t i = (isText ? 1 : 0); i < Y_ARRAY_SIZE(Escapable); ++i) {
- if (*ci == Escapable[i].Char) {
- goto escape;
- }
- }
+ auto ci = value.begin();
+ // Looking for escapable characters.
+ for (; ci != value.end(); ++ci) {
+ for (size_t i = (isText ? 1 : 0); i < Y_ARRAY_SIZE(Escapable); ++i) {
+ if (*ci == Escapable[i].Char) {
+ goto escape;
+ }
+ }
}
- // There is no escapable characters, so return original value.
- return value;
+ // There is no escapable characters, so return original value.
+ return value;
- escape:
- TString tmp = TString(value.begin(), ci);
+ escape:
+ TString tmp = TString(value.begin(), ci);
- for (; ci != value.end(); ++ci) {
- size_t i = (isText ? 1 : 0);
+ for (; ci != value.end(); ++ci) {
+ size_t i = (isText ? 1 : 0);
- for (; i < Y_ARRAY_SIZE(Escapable); ++i) {
- if (*ci == Escapable[i].Char) {
- tmp += Escapable[i].Entity;
- break;
- }
- }
-
- if (i == Y_ARRAY_SIZE(Escapable)) {
- tmp += *ci;
- }
+ for (; i < Y_ARRAY_SIZE(Escapable); ++i) {
+ if (*ci == Escapable[i].Char) {
+ tmp += Escapable[i].Entity;
+ break;
+ }
+ }
+
+ if (i == Y_ARRAY_SIZE(Escapable)) {
+ tmp += *ci;
+ }
}
-
- return tmp;
+
+ return tmp;
}
}
- TString EscapeAttributeValue(const TString& value) {
- return EscapeImpl(value, false);
- }
+ TString EscapeAttributeValue(const TString& value) {
+ return EscapeImpl(value, false);
+ }
- TString EscapeText(const TString& value) {
- return EscapeImpl(value, true);
- }
+ TString EscapeText(const TString& value) {
+ return EscapeImpl(value, true);
+ }
}
diff --git a/library/cpp/html/escape/escape.h b/library/cpp/html/escape/escape.h
index e255ec7997..1c45fc5193 100644
--- a/library/cpp/html/escape/escape.h
+++ b/library/cpp/html/escape/escape.h
@@ -3,7 +3,7 @@
#include <util/generic/string.h>
namespace NHtml {
- TString EscapeAttributeValue(const TString& value);
- TString EscapeText(const TString& value);
+ TString EscapeAttributeValue(const TString& value);
+ TString EscapeText(const TString& value);
-}
+}
diff --git a/library/cpp/html/pcdata/pcdata.cpp b/library/cpp/html/pcdata/pcdata.cpp
index 1f8d2950de..740c240fd2 100644
--- a/library/cpp/html/pcdata/pcdata.cpp
+++ b/library/cpp/html/pcdata/pcdata.cpp
@@ -1,54 +1,54 @@
-#include "pcdata.h"
-
+#include "pcdata.h"
+
#include <util/string/strspn.h>
-static TCompactStrSpn sspn("\"<>&'");
-
+static TCompactStrSpn sspn("\"<>&'");
+
static void EncodeHtmlPcdataAppendInternal(const TStringBuf str, TString& strout, bool qAmp) {
- const char* s = str.data();
- const char* e = s + str.length();
-
- for (;;) {
- const char* next = sspn.FindFirstOf(s, e);
-
- strout.AppendNoAlias(s, next - s);
- s = next;
-
+ const char* s = str.data();
+ const char* e = s + str.length();
+
+ for (;;) {
+ const char* next = sspn.FindFirstOf(s, e);
+
+ strout.AppendNoAlias(s, next - s);
+ s = next;
+
if (s == e)
break;
-
- switch (*s) {
- case '\"':
+
+ switch (*s) {
+ case '\"':
strout += TStringBuf("&quot;");
++s;
- break;
-
- case '<':
+ break;
+
+ case '<':
strout += TStringBuf("&lt;");
++s;
- break;
-
- case '>':
+ break;
+
+ case '>':
strout += TStringBuf("&gt;");
++s;
- break;
-
- case '\'':
+ break;
+
+ case '\'':
strout += TStringBuf("&#39;");
++s;
- break;
-
- case '&':
- if (qAmp)
+ break;
+
+ case '&':
+ if (qAmp)
strout += TStringBuf("&amp;");
- else
+ else
strout += TStringBuf("&");
++s;
- break;
- }
- }
+ break;
+ }
+ }
}
-
+
void EncodeHtmlPcdataAppend(const TStringBuf str, TString& strout) {
EncodeHtmlPcdataAppendInternal(str, strout, true);
}
@@ -56,26 +56,26 @@ void EncodeHtmlPcdataAppend(const TStringBuf str, TString& strout) {
TString EncodeHtmlPcdata(const TStringBuf str, bool qAmp) {
TString strout;
EncodeHtmlPcdataAppendInternal(str, strout, qAmp);
- return strout;
-}
-
+ return strout;
+}
+
TString DecodeHtmlPcdata(const TString& sz) {
TString res;
const char* codes[] = {"&quot;", "&lt;", "&gt;", "&#39;", "&#039;", "&amp;", "&apos;", nullptr};
- const char chars[] = {'\"', '<', '>', '\'', '\'', '&', '\''};
- for (size_t i = 0; i < sz.length(); ++i) {
- char c = sz[i];
- if (c == '&') {
- for (const char** p = codes; *p; ++p) {
- size_t len = strlen(*p);
- if (strncmp(sz.c_str() + i, *p, len) == 0) {
- i += len - 1;
- c = chars[p - codes];
- break;
- }
- }
- }
- res += c;
- }
- return res;
-}
+ const char chars[] = {'\"', '<', '>', '\'', '\'', '&', '\''};
+ for (size_t i = 0; i < sz.length(); ++i) {
+ char c = sz[i];
+ if (c == '&') {
+ for (const char** p = codes; *p; ++p) {
+ size_t len = strlen(*p);
+ if (strncmp(sz.c_str() + i, *p, len) == 0) {
+ i += len - 1;
+ c = chars[p - codes];
+ break;
+ }
+ }
+ }
+ res += c;
+ }
+ return res;
+}
diff --git a/library/cpp/html/pcdata/pcdata.h b/library/cpp/html/pcdata/pcdata.h
index f43c3d0c8d..7dd741f53d 100644
--- a/library/cpp/html/pcdata/pcdata.h
+++ b/library/cpp/html/pcdata/pcdata.h
@@ -1,10 +1,10 @@
-#pragma once
-
+#pragma once
+
#include <util/generic/fwd.h>
-
+
/// Converts a text into HTML-code. Special characters of HTML («<», «>», ...) replaced with entities.
TString EncodeHtmlPcdata(const TStringBuf str, bool qAmp = true);
void EncodeHtmlPcdataAppend(const TStringBuf str, TString& strout);
-
+
/// Reverse of EncodeHtmlPcdata()
TString DecodeHtmlPcdata(const TString& sz);
diff --git a/library/cpp/html/pcdata/pcdata_ut.cpp b/library/cpp/html/pcdata/pcdata_ut.cpp
index 7418ecf11e..5833f8bc59 100644
--- a/library/cpp/html/pcdata/pcdata_ut.cpp
+++ b/library/cpp/html/pcdata/pcdata_ut.cpp
@@ -1,36 +1,36 @@
-#include "pcdata.h"
-
+#include "pcdata.h"
+
#include <library/cpp/testing/unittest/registar.h>
-
+
Y_UNIT_TEST_SUITE(TPcdata) {
Y_UNIT_TEST(TestStress) {
- {
- ui64 key = 0x000017C0B76C4E87ull;
+ {
+ ui64 key = 0x000017C0B76C4E87ull;
TString res = EncodeHtmlPcdata(TStringBuf((const char*)&key, sizeof(key)));
- }
-
- for (size_t i = 0; i < 1000; ++i) {
+ }
+
+ for (size_t i = 0; i < 1000; ++i) {
const TString s = NUnitTest::RandomString(i, i);
-
- UNIT_ASSERT_VALUES_EQUAL(DecodeHtmlPcdata(EncodeHtmlPcdata(s)), s);
- }
- }
-
+
+ UNIT_ASSERT_VALUES_EQUAL(DecodeHtmlPcdata(EncodeHtmlPcdata(s)), s);
+ }
+ }
+
Y_UNIT_TEST(Test1) {
const TString tests[] = {
- "qw&qw",
- "&<",
- ">&qw",
- "\'&aaa"};
-
+ "qw&qw",
+ "&<",
+ ">&qw",
+ "\'&aaa"};
+
for (auto s : tests) {
- UNIT_ASSERT_VALUES_EQUAL(DecodeHtmlPcdata(EncodeHtmlPcdata(s)), s);
- }
- }
-
+ UNIT_ASSERT_VALUES_EQUAL(DecodeHtmlPcdata(EncodeHtmlPcdata(s)), s);
+ }
+ }
+
Y_UNIT_TEST(Test2) {
- UNIT_ASSERT_VALUES_EQUAL(EncodeHtmlPcdata("&qqq"), "&amp;qqq");
- }
+ UNIT_ASSERT_VALUES_EQUAL(EncodeHtmlPcdata("&qqq"), "&amp;qqq");
+ }
Y_UNIT_TEST(TestEncodeHtmlPcdataAppend) {
TString s;
@@ -41,8 +41,8 @@ Y_UNIT_TEST_SUITE(TPcdata) {
}
Y_UNIT_TEST(TestStrangeAmpParameter) {
- UNIT_ASSERT_VALUES_EQUAL(EncodeHtmlPcdata("m&m's", true), "m&amp;m&#39;s");
- UNIT_ASSERT_VALUES_EQUAL(EncodeHtmlPcdata("m&m's"), "m&amp;m&#39;s"); //default
+ UNIT_ASSERT_VALUES_EQUAL(EncodeHtmlPcdata("m&m's", true), "m&amp;m&#39;s");
+ UNIT_ASSERT_VALUES_EQUAL(EncodeHtmlPcdata("m&m's"), "m&amp;m&#39;s"); //default
UNIT_ASSERT_VALUES_EQUAL(EncodeHtmlPcdata("m&m's", false), "m&m&#39;s");
}
-}
+}