aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/uri/uri.h
diff options
context:
space:
mode:
authoralbert <albert@yandex-team.ru>2022-02-10 16:48:14 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:48:14 +0300
commit9f25ef3232c288ca664ceee6c376cf64e4349a2e (patch)
treeb192eaf3150845f7302fafd460a972b0439d6fe5 /library/cpp/uri/uri.h
parent6a1e535429145ec1ecfbc5f1efd3c95323261fb5 (diff)
downloadydb-9f25ef3232c288ca664ceee6c376cf64e4349a2e.tar.gz
Restoring authorship annotation for <albert@yandex-team.ru>. Commit 1 of 2.
Diffstat (limited to 'library/cpp/uri/uri.h')
-rw-r--r--library/cpp/uri/uri.h182
1 files changed, 91 insertions, 91 deletions
diff --git a/library/cpp/uri/uri.h b/library/cpp/uri/uri.h
index 3b6c19fe4a..c686e0c7ea 100644
--- a/library/cpp/uri/uri.h
+++ b/library/cpp/uri/uri.h
@@ -1,22 +1,22 @@
#pragma once
-#include "common.h"
-#include "encode.h"
+#include "common.h"
+#include "encode.h"
#include <library/cpp/charset/doccodes.h>
#include <util/generic/buffer.h>
-#include <util/generic/ptr.h>
-#include <util/generic/singleton.h>
+#include <util/generic/ptr.h>
+#include <util/generic/singleton.h>
#include <util/generic/string.h>
-#include <util/memory/alloc.h>
+#include <util/memory/alloc.h>
#include <util/stream/mem.h>
-#include <util/stream/output.h>
+#include <util/stream/output.h>
#include <util/stream/str.h>
#include <util/system/yassert.h>
#include <cstdlib>
-namespace NUri {
+namespace NUri {
/********************************************************/
class TUri
: public TFeature,
@@ -31,7 +31,7 @@ namespace NUri {
LinkIsLocal,
LinkIsGlobal
};
-
+
private:
TBuffer Buffer;
TStringBuf Fields[FieldAllMAX];
@@ -57,7 +57,7 @@ namespace NUri {
Scheme = SchemeEmpty;
FieldsDirty = 0;
}
-
+
void CopyData(const TUri& url) {
FieldsSet = url.FieldsSet;
Port = url.Port;
@@ -65,51 +65,51 @@ namespace NUri {
Scheme = url.Scheme;
FieldsDirty = url.FieldsDirty;
}
-
+
void CopyImpl(const TUri& url) {
for (int i = 0; i < FieldAllMAX; ++i)
Fields[i] = url.Fields[i];
-
+
RewriteImpl();
}
-
+
private:
static ui32 FldFlag(EField fld) {
return 1 << fld;
}
-
+
public:
static bool FldIsValid(EField fld) {
return 0 <= fld && FieldAllMAX > fld;
}
-
+
bool FldSetCmp(ui32 chk, ui32 exp) const {
return (FieldsSet & chk) == exp;
}
-
+
bool FldSetCmp(ui32 chk) const {
return FldSetCmp(chk, chk);
}
-
+
bool FldIsSet(EField fld) const {
return !FldSetCmp(FldFlag(fld), 0);
}
-
+
private:
void FldMarkSet(EField fld) {
FieldsSet |= FldFlag(fld);
}
-
+
void FldMarkUnset(EField fld) {
FieldsSet &= ~FldFlag(fld);
}
-
+
// use when we know the field is dirty or RewriteImpl will be called
void FldSetNoDirty(EField fld, const TStringBuf& value) {
Fields[fld] = value;
FldMarkSet(fld);
}
-
+
void FldSet(EField fld, const TStringBuf& value) {
FldSetNoDirty(fld, value);
FldMarkDirty(fld);
@@ -118,7 +118,7 @@ namespace NUri {
const TStringBuf& FldGet(EField fld) const {
return Fields[fld];
}
-
+
private:
/// depending on value, clears or sets it
void FldChkSet(EField fld, const TStringBuf& value) {
@@ -130,7 +130,7 @@ namespace NUri {
void FldChkSet(EField fld, const TUri& other) {
FldChkSet(fld, other.GetField(fld));
}
-
+
/// set only if initialized
bool FldTrySet(EField fld, const TStringBuf& value) {
const bool ok = value.IsInited();
@@ -145,48 +145,48 @@ namespace NUri {
private:
/// copies the value if it fits
bool FldTryCpy(EField fld, const TStringBuf& value);
-
+
// main method: sets the field value, possibly copies, etc.
bool FldSetImpl(EField fld, TStringBuf value, bool strconst = false, bool nocopy = false);
-
+
public: // clear a field
void FldClr(EField fld) {
Fields[fld].Clear();
FldMarkUnset(fld);
FldMarkClean(fld);
}
-
+
bool FldTryClr(EField field) {
const bool ok = FldIsSet(field);
if (ok)
FldClr(field);
return ok;
}
-
+
public: // set a field value: might leave state dirty and require a Rewrite()
// copies if fits and not dirty, sets and marks dirty otherwise
bool FldMemCpy(EField field, const TStringBuf& value) {
return FldSetImpl(field, value, false);
}
-
+
// uses directly, marks dirty
/// @note client MUST guarantee value will be alive until Rewrite is called
bool FldMemSet(EField field, const TStringBuf& value) {
return FldSetImpl(field, value, false, true);
}
-
+
// uses directly, doesn't mark dirty (value scope exceeds "this")
bool FldMemUse(EField field, const TStringBuf& value) {
return FldSetImpl(field, value, true);
}
-
+
// uses directly, doesn't mark dirty
template <size_t size>
bool FldMemSet(EField field, const char (&value)[size]) {
static_assert(size > 0);
return FldSetImpl(field, TStringBuf(value, size - 1), true);
}
-
+
// duplicate one field to another
bool FldDup(EField src, EField dst) {
if (!FldIsSet(src) || !FldIsValid(dst))
@@ -198,7 +198,7 @@ namespace NUri {
FldMarkClean(dst);
return true;
}
-
+
// move one field to another
bool FldMov(EField src, EField dst) {
if (!FldDup(src, dst))
@@ -206,47 +206,47 @@ namespace NUri {
FldClr(src);
return true;
}
-
+
private:
bool IsInBuffer(const char* buf) const {
return buf >= Buffer.data() && buf < Buffer.data() + Buffer.size();
}
-
+
public:
bool FldIsDirty() const {
return 0 != FieldsDirty;
}
-
+
bool FldIsDirty(EField fld) const {
return 0 != (FieldsDirty & FldFlag(fld));
}
-
+
private:
void FldMarkDirty(EField fld) {
FieldsDirty |= FldFlag(fld);
}
-
+
void FldMarkClean(EField fld) {
FieldsDirty &= ~FldFlag(fld);
}
-
+
void RewriteImpl();
-
+
public:
static TState::EParsed CheckHost(const TStringBuf& host);
-
+
// convert a [potential] IDN to ascii
static TMallocPtr<char> IDNToAscii(const wchar32* idna);
static TMallocPtr<char> IDNToAscii(const TStringBuf& host, ECharset enc = CODES_UTF8);
-
+
// convert hosts with percent-encoded or extended chars
-
+
// returns non-empty string if host can be converted to ASCII with given parameters
static TStringBuf HostToAscii(TStringBuf host, TMallocPtr<char>& buf, bool hasExtended, bool allowIDN, ECharset enc = CODES_UTF8);
-
+
// returns host if already ascii, or non-empty if it can be converted
static TStringBuf HostToAscii(const TStringBuf& host, TMallocPtr<char>& buf, bool allowIDN, ECharset enc = CODES_UTF8);
-
+
public:
explicit TUri(unsigned defaultPort = 0)
: FieldsSet(0)
@@ -256,9 +256,9 @@ namespace NUri {
, FieldsDirty(0)
{
}
-
+
TUri(const TStringBuf& host, ui16 port, const TStringBuf& path, const TStringBuf& query = TStringBuf(), const TStringBuf& scheme = "http", unsigned defaultPort = 0);
-
+
TUri(const TUri& url)
: FieldsSet(url.FieldsSet)
, Port(url.Port)
@@ -283,8 +283,8 @@ namespace NUri {
void Clear() {
Dealloc();
ClearImpl();
- }
-
+ }
+
ui32 GetFieldMask() const {
return FieldsSet;
}
@@ -292,15 +292,15 @@ namespace NUri {
ui32 GetUrlFieldMask() const {
return GetFieldMask() & FlagUrlFields;
}
-
+
ui32 GetDirtyMask() const {
return FieldsDirty;
}
-
+
void CheckMissingFields();
-
+
// Process methods
-
+
void Rewrite() {
if (FldIsDirty())
RewriteImpl();
@@ -310,7 +310,7 @@ namespace NUri {
TState::EParsed AssignImpl(const TParser& parser, TScheme::EKind defscheme = SchemeEmpty);
TState::EParsed ParseImpl(const TStringBuf& url, const TParseFlags& flags = FeaturesDefault, ui32 maxlen = 0, TScheme::EKind defscheme = SchemeEmpty, ECharset enc = CODES_UTF8);
-
+
public:
TState::EParsed Assign(const TParser& parser, TScheme::EKind defscheme = SchemeEmpty) {
const TState::EParsed ret = AssignImpl(parser, defscheme);
@@ -318,40 +318,40 @@ namespace NUri {
Rewrite();
return ret;
}
-
+
TState::EParsed ParseUri(const TStringBuf& url, const TParseFlags& flags = FeaturesDefault, ui32 maxlen = 0, ECharset enc = CODES_UTF8) {
const TState::EParsed ret = ParseImpl(url, flags, maxlen, SchemeEmpty, enc);
if (ParsedOK == ret)
Rewrite();
return ret;
}
-
+
// parses absolute URIs
// prepends default scheme (unless unknown) if URI has none
TState::EParsed ParseAbsUri(const TStringBuf& url, const TParseFlags& flags = FeaturesDefault, ui32 maxlen = 0, TScheme::EKind defscheme = SchemeUnknown, ECharset enc = CODES_UTF8);
-
+
TState::EParsed ParseAbsOrHttpUri(const TStringBuf& url, const TParseFlags& flags = FeaturesDefault, ui32 maxlen = 0, ECharset enc = CODES_UTF8) {
return ParseAbsUri(url, flags, maxlen, SchemeHTTP, enc);
}
-
+
TState::EParsed Parse(const TStringBuf& url, const TUri& base, const TParseFlags& flags = FeaturesDefault, ui32 maxlen = 0, ECharset enc = CODES_UTF8);
-
+
TState::EParsed Parse(const TStringBuf& url, const TParseFlags& flags = FeaturesDefault) {
return ParseUri(url, flags);
}
-
+
TState::EParsed Parse(const TStringBuf& url, const TParseFlags& flags, const TStringBuf& base_url, ui32 maxlen = 0, ECharset enc = CODES_UTF8);
-
+
TState::EParsed ParseAbs(const TStringBuf& url, const TParseFlags& flags = FeaturesDefault, const TStringBuf& base_url = TStringBuf(), ui32 maxlen = 0, ECharset enc = CODES_UTF8) {
const TState::EParsed result = Parse(url, flags, base_url, maxlen, enc);
return ParsedOK != result || IsValidGlobal() ? result : ParsedBadFormat;
}
-
+
// correctAbs works with head "/.." portions:
// 1 - reject URL
// 0 - keep portions
// -1 - ignore portions
-
+
void Merge(const TUri& base, int correctAbs = -1);
TLinkType Normalize(const TUri& base, const TStringBuf& link, const TStringBuf& codebase = TStringBuf(), long careFlags = FeaturesDefault, ECharset enc = CODES_UTF8);
@@ -365,36 +365,36 @@ namespace NUri {
protected:
size_t PrintSize(ui32 flags) const;
-
+
// Output method, prints to stream
IOutputStream& PrintImpl(IOutputStream& out, int flags) const;
-
+
char* PrintImpl(char* str, size_t size, int flags) const {
TMemoryOutput out(str, size);
PrintImpl(out, flags) << '\0';
return str;
}
-
+
static bool IsAbsPath(const TStringBuf& path) {
return 1 <= path.length() && path[0] == '/';
}
-
+
bool IsAbsPathImpl() const {
return IsAbsPath(GetField(FieldPath));
}
-
+
public:
// Output method, prints to stream
IOutputStream& Print(IOutputStream& out, int flags = FlagUrlFields) const {
return PrintImpl(out, PrintFlags(flags));
}
-
+
// Output method, print to str, allocate memory if str is NULL
// Should be deprecated
char* Print(char* str, size_t size, int flags = FlagUrlFields) const {
return nullptr == str ? Serialize(flags) : Serialize(str, size, flags);
}
-
+
char* Serialize(char* str, size_t size, int flags = FlagUrlFields) const {
Y_ASSERT(str);
flags = PrintFlags(flags);
@@ -407,7 +407,7 @@ namespace NUri {
const size_t size = PrintSize(flags) + 1;
return PrintImpl(static_cast<char*>(malloc(size)), size, flags);
}
-
+
// Output method to str
void Print(TString& str, int flags = FlagUrlFields) const {
flags = PrintFlags(flags);
@@ -415,7 +415,7 @@ namespace NUri {
TStringOutput out(str);
PrintImpl(out, flags);
}
-
+
TString PrintS(int flags = FlagUrlFields) const {
TString str;
Print(str, flags);
@@ -429,7 +429,7 @@ namespace NUri {
TString PrintHostS() const {
return PrintS((Scheme != SchemeHTTP ? FlagScheme : 0) | FlagHostPort);
}
-
+
// Info methods
int Compare(const TUri& A, int flags = FlagUrlFields) const;
@@ -438,7 +438,7 @@ namespace NUri {
const TStringBuf& GetField(EField fld) const {
return FldIsValid(fld) && FldIsSet(fld) ? FldGet(fld) : Default<TStringBuf>();
}
-
+
ui16 GetPort() const {
return 0 == Port ? DefaultPort : Port;
}
@@ -454,14 +454,14 @@ namespace NUri {
bool UseHostAscii() {
return FldMov(FieldHostAscii, FieldHost);
}
-
+
TScheme::EKind GetScheme() const {
return Scheme;
}
const TSchemeInfo& GetSchemeInfo() const {
return TSchemeInfo::Get(Scheme);
}
-
+
bool IsNull(ui32 flags = FlagScheme | FlagHost | FlagPath) const {
return !FldSetCmp(flags);
}
@@ -475,7 +475,7 @@ namespace NUri {
return false;
return IsAbsPathImpl();
}
-
+
bool IsValidGlobal() const {
if (IsNull(FlagScheme | FlagHost))
return false;
@@ -492,13 +492,13 @@ namespace NUri {
bool IsOpaque() const {
return IsRootless();
}
-
+
// Inline helpers
TUri& operator=(const TUri& u) {
Copy(u);
return *this;
}
-
+
bool operator!() const {
return IsNull();
}
@@ -554,14 +554,14 @@ namespace NUri {
static IOutputStream& ReEncode(IOutputStream& out, const TStringBuf& val, long flags = FeaturesEncodeDecode) {
return ReEncodeField(out, val, FieldAllMAX, flags);
}
-
+
static int PathOperationFlag(const TParseFlags& flags) {
return flags & FeaturePathDenyRootParent ? 1
: flags & FeaturePathStripRootParent ? -1 : 0;
}
static bool PathOperation(char*& pathBeg, char*& pathEnd, int correctAbs);
-
+
private:
const TSchemeInfo& SetSchemeImpl(const TSchemeInfo& info) {
Scheme = info.Kind;
@@ -573,7 +573,7 @@ namespace NUri {
const TSchemeInfo& SetSchemeImpl(TScheme::EKind scheme) {
return SetSchemeImpl(TSchemeInfo::Get(scheme));
}
-
+
public:
const TSchemeInfo& SetScheme(const TSchemeInfo& info) {
SetSchemeImpl(info);
@@ -585,7 +585,7 @@ namespace NUri {
return SetScheme(TSchemeInfo::Get(scheme));
}
};
-
+
class TUriUpdate {
TUri& Uri_;
@@ -597,30 +597,30 @@ namespace NUri {
~TUriUpdate() {
Uri_.Rewrite();
}
-
+
public:
bool Set(TField::EField field, const TStringBuf& value) {
return Uri_.FldMemSet(field, value);
}
-
+
template <size_t size>
bool Set(TField::EField field, const char (&value)[size]) {
return Uri_.FldMemSet(field, value);
}
-
+
void Clr(TField::EField field) {
Uri_.FldClr(field);
}
};
-
+
const char* LinkTypeToString(const TUri::TLinkType& t);
-
-}
+
+}
Y_DECLARE_OUT_SPEC(inline, NUri::TUri, out, url) {
- url.Print(out);
-}
-
+ url.Print(out);
+}
+
Y_DECLARE_OUT_SPEC(inline, NUri::TUri::TLinkType, out, t) {
- out << NUri::LinkTypeToString(t);
+ out << NUri::LinkTypeToString(t);
}