diff options
author | Anton Samokhvalov <pg83@yandex.ru> | 2022-02-10 16:45:17 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:45:17 +0300 |
commit | d3a398281c6fd1d3672036cb2d63f842d2cb28c5 (patch) | |
tree | dd4bd3ca0f36b817e96812825ffaf10d645803f2 /library/cpp/string_utils/url | |
parent | 72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff) | |
download | ydb-d3a398281c6fd1d3672036cb2d63f842d2cb28c5.tar.gz |
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 2 of 2.
Diffstat (limited to 'library/cpp/string_utils/url')
-rw-r--r-- | library/cpp/string_utils/url/url.cpp | 84 | ||||
-rw-r--r-- | library/cpp/string_utils/url/url_ut.cpp | 6 |
2 files changed, 45 insertions, 45 deletions
diff --git a/library/cpp/string_utils/url/url.cpp b/library/cpp/string_utils/url/url.cpp index 0e9e482ed6..85f4ac5d69 100644 --- a/library/cpp/string_utils/url/url.cpp +++ b/library/cpp/string_utils/url/url.cpp @@ -1,5 +1,5 @@ -#include "url.h" - +#include "url.h" + #include <util/string/cast.h> #include <util/string/util.h> #include <util/string/cstriter.h> @@ -11,7 +11,7 @@ #include <util/generic/algorithm.h> #include <util/generic/hash_set.h> #include <util/generic/yexception.h> -#include <util/generic/singleton.h> +#include <util/generic/singleton.h> #include <cstdlib> @@ -26,8 +26,8 @@ namespace { size_t MySize; explicit TKnownSize(size_t sz) : MySize(sz) - { - } + { + } bool Has(size_t sz) const { return sz <= MySize; } @@ -43,9 +43,9 @@ namespace { } template <typename TChar, typename TBounds> - inline size_t GetHttpPrefixSizeImpl(const TChar* url, const TBounds& urlSize, bool ignorehttps) { - const TChar httpPrefix[] = {'h', 't', 't', 'p', ':', '/', '/', 0}; - const TChar httpsPrefix[] = {'h', 't', 't', 'p', 's', ':', '/', '/', 0}; + inline size_t GetHttpPrefixSizeImpl(const TChar* url, const TBounds& urlSize, bool ignorehttps) { + const TChar httpPrefix[] = {'h', 't', 't', 'p', ':', '/', '/', 0}; + const TChar httpsPrefix[] = {'h', 't', 't', 'p', 's', ':', '/', '/', 0}; if (urlSize.Has(7) && Compare1Case2(url, httpPrefix, 7) == 0) return 7; if (!ignorehttps && urlSize.Has(8) && Compare1Case2(url, httpsPrefix, 8) == 0) @@ -98,20 +98,20 @@ TWtringBuf CutHttpPrefix(const TWtringBuf url, bool ignorehttps) noexcept { } size_t GetSchemePrefixSize(const TStringBuf url) noexcept { - struct TDelim: public str_spn { - inline TDelim() - : str_spn("!-/:-@[-`{|}", true) - { - } - }; - - const auto& delim = *Singleton<TDelim>(); + struct TDelim: public str_spn { + inline TDelim() + : str_spn("!-/:-@[-`{|}", true) + { + } + }; + + const auto& delim = *Singleton<TDelim>(); const char* n = delim.brk(url.data(), url.end()); - - if (n + 2 >= url.end() || *n != ':' || n[1] != '/' || n[2] != '/') { + + if (n + 2 >= url.end() || *n != ':' || n[1] != '/' || n[2] != '/') { return 0; - } - + } + return n + 3 - url.begin(); } @@ -123,27 +123,27 @@ TStringBuf CutSchemePrefix(const TStringBuf url) noexcept { return url.Tail(GetSchemePrefixSize(url)); } -template <bool KeepPort> +template <bool KeepPort> static inline TStringBuf GetHostAndPortImpl(const TStringBuf url) { TStringBuf urlNoScheme = url; - + urlNoScheme.Skip(GetHttpPrefixSize(url)); - struct TDelim: public str_spn { - inline TDelim() - : str_spn(KeepPort ? "/;?#" : "/:;?#") - { - } - }; - - const auto& nonHostCharacters = *Singleton<TDelim>(); + struct TDelim: public str_spn { + inline TDelim() + : str_spn(KeepPort ? "/;?#" : "/:;?#") + { + } + }; + + const auto& nonHostCharacters = *Singleton<TDelim>(); const char* firstNonHostCharacter = nonHostCharacters.brk(urlNoScheme.begin(), urlNoScheme.end()); - - if (firstNonHostCharacter != urlNoScheme.end()) { + + if (firstNonHostCharacter != urlNoScheme.end()) { return urlNoScheme.substr(0, firstNonHostCharacter - urlNoScheme.data()); - } - - return urlNoScheme; + } + + return urlNoScheme; } TStringBuf GetHost(const TStringBuf url) noexcept { @@ -337,27 +337,27 @@ TString AddSchemePrefix(const TString& url, TStringBuf scheme) { #define X(c) (c >= 'A' ? ((c & 0xdf) - 'A') + 10 : (c - '0')) static inline int x2c(unsigned char* x) { - if (!IsAsciiHex(x[0]) || !IsAsciiHex(x[1])) + if (!IsAsciiHex(x[0]) || !IsAsciiHex(x[1])) return -1; return X(x[0]) * 16 + X(x[1]); } #undef X -static inline int Unescape(char* str) { - char *to, *from; +static inline int Unescape(char* str) { + char *to, *from; int dlen = 0; if ((str = strchr(str, '%')) == nullptr) return dlen; for (to = str, from = str; *from; from++, to++) { if ((*to = *from) == '%') { - int c = x2c((unsigned char*)from + 1); + int c = x2c((unsigned char*)from + 1); *to = char((c > 0) ? c : '0'); from += 2; dlen += 2; } } - *to = 0; /* terminate it at the new length */ + *to = 0; /* terminate it at the new length */ return dlen; } @@ -379,8 +379,8 @@ size_t NormalizeHostName(char* dest, const TStringBuf source, size_t dest_size, char buf[8] = ":"; size_t buflen = 1 + ToString(defport, buf + 1, sizeof(buf) - 2); buf[buflen] = '\0'; - char* ptr = strstr(dest, buf); - if (ptr && ptr[buflen] == 0) { + char* ptr = strstr(dest, buf); + if (ptr && ptr[buflen] == 0) { len -= buflen; *ptr = 0; } diff --git a/library/cpp/string_utils/url/url_ut.cpp b/library/cpp/string_utils/url/url_ut.cpp index bf12597c98..1588013893 100644 --- a/library/cpp/string_utils/url/url_ut.cpp +++ b/library/cpp/string_utils/url/url_ut.cpp @@ -1,5 +1,5 @@ -#include "url.h" - +#include "url.h" + #include <util/string/cast.h> #include <library/cpp/testing/unittest/registar.h> @@ -100,7 +100,7 @@ Y_UNIT_TEST_SUITE(TUtilUrlTest) { UNIT_ASSERT_VALUES_EQUAL("ya.ru/zzz", CutHttpPrefix("http://ya.ru/zzz", true)); UNIT_ASSERT_VALUES_EQUAL("ya.ru/zzz", CutHttpPrefix("https://ya.ru/zzz")); UNIT_ASSERT_VALUES_EQUAL("https://ya.ru/zzz", CutHttpPrefix("https://ya.ru/zzz", true)); - UNIT_ASSERT_VALUES_EQUAL("", CutHttpPrefix("https://")); // is that right? + UNIT_ASSERT_VALUES_EQUAL("", CutHttpPrefix("https://")); // is that right? UNIT_ASSERT_VALUES_EQUAL("https://", CutHttpPrefix("https://", true)); // is that right? } |