aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/string_utils/url
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/string_utils/url
parent72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff)
downloadydb-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.cpp84
-rw-r--r--library/cpp/string_utils/url/url_ut.cpp6
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?
}