diff options
author | danlark <danlark@yandex-team.ru> | 2022-02-10 16:46:10 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:46:10 +0300 |
commit | baa58daefa91fde4b4769facdbd2903763b9c6a8 (patch) | |
tree | 1a2c5ffcf89eb53ecd79dbc9bc0a195c27404d0c /util | |
parent | 3426a9bc7f169ae9da54cef557ad2a33f6e8eee0 (diff) | |
download | ydb-baa58daefa91fde4b4769facdbd2903763b9c6a8.tar.gz |
Restoring authorship annotation for <danlark@yandex-team.ru>. Commit 2 of 2.
Diffstat (limited to 'util')
105 files changed, 1539 insertions, 1539 deletions
diff --git a/util/charset/utf8.cpp b/util/charset/utf8.cpp index a18a84dad1..efe3a52f61 100644 --- a/util/charset/utf8.cpp +++ b/util/charset/utf8.cpp @@ -55,19 +55,19 @@ namespace { // before each iteration (including the first one) variable 'cNew' contains unwritten symbol while (true) { size_t cNewLen; - Y_ASSERT((writePtr - newString.data()) + destSpace == newString.size()); + Y_ASSERT((writePtr - newString.data()) + destSpace == newString.size()); if (RECODE_EOOUTPUT == SafeWriteUTF8Char(cNew, cNewLen, (unsigned char*)writePtr, destSpace)) { - destSpace += newString.size(); - newString.resize(newString.size() * 2); - writePtr = newString.begin() + (newString.size() - destSpace); + destSpace += newString.size(); + newString.resize(newString.size() * 2); + writePtr = newString.begin() + (newString.size() - destSpace); continue; } destSpace -= cNewLen; writePtr += cNewLen; p += cLen; if (p == end) { - newString.resize(newString.size() - destSpace); + newString.resize(newString.size() - destSpace); return true; } wchar32 c = 0; @@ -135,14 +135,14 @@ bool ToLowerUTF8Impl(const char* beg, size_t n, TString& newString) { TString ToLowerUTF8(const TString& s) { TString newString; - bool changed = ToLowerUTF8Impl(s.data(), s.size(), newString); + bool changed = ToLowerUTF8Impl(s.data(), s.size(), newString); return changed ? newString : s; } TString ToLowerUTF8(TStringBuf s) { TString newString; - bool changed = ToLowerUTF8Impl(s.data(), s.size(), newString); - return changed ? newString : TString(s.data(), s.size()); + bool changed = ToLowerUTF8Impl(s.data(), s.size(), newString); + return changed ? newString : TString(s.data(), s.size()); } TString ToLowerUTF8(const char* s) { @@ -155,14 +155,14 @@ bool ToUpperUTF8Impl(const char* beg, size_t n, TString& newString) { TString ToUpperUTF8(const TString& s) { TString newString; - bool changed = ToUpperUTF8Impl(s.data(), s.size(), newString); + bool changed = ToUpperUTF8Impl(s.data(), s.size(), newString); return changed ? newString : s; } TString ToUpperUTF8(TStringBuf s) { TString newString; - bool changed = ToUpperUTF8Impl(s.data(), s.size(), newString); - return changed ? newString : TString(s.data(), s.size()); + bool changed = ToUpperUTF8Impl(s.data(), s.size(), newString); + return changed ? newString : TString(s.data(), s.size()); } TString ToUpperUTF8(const char* s) { diff --git a/util/charset/utf8.h b/util/charset/utf8.h index c4708be9be..5039b46ae9 100644 --- a/util/charset/utf8.h +++ b/util/charset/utf8.h @@ -133,7 +133,7 @@ inline bool GetNumberOfUTF8Chars(const char* text, size_t len, size_t& number) { inline size_t GetNumberOfUTF8Chars(TStringBuf text) { size_t number; - if (!GetNumberOfUTF8Chars(text.data(), text.size(), number)) { + if (!GetNumberOfUTF8Chars(text.data(), text.size(), number)) { ythrow yexception() << "GetNumberOfUTF8Chars failed on invalid utf-8 " << TString(text.substr(0, 50)).Quote(); } return number; @@ -356,7 +356,7 @@ enum EUTF8Detect { EUTF8Detect UTF8Detect(const char* s, size_t len); inline EUTF8Detect UTF8Detect(const TStringBuf input) { - return UTF8Detect(input.data(), input.size()); + return UTF8Detect(input.data(), input.size()); } inline bool IsUtf(const char* input, size_t len) { @@ -364,7 +364,7 @@ inline bool IsUtf(const char* input, size_t len) { } inline bool IsUtf(const TStringBuf input) { - return IsUtf(input.data(), input.size()); + return IsUtf(input.data(), input.size()); } //! returns true, if result is not the same as input, and put it in newString diff --git a/util/charset/utf8_ut.cpp b/util/charset/utf8_ut.cpp index 8f8e6996c5..9e68881cca 100644 --- a/util/charset/utf8_ut.cpp +++ b/util/charset/utf8_ut.cpp @@ -21,8 +21,8 @@ Y_UNIT_TEST_SUITE(TUtfUtilTest) { TString s = "привет!"; TString q = "ПРИВЕТ!"; TString tmp; - UNIT_ASSERT(ToLowerUTF8Impl(s.data(), s.size(), tmp) == false); - UNIT_ASSERT(ToLowerUTF8Impl(q.data(), q.size(), tmp) == true); + UNIT_ASSERT(ToLowerUTF8Impl(s.data(), s.size(), tmp) == false); + UNIT_ASSERT(ToLowerUTF8Impl(q.data(), q.size(), tmp) == true); } { @@ -61,8 +61,8 @@ Y_UNIT_TEST_SUITE(TUtfUtilTest) { TString s = "ПРИВЕТ!"; TString q = "привет!"; TString tmp; - UNIT_ASSERT(ToUpperUTF8Impl(s.data(), s.size(), tmp) == false); - UNIT_ASSERT(ToUpperUTF8Impl(q.data(), q.size(), tmp) == true); + UNIT_ASSERT(ToUpperUTF8Impl(s.data(), s.size(), tmp) == false); + UNIT_ASSERT(ToUpperUTF8Impl(q.data(), q.size(), tmp) == true); } { diff --git a/util/datetime/cputimer.cpp b/util/datetime/cputimer.cpp index b8434b419f..516d372c37 100644 --- a/util/datetime/cputimer.cpp +++ b/util/datetime/cputimer.cpp @@ -111,7 +111,7 @@ TTimeLogger::TTimeLogger(const TString& message, bool verbose) { if (Verbose) { fprintf(stderr, "=========================================================\n"); - fprintf(stderr, "%s started: %.24s (%lu) (%d)\n", Message.data(), ctime(&Begin), (unsigned long)Begin, (int)getpid()); + fprintf(stderr, "%s started: %.24s (%lu) (%d)\n", Message.data(), ctime(&Begin), (unsigned long)Begin, (int)getpid()); } } @@ -129,8 +129,8 @@ TTimeLogger::~TTimeLogger() { if (Verbose) { const char* prefix = (OK) ? "" : "!"; fprintf(stderr, "%s%s ended: %.24s (%lu) (%d) (took %lus = %s)\n", - prefix, Message.data(), ctime(&tim), (unsigned long)tim, (int)getpid(), - (unsigned long)tim - (unsigned long)Begin, FormatCycles(endCycles - BeginCycles).data()); + prefix, Message.data(), ctime(&tim), (unsigned long)tim, (int)getpid(), + (unsigned long)tim - (unsigned long)Begin, FormatCycles(endCycles - BeginCycles).data()); fprintf(stderr, "%s=========================================================\n", prefix); } } diff --git a/util/datetime/parser.rl6 b/util/datetime/parser.rl6 index cb6ec3bcfa..931f09eae1 100644 --- a/util/datetime/parser.rl6 +++ b/util/datetime/parser.rl6 @@ -461,30 +461,30 @@ static inline TResult ParseUnsafe(const char* input, size_t len) { } TInstant TInstant::ParseIso8601Deprecated(const TStringBuf input) { - return ParseUnsafe<TIso8601DateTimeParserDeprecated, TInstant>(input.data(), input.size()); + return ParseUnsafe<TIso8601DateTimeParserDeprecated, TInstant>(input.data(), input.size()); } TInstant TInstant::ParseRfc822Deprecated(const TStringBuf input) { - return ParseUnsafe<TRfc822DateTimeParserDeprecated, TInstant>(input.data(), input.size()); + return ParseUnsafe<TRfc822DateTimeParserDeprecated, TInstant>(input.data(), input.size()); } TInstant TInstant::ParseHttpDeprecated(const TStringBuf input) { - return ParseUnsafe<THttpDateTimeParserDeprecated, TInstant>(input.data(), input.size()); + return ParseUnsafe<THttpDateTimeParserDeprecated, TInstant>(input.data(), input.size()); } TInstant TInstant::ParseX509ValidityDeprecated(const TStringBuf input) { - switch (input.size()) { + switch (input.size()) { case 13: - return ParseUnsafe<TX509ValidityDateTimeParserDeprecated, TInstant>(input.data(), 13); + return ParseUnsafe<TX509ValidityDateTimeParserDeprecated, TInstant>(input.data(), 13); case 15: - return ParseUnsafe<TX509Validity4yDateTimeParserDeprecated, TInstant>(input.data(), 15); + return ParseUnsafe<TX509Validity4yDateTimeParserDeprecated, TInstant>(input.data(), 15); default: ythrow TDateTimeParseException(); } } bool TInstant::TryParseIso8601Deprecated(const TStringBuf input, TInstant& instant) { - const auto parsed = ParseUnsafe<TIso8601DateTimeParserDeprecated, TInstant, false>(input.data(), input.size()); + const auto parsed = ParseUnsafe<TIso8601DateTimeParserDeprecated, TInstant, false>(input.data(), input.size()); if (TInstant::Max() == parsed) { return false; } @@ -493,7 +493,7 @@ bool TInstant::TryParseIso8601Deprecated(const TStringBuf input, TInstant& insta } bool TInstant::TryParseRfc822Deprecated(const TStringBuf input, TInstant& instant) { - const auto parsed = ParseUnsafe<TRfc822DateTimeParserDeprecated, TInstant, false>(input.data(), input.size()); + const auto parsed = ParseUnsafe<TRfc822DateTimeParserDeprecated, TInstant, false>(input.data(), input.size()); if (TInstant::Max() == parsed) { return false; } @@ -502,7 +502,7 @@ bool TInstant::TryParseRfc822Deprecated(const TStringBuf input, TInstant& instan } bool TInstant::TryParseHttpDeprecated(const TStringBuf input, TInstant& instant) { - const auto parsed = ParseUnsafe<THttpDateTimeParserDeprecated, TInstant, false>(input.data(), input.size()); + const auto parsed = ParseUnsafe<THttpDateTimeParserDeprecated, TInstant, false>(input.data(), input.size()); if (TInstant::Max() == parsed) { return false; } @@ -512,12 +512,12 @@ bool TInstant::TryParseHttpDeprecated(const TStringBuf input, TInstant& instant) bool TInstant::TryParseX509Deprecated(const TStringBuf input, TInstant& instant) { TInstant parsed; - switch (input.size()) { + switch (input.size()) { case 13: - parsed = ParseUnsafe<TX509ValidityDateTimeParserDeprecated, TInstant, false>(input.data(), 13); + parsed = ParseUnsafe<TX509ValidityDateTimeParserDeprecated, TInstant, false>(input.data(), 13); break; case 15: - parsed = ParseUnsafe<TX509Validity4yDateTimeParserDeprecated, TInstant, false>(input.data(), 15); + parsed = ParseUnsafe<TX509Validity4yDateTimeParserDeprecated, TInstant, false>(input.data(), 15); break; default: return false; @@ -530,30 +530,30 @@ bool TInstant::TryParseX509Deprecated(const TStringBuf input, TInstant& instant) } TInstant TInstant::ParseIso8601(const TStringBuf input) { - return ParseUnsafe<TIso8601DateTimeParser, TInstant>(input.data(), input.size()); + return ParseUnsafe<TIso8601DateTimeParser, TInstant>(input.data(), input.size()); } TInstant TInstant::ParseRfc822(const TStringBuf input) { - return ParseUnsafe<TRfc822DateTimeParser, TInstant>(input.data(), input.size()); + return ParseUnsafe<TRfc822DateTimeParser, TInstant>(input.data(), input.size()); } TInstant TInstant::ParseHttp(const TStringBuf input) { - return ParseUnsafe<THttpDateTimeParser, TInstant>(input.data(), input.size()); + return ParseUnsafe<THttpDateTimeParser, TInstant>(input.data(), input.size()); } TInstant TInstant::ParseX509Validity(const TStringBuf input) { - switch (input.size()) { + switch (input.size()) { case 13: - return ParseUnsafe<TX509ValidityDateTimeParser, TInstant>(input.data(), 13); + return ParseUnsafe<TX509ValidityDateTimeParser, TInstant>(input.data(), 13); case 15: - return ParseUnsafe<TX509Validity4yDateTimeParser, TInstant>(input.data(), 15); + return ParseUnsafe<TX509Validity4yDateTimeParser, TInstant>(input.data(), 15); default: ythrow TDateTimeParseException(); } } bool TInstant::TryParseIso8601(const TStringBuf input, TInstant& instant) { - const auto parsed = ParseUnsafe<TIso8601DateTimeParser, TInstant, false>(input.data(), input.size()); + const auto parsed = ParseUnsafe<TIso8601DateTimeParser, TInstant, false>(input.data(), input.size()); if (TInstant::Max() == parsed) { return false; } @@ -562,7 +562,7 @@ bool TInstant::TryParseIso8601(const TStringBuf input, TInstant& instant) { } bool TInstant::TryParseRfc822(const TStringBuf input, TInstant& instant) { - const auto parsed = ParseUnsafe<TRfc822DateTimeParser, TInstant, false>(input.data(), input.size()); + const auto parsed = ParseUnsafe<TRfc822DateTimeParser, TInstant, false>(input.data(), input.size()); if (TInstant::Max() == parsed) { return false; } @@ -571,7 +571,7 @@ bool TInstant::TryParseRfc822(const TStringBuf input, TInstant& instant) { } bool TInstant::TryParseHttp(const TStringBuf input, TInstant& instant) { - const auto parsed = ParseUnsafe<THttpDateTimeParser, TInstant, false>(input.data(), input.size()); + const auto parsed = ParseUnsafe<THttpDateTimeParser, TInstant, false>(input.data(), input.size()); if (TInstant::Max() == parsed) { return false; } @@ -581,12 +581,12 @@ bool TInstant::TryParseHttp(const TStringBuf input, TInstant& instant) { bool TInstant::TryParseX509(const TStringBuf input, TInstant& instant) { TInstant parsed; - switch (input.size()) { + switch (input.size()) { case 13: - parsed = ParseUnsafe<TX509ValidityDateTimeParser, TInstant, false>(input.data(), 13); + parsed = ParseUnsafe<TX509ValidityDateTimeParser, TInstant, false>(input.data(), 13); break; case 15: - parsed = ParseUnsafe<TX509Validity4yDateTimeParser, TInstant, false>(input.data(), 15); + parsed = ParseUnsafe<TX509Validity4yDateTimeParser, TInstant, false>(input.data(), 15); break; default: return false; @@ -789,7 +789,7 @@ TDuration TDurationParser::GetResult(TDuration defaultValue) const { } bool TDuration::TryParse(const TStringBuf input, TDuration& result) { - TDuration r = ::Parse<TDurationParser, TDuration>(input.data(), input.size(), TDuration::Max()); + TDuration r = ::Parse<TDurationParser, TDuration>(input.data(), input.size(), TDuration::Max()); if (r == TDuration::Max()) return false; result = r; @@ -797,5 +797,5 @@ bool TDuration::TryParse(const TStringBuf input, TDuration& result) { } TDuration TDuration::Parse(const TStringBuf input) { - return ParseUnsafe<TDurationParser, TDuration>(input.data(), input.size()); + return ParseUnsafe<TDurationParser, TDuration>(input.data(), input.size()); } diff --git a/util/digest/fnv.h b/util/digest/fnv.h index 8773246ee0..87b41a3de7 100644 --- a/util/digest/fnv.h +++ b/util/digest/fnv.h @@ -69,5 +69,5 @@ static constexpr T FnvHash(const void* buf, size_t len) { template <class T, class Buf> static constexpr T FnvHash(const Buf& buf) { - return FnvHash<T>(buf.data(), buf.size() * sizeof(*buf.data())); + return FnvHash<T>(buf.data(), buf.size() * sizeof(*buf.data())); } diff --git a/util/draft/date.cpp b/util/draft/date.cpp index e06926bfc2..a290c46050 100644 --- a/util/draft/date.cpp +++ b/util/draft/date.cpp @@ -36,7 +36,7 @@ static time_t ParseDate(const char* dateStr) { template <> TDate FromStringImpl<TDate>(const char* data, size_t len) { - return TDate(ParseDate(TString(data, len).data())); + return TDate(ParseDate(TString(data, len).data())); } TDate::TDate(const char* yyyymmdd) @@ -55,7 +55,7 @@ TDate::TDate(time_t ts) } TDate::TDate(const TString& date, const TString& format) - : Timestamp(GetDateStart(ParseDate(date.data(), format.data()))) + : Timestamp(GetDateStart(ParseDate(date.data(), format.data()))) { } diff --git a/util/draft/datetime.h b/util/draft/datetime.h index 912d63fe1e..8a387ea6f1 100644 --- a/util/draft/datetime.h +++ b/util/draft/datetime.h @@ -145,7 +145,7 @@ inline TString date2str(const time_t date) { inline time_t str2date(const TString& dateStr) { struct tm dateTm; memset(&dateTm, 0, sizeof(tm)); - strptime(dateStr.data(), "%Y%m%d", &dateTm); + strptime(dateStr.data(), "%Y%m%d", &dateTm); return mktime(&dateTm); } diff --git a/util/draft/enum.h b/util/draft/enum.h index efea2c93a4..18002b7df2 100644 --- a/util/draft/enum.h +++ b/util/draft/enum.h @@ -5,7 +5,7 @@ #include <util/generic/strbuf.h> #include <util/stream/str.h> #include <util/string/cast.h> -#include <util/string/split.h> +#include <util/string/split.h> #include <utility> class TEnumNotFoundException: public yexception { @@ -98,7 +98,7 @@ inline void SetEnumFlags(const std::pair<const char*, E> (&str2Enum)[N], TString } else { flags.reset(); for (const auto& it : StringSplitter(optSpec).Split(',')) { - E e = *EnumFromStringImpl(ToString(it.Token()).data(), str2Enum, N); + E e = *EnumFromStringImpl(ToString(it.Token()).data(), str2Enum, N); flags.set(e); } } @@ -113,7 +113,7 @@ inline void SetEnumFlags(const std::pair<const char*, E>* str2Enum, TStringBuf o } else { flags.reset(); for (const auto& it : StringSplitter(optSpec).Split(',')) { - E e = *EnumFromStringImpl(ToString(it.Token()).data(), str2Enum, size); + E e = *EnumFromStringImpl(ToString(it.Token()).data(), str2Enum, size); flags.set(e); } } diff --git a/util/draft/holder_vector.h b/util/draft/holder_vector.h index 0ca1d044d8..1c62055bd9 100644 --- a/util/draft/holder_vector.h +++ b/util/draft/holder_vector.h @@ -5,7 +5,7 @@ #include <util/generic/noncopyable.h> template <class T, class D = TDelete> -class THolderVector: public TVector<T*>, public TNonCopyable { +class THolderVector: public TVector<T*>, public TNonCopyable { using TBase = TVector<T*>; public: diff --git a/util/draft/matrix.h b/util/draft/matrix.h index d4087c76df..154d00b35e 100644 --- a/util/draft/matrix.h +++ b/util/draft/matrix.h @@ -1,6 +1,6 @@ #pragma once -#include <util/generic/noncopyable.h> +#include <util/generic/noncopyable.h> #include <util/system/yassert.h> #include <util/system/defaults.h> #include <string.h> diff --git a/util/draft/memory.h b/util/draft/memory.h index 51edf683cf..0a9722bb36 100644 --- a/util/draft/memory.h +++ b/util/draft/memory.h @@ -8,7 +8,7 @@ template <class T> inline bool IsZero(const T* begin, const T* end) { - return std::find_if(begin, end, [](const T& other) { return other != T(0); }) == end; + return std::find_if(begin, end, [](const T& other) { return other != T(0); }) == end; } template <size_t Size> diff --git a/util/folder/dirut.cpp b/util/folder/dirut.cpp index 57bc56003f..ffc9b09f96 100644 --- a/util/folder/dirut.cpp +++ b/util/folder/dirut.cpp @@ -19,7 +19,7 @@ void SlashFolderLocal(TString& folder) { while ((pos = folder.find('/')) != TString::npos) folder.replace(pos, 1, LOCSLASH_S); #endif - if (folder[folder.size() - 1] != LOCSLASH_C) + if (folder[folder.size() - 1] != LOCSLASH_C) folder.append(LOCSLASH_S); } @@ -41,10 +41,10 @@ bool resolvepath(TString& folder, const TString& home) { if (folder.at(0) == '~') { if (folder.length() == 1 || folder.at(1) == '/') { - folder = GetHomeDir() + (folder.data() + 1); + folder = GetHomeDir() + (folder.data() + 1); } else { char* buf = (char*)alloca(folder.length() + 1); - strcpy(buf, folder.data() + 1); + strcpy(buf, folder.data() + 1); char* p = strchr(buf, '/'); if (p) *p++ = 0; @@ -62,10 +62,10 @@ bool resolvepath(TString& folder, const TString& home) { int len = folder.length() + home.length() + 1; char* path = (char*)alloca(len); if (folder.at(0) != '/') { - strcpy(path, home.data()); - strcpy(strrchr(path, '/') + 1, folder.data()); // the last char must be '/' if it's a dir + strcpy(path, home.data()); + strcpy(strrchr(path, '/') + 1, folder.data()); // the last char must be '/' if it's a dir } else { - strcpy(path, folder.data()); + strcpy(path, folder.data()); } len = strlen(path) + 1; // grabbed from url.cpp @@ -349,8 +349,8 @@ int resolvepath(char* apath, const char* rpath, const char* cpath) { } bool correctpath(TString& filename) { - char* ptr = (char*)alloca(filename.size() + 2); - if (correctpath(ptr, filename.data())) { + char* ptr = (char*)alloca(filename.size() + 2); + if (correctpath(ptr, filename.data())) { filename = ptr; return true; } @@ -358,8 +358,8 @@ bool correctpath(TString& filename) { } bool resolvepath(TString& folder, const TString& home) { - char* ptr = (char*)alloca(folder.size() + 3 + home.size()); - if (resolvepath(ptr, folder.data(), home.data())) { + char* ptr = (char*)alloca(folder.size() + 3 + home.size()); + if (resolvepath(ptr, folder.data(), home.data())) { folder = ptr; return true; } @@ -406,9 +406,9 @@ TString RealPath(const TString& path) { TTempBuf result; Y_ASSERT(result.Size() > MAX_PATH); //TMP_BUF_LEN > MAX_PATH #ifdef _win_ - if (GetFullPathName(path.data(), result.Size(), result.Data(), nullptr) == 0) + if (GetFullPathName(path.data(), result.Size(), result.Data(), nullptr) == 0) #else - if (realpath(path.data(), result.Data()) == nullptr) + if (realpath(path.data(), result.Data()) == nullptr) #endif ythrow TFileError() << "RealPath failed \"" << path << "\""; return result.Data(); @@ -419,7 +419,7 @@ TString RealLocation(const TString& path) { return RealPath(path); TString dirpath = GetDirName(path); if (NFs::Exists(dirpath)) - return RealPath(dirpath) + GetDirectorySeparatorS() + GetFileNameComponent(path.data()); + return RealPath(dirpath) + GetDirectorySeparatorS() + GetFileNameComponent(path.data()); ythrow TFileError() << "RealLocation failed \"" << path << "\""; } @@ -434,7 +434,7 @@ int MakeTempDir(char path[/*FILENAME_MAX*/], const char* prefix) { if (!prefix) { #endif sysTmp = GetSystemTempDir(); - prefix = sysTmp.data(); + prefix = sysTmp.data(); } if ((ret = ResolvePath(prefix, nullptr, path, 1)) != 0) @@ -460,7 +460,7 @@ TString GetHomeDir() { passwd* pw = nullptr; s = getenv("USER"); if (s) - pw = getpwnam(s.data()); + pw = getpwnam(s.data()); else pw = getpwuid(getuid()); if (pw) @@ -580,13 +580,13 @@ int ResolvePath(const char* rel, const char* abs, char res[/*MAXPATHLEN*/], bool t[len] = 0; } if (!realpath(t, res)) { - if (!isdir && realpath(GetDirName(t).data(), res)) { + if (!isdir && realpath(GetDirName(t).data(), res)) { len = strlen(res); if (res[len - 1] != LOCSLASH_C) { res[len++] = LOCSLASH_C; res[len] = 0; } - strcpy(res + len, GetBaseName(t).data()); + strcpy(res + len, GetBaseName(t).data()); return 0; } return errno ? errno : ENOENT; diff --git a/util/folder/dirut.h b/util/folder/dirut.h index c707838d81..2537027b12 100644 --- a/util/folder/dirut.h +++ b/util/folder/dirut.h @@ -46,7 +46,7 @@ TString GetHomeDir(); void MakeDirIfNotExist(const char* path, int mode = 0777); inline void MakeDirIfNotExist(const TString& path, int mode = 0777) { - MakeDirIfNotExist(path.data(), mode); + MakeDirIfNotExist(path.data(), mode); } /// Create path making parent directories as needed @@ -64,7 +64,7 @@ void RemoveDirWithContents(TString dirName); const char* GetFileNameComponent(const char* f); inline TString GetFileNameComponent(const TString& f) { - return GetFileNameComponent(f.data()); + return GetFileNameComponent(f.data()); } /// RealPath doesn't guarantee trailing separator to be stripped or left in place for directories. diff --git a/util/folder/filelist.cpp b/util/folder/filelist.cpp index 9e33b567e7..b21fcdbf20 100644 --- a/util/folder/filelist.cpp +++ b/util/folder/filelist.cpp @@ -32,7 +32,7 @@ void TFileEntitiesList::Fill(const TString& dirname, TStringBuf prefix, TStringB if (((Mask & EM_FILES) && file->fts_info == FTS_F) || ((Mask & EM_DIRS) && file->fts_info == FTS_D) || ((Mask & EM_SLINKS) && file->fts_info == FTS_SL)) { ++FileNamesSize; - FileNames.Append(filename.data(), filename.size() + 1); + FileNames.Append(filename.data(), filename.size() + 1); } } diff --git a/util/folder/filelist_ut.cpp b/util/folder/filelist_ut.cpp index f06a5ba332..0cdcdf3d00 100644 --- a/util/folder/filelist_ut.cpp +++ b/util/folder/filelist_ut.cpp @@ -20,11 +20,11 @@ public: void TFileListTest::TestSimple() { TTempDir tempDir("nonexistingdir"); - MakeDirIfNotExist((tempDir() + LOCSLASH_S "subdir").data()); - TFile((tempDir() + LOCSLASH_S "subdir" LOCSLASH_S "file").data(), CreateAlways); + MakeDirIfNotExist((tempDir() + LOCSLASH_S "subdir").data()); + TFile((tempDir() + LOCSLASH_S "subdir" LOCSLASH_S "file").data(), CreateAlways); TFileList fileList; - fileList.Fill(tempDir().data(), "", "", 1000); + fileList.Fill(tempDir().data(), "", "", 1000); TString fileName(fileList.Next()); UNIT_ASSERT_EQUAL(fileName, "subdir" LOCSLASH_S "file"); UNIT_ASSERT_EQUAL(fileList.Next(), nullptr); @@ -32,21 +32,21 @@ void TFileListTest::TestSimple() { void TFileListTest::TestPrefix() { TTempDir tempDir("nonexistingdir"); - TFile((tempDir() + LOCSLASH_S "good_file1").data(), CreateAlways); - TFile((tempDir() + LOCSLASH_S "good_file2").data(), CreateAlways); - TFile((tempDir() + LOCSLASH_S "bad_file1").data(), CreateAlways); - TFile((tempDir() + LOCSLASH_S "bad_file2").data(), CreateAlways); + TFile((tempDir() + LOCSLASH_S "good_file1").data(), CreateAlways); + TFile((tempDir() + LOCSLASH_S "good_file2").data(), CreateAlways); + TFile((tempDir() + LOCSLASH_S "bad_file1").data(), CreateAlways); + TFile((tempDir() + LOCSLASH_S "bad_file2").data(), CreateAlways); const bool SORT = true; TFileList fileList; { - fileList.Fill(tempDir().data(), "good_file", SORT); + fileList.Fill(tempDir().data(), "good_file", SORT); UNIT_ASSERT_EQUAL(TString(fileList.Next()), "good_file1"); UNIT_ASSERT_EQUAL(TString(fileList.Next()), "good_file2"); UNIT_ASSERT_EQUAL(fileList.Next(), nullptr); } { - fileList.Fill(tempDir().data(), "bad_file", SORT); + fileList.Fill(tempDir().data(), "bad_file", SORT); UNIT_ASSERT_EQUAL(TString(fileList.Next()), "bad_file1"); UNIT_ASSERT_EQUAL(TString(fileList.Next()), "bad_file2"); UNIT_ASSERT_EQUAL(fileList.Next(), nullptr); diff --git a/util/folder/fts_ut.cpp b/util/folder/fts_ut.cpp index 02622aff4e..c5d59e35f4 100644 --- a/util/folder/fts_ut.cpp +++ b/util/folder/fts_ut.cpp @@ -58,27 +58,27 @@ void TFtsTest::TestSimple() { TFileTree currentDirTree((char* const*)dotPath, 0, FtsCmp); UNIT_ASSERT(currentDirTree()); TTempDir tempDir = MakeTempName(yfts_read(currentDirTree())->fts_path); - MakeDirIfNotExist(tempDir().data()); - MakeDirIfNotExist((tempDir() + LOCSLASH_S "dir1").data()); - MakeFile((tempDir() + LOCSLASH_S "dir1" LOCSLASH_S "file1").data()); - MakeFile((tempDir() + LOCSLASH_S "dir1" LOCSLASH_S "file2").data()); - MakeDirIfNotExist((tempDir() + LOCSLASH_S "dir2").data()); - MakeFile((tempDir() + LOCSLASH_S "dir2" LOCSLASH_S "file3").data()); - MakeFile((tempDir() + LOCSLASH_S "dir2" LOCSLASH_S "file4").data()); - - const char* path[2] = {tempDir().data(), nullptr}; + MakeDirIfNotExist(tempDir().data()); + MakeDirIfNotExist((tempDir() + LOCSLASH_S "dir1").data()); + MakeFile((tempDir() + LOCSLASH_S "dir1" LOCSLASH_S "file1").data()); + MakeFile((tempDir() + LOCSLASH_S "dir1" LOCSLASH_S "file2").data()); + MakeDirIfNotExist((tempDir() + LOCSLASH_S "dir2").data()); + MakeFile((tempDir() + LOCSLASH_S "dir2" LOCSLASH_S "file3").data()); + MakeFile((tempDir() + LOCSLASH_S "dir2" LOCSLASH_S "file4").data()); + + const char* path[2] = {tempDir().data(), nullptr}; TFileTree fileTree((char* const*)path, 0, FtsCmp); UNIT_ASSERT(fileTree()); - CheckEnt(yfts_read(fileTree()), tempDir().data(), FTS_D); - CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir1").data(), FTS_D); - CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir1" LOCSLASH_S "file1").data(), FTS_F); - CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir1" LOCSLASH_S "file2").data(), FTS_F); - CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir1").data(), FTS_DP); - CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir2").data(), FTS_D); - CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir2" LOCSLASH_S "file3").data(), FTS_F); - CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir2" LOCSLASH_S "file4").data(), FTS_F); - CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir2").data(), FTS_DP); - CheckEnt(yfts_read(fileTree()), (tempDir()).data(), FTS_DP); + CheckEnt(yfts_read(fileTree()), tempDir().data(), FTS_D); + CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir1").data(), FTS_D); + CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir1" LOCSLASH_S "file1").data(), FTS_F); + CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir1" LOCSLASH_S "file2").data(), FTS_F); + CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir1").data(), FTS_DP); + CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir2").data(), FTS_D); + CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir2" LOCSLASH_S "file3").data(), FTS_F); + CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir2" LOCSLASH_S "file4").data(), FTS_F); + CheckEnt(yfts_read(fileTree()), (tempDir() + LOCSLASH_S "dir2").data(), FTS_DP); + CheckEnt(yfts_read(fileTree()), (tempDir()).data(), FTS_DP); UNIT_ASSERT_EQUAL(yfts_read(fileTree()), nullptr); } diff --git a/util/folder/iterator_ut.cpp b/util/folder/iterator_ut.cpp index c6c756b999..936becd139 100644 --- a/util/folder/iterator_ut.cpp +++ b/util/folder/iterator_ut.cpp @@ -56,7 +56,7 @@ private: break; case 1: - MakeDirIfNotExist(path.Path.data()); + MakeDirIfNotExist(path.Path.data()); break; case 2: diff --git a/util/folder/path.cpp b/util/folder/path.cpp index 0d5400fd14..bfe0c67d68 100644 --- a/util/folder/path.cpp +++ b/util/folder/path.cpp @@ -93,11 +93,11 @@ TFsPath TFsPath::RelativePath(const TFsPath& root) const { for (size_t i = 0; i < rsplit.size() - cnt; i++) { r += i == 0 ? ".." : "/.."; } - for (size_t i = cnt; i < split.size(); i++) { - r += (i == 0 || i == cnt && rsplit.size() - cnt == 0 ? "" : "/"); + for (size_t i = cnt; i < split.size(); i++) { + r += (i == 0 || i == cnt && rsplit.size() - cnt == 0 ? "" : "/"); r += split[i]; } - return r.size() ? TFsPath(r) : TFsPath(); + return r.size() ? TFsPath(r) : TFsPath(); } TFsPath TFsPath::Parent() const { @@ -230,7 +230,7 @@ struct TClosedir { void TFsPath::ListNames(TVector<TString>& children) const { CheckDefined(); - THolder<DIR, TClosedir> dir(opendir(this->c_str())); + THolder<DIR, TClosedir> dir(opendir(this->c_str())); if (!dir) { ythrow TIoSystemError() << "failed to opendir " << Path_; } @@ -340,15 +340,15 @@ void TFsPath::CheckExists() const { } bool TFsPath::IsDirectory() const { - return IsDefined() && TFileStat(GetPath().data()).IsDir(); + return IsDefined() && TFileStat(GetPath().data()).IsDir(); } bool TFsPath::IsFile() const { - return IsDefined() && TFileStat(GetPath().data()).IsFile(); + return IsDefined() && TFileStat(GetPath().data()).IsFile(); } bool TFsPath::IsSymlink() const { - return IsDefined() && TFileStat(GetPath().data(), true).IsSymlink(); + return IsDefined() && TFileStat(GetPath().data(), true).IsSymlink(); } void TFsPath::DeleteIfExists() const { @@ -356,8 +356,8 @@ void TFsPath::DeleteIfExists() const { return; } - ::unlink(this->c_str()); - ::rmdir(this->c_str()); + ::unlink(this->c_str()); + ::rmdir(this->c_str()); if (Exists()) { ythrow TIoException() << "failed to delete " << Path_; } @@ -366,7 +366,7 @@ void TFsPath::DeleteIfExists() const { void TFsPath::MkDir(const int mode) const { CheckDefined(); if (!Exists()) { - int r = Mkdir(this->c_str(), mode); + int r = Mkdir(this->c_str(), mode); if (r != 0) { // TODO (stanly) will still fail on Windows because // LastSystemError() returns windows specific ERROR_ALREADY_EXISTS diff --git a/util/folder/path.h b/util/folder/path.h index f90f0b70e9..2fb4d6b4ef 100644 --- a/util/folder/path.h +++ b/util/folder/path.h @@ -44,8 +44,8 @@ public: return IsDefined(); } - inline const char* c_str() const { - return Path_.c_str(); + inline const char* c_str() const { + return Path_.c_str(); } inline operator const TString&() const { @@ -166,7 +166,7 @@ public: // XXX: ino inline bool Stat(TFileStat& stat) const { - stat = TFileStat(Path_.data()); + stat = TFileStat(Path_.data()); return stat.Mode; } diff --git a/util/folder/pathsplit.cpp b/util/folder/pathsplit.cpp index e24ca90203..81d439a727 100644 --- a/util/folder/pathsplit.cpp +++ b/util/folder/pathsplit.cpp @@ -31,7 +31,7 @@ void TPathSplitTraitsUnix::DoParseFirstPart(const TStringBuf part) { } void TPathSplitTraitsUnix::DoParsePart(const TStringBuf part0) { - DoAppendHint(part0.size() / 8); + DoAppendHint(part0.size() / 8); TStringBuf next(part0); TStringBuf part; @@ -55,7 +55,7 @@ void TPathSplitTraitsWindows::DoParseFirstPart(const TStringBuf part0) { if (IsAbsolutePath(part)) { IsAbsolute = true; - if (part.size() > 1 && part[1] == ':') { + if (part.size() > 1 && part[1] == ':') { Drive = part.SubStr(0, 2); part = part.SubStr(2); } @@ -65,23 +65,23 @@ void TPathSplitTraitsWindows::DoParseFirstPart(const TStringBuf part0) { } void TPathSplitTraitsWindows::DoParsePart(const TStringBuf part0) { - DoAppendHint(part0.size() / 8); + DoAppendHint(part0.size() / 8); size_t pos = 0; TStringBuf part(part0); - while (pos < part.size()) { - while (pos < part.size() && this->IsPathSep(part[pos])) { + while (pos < part.size()) { + while (pos < part.size() && this->IsPathSep(part[pos])) { ++pos; } - const char* begin = part.data() + pos; + const char* begin = part.data() + pos; - while (pos < part.size() && !this->IsPathSep(part[pos])) { + while (pos < part.size() && !this->IsPathSep(part[pos])) { ++pos; } - AppendComponent(TStringBuf(begin, part.data() + pos)); + AppendComponent(TStringBuf(begin, part.data() + pos)); } } @@ -135,14 +135,14 @@ TString JoinPaths(const TPathSplit& p1, const TPathSplit& p2) { } TStringBuf CutExtension(const TStringBuf fileName) { - if (fileName.empty()) { + if (fileName.empty()) { return fileName; } TStringBuf name; TStringBuf extension; fileName.RSplit('.', name, extension); - if (name.empty()) { + if (name.empty()) { // dot at a start or not found return name; } else { diff --git a/util/folder/pathsplit.h b/util/folder/pathsplit.h index 94eacb49a7..d134338e35 100644 --- a/util/folder/pathsplit.h +++ b/util/folder/pathsplit.h @@ -52,7 +52,7 @@ struct TPathSplitTraitsWindows: public TPathSplitStore { } static inline bool IsAbsolutePath(const TStringBuf path) noexcept { - return path && (IsPathSep(path[0]) || (path.size() > 1 && path[1] == ':' && IsAsciiAlpha(path[0]) && (path.size() == 2 || IsPathSep(path[2])))); + return path && (IsPathSep(path[0]) || (path.size() > 1 && path[1] == ':' && IsAsciiAlpha(path[0]) && (path.size() == 2 || IsPathSep(path[2])))); } void DoParseFirstPart(const TStringBuf part); diff --git a/util/folder/tempdir.cpp b/util/folder/tempdir.cpp index f66d41bf5f..6fdf8f753c 100644 --- a/util/folder/tempdir.cpp +++ b/util/folder/tempdir.cpp @@ -26,7 +26,7 @@ TTempDir::TTempDir(const TString& tempDir) , Remove(true) { NFs::Remove(TempDir); - MakeDirIfNotExist(TempDir.c_str()); + MakeDirIfNotExist(TempDir.c_str()); } TTempDir TTempDir::NewTempDir(const TString& root) { diff --git a/util/generic/algorithm.h b/util/generic/algorithm.h index 0b24a74a92..badfb88993 100644 --- a/util/generic/algorithm.h +++ b/util/generic/algorithm.h @@ -347,17 +347,17 @@ void EraseIf(C& c, P p) { c.erase(std::remove_if(c.begin(), c.end(), p), c.end()); } -template <class C, class P> -void EraseNodesIf(C& c, P p) { - for (auto iter = c.begin(), last = c.end(); iter != last;) { - if (p(*iter)) { - c.erase(iter++); - } else { - ++iter; - } - } -} - +template <class C, class P> +void EraseNodesIf(C& c, P p) { + for (auto iter = c.begin(), last = c.end(); iter != last;) { + if (p(*iter)) { + c.erase(iter++); + } else { + ++iter; + } + } +} + template <class T1, class T2> static inline bool Equal(T1 f1, T1 l1, T2 f2) { return std::equal(f1, l1, f2); diff --git a/util/generic/algorithm_ut.cpp b/util/generic/algorithm_ut.cpp index 0925eb354d..8d732fcc0c 100644 --- a/util/generic/algorithm_ut.cpp +++ b/util/generic/algorithm_ut.cpp @@ -281,37 +281,37 @@ Y_UNIT_TEST_SUITE(TAlgorithm) { } Y_UNIT_TEST(EraseNodesIfTest) { - TMap<int, int> map{{1, 1}, {2, 2}, {3, 5}}; - TMap<int, int> expectedMap{{1, 1}}; - EraseNodesIf(map, [](auto p) { return p.first >= 2; }); - UNIT_ASSERT_EQUAL(map, expectedMap); - - TMultiMap<int, int> multiMap{{1, 1}, {1, 3}, {2, 2}, {3, 5}}; - TMultiMap<int, int> expectedMultiMap{{1, 1}, {1, 3}}; - EraseNodesIf(multiMap, [](auto p) { return p.first >= 2; }); - UNIT_ASSERT_EQUAL(multiMap, expectedMultiMap); - - TSet<int> set{1, 2, 3, 4, 5, 6, 7}; - TSet<int> expectedSet{1, 3, 5, 7}; - EraseNodesIf(set, [](int i) { return i % 2 == 0; }); - UNIT_ASSERT_EQUAL(set, expectedSet); - - TMultiSet<int> multiSet{1, 1, 2, 3, 4, 4, 4, 5, 5, 5, 6, 7}; - TMultiSet<int> expectedMultiSet{1, 1, 3, 5, 5, 5, 7}; - EraseNodesIf(multiSet, [](int i) { return i % 2 == 0; }); - UNIT_ASSERT_EQUAL(multiSet, expectedMultiSet); - - THashMap<int, int> hashMap{{1, 0}, {3, 0}, {4, 0}, {10, 0}, {2, 0}, {5, 2}}; - THashMap<int, int> expectedHashMap{{1, 0}, {3, 0}, {5, 2}}; - EraseNodesIf(hashMap, [](auto p) { return p.first % 2 == 0; }); - UNIT_ASSERT_EQUAL(hashMap, expectedHashMap); - - THashMultiMap<int, int> hashMultiMap{{1, 0}, {3, 0}, {4, 0}, {10, 0}, {2, 0}, {5, 0}, {1, 0}, {1, 0}, {2, 0}, {2, 2}}; - THashMultiMap<int, int> expectedHashMultiMap{{1, 0}, {1, 0}, {1, 0}, {3, 0}, {5, 0}}; - EraseNodesIf(hashMultiMap, [](auto p) { return p.first % 2 == 0; }); - UNIT_ASSERT_EQUAL(hashMultiMap, expectedHashMultiMap); - } - + TMap<int, int> map{{1, 1}, {2, 2}, {3, 5}}; + TMap<int, int> expectedMap{{1, 1}}; + EraseNodesIf(map, [](auto p) { return p.first >= 2; }); + UNIT_ASSERT_EQUAL(map, expectedMap); + + TMultiMap<int, int> multiMap{{1, 1}, {1, 3}, {2, 2}, {3, 5}}; + TMultiMap<int, int> expectedMultiMap{{1, 1}, {1, 3}}; + EraseNodesIf(multiMap, [](auto p) { return p.first >= 2; }); + UNIT_ASSERT_EQUAL(multiMap, expectedMultiMap); + + TSet<int> set{1, 2, 3, 4, 5, 6, 7}; + TSet<int> expectedSet{1, 3, 5, 7}; + EraseNodesIf(set, [](int i) { return i % 2 == 0; }); + UNIT_ASSERT_EQUAL(set, expectedSet); + + TMultiSet<int> multiSet{1, 1, 2, 3, 4, 4, 4, 5, 5, 5, 6, 7}; + TMultiSet<int> expectedMultiSet{1, 1, 3, 5, 5, 5, 7}; + EraseNodesIf(multiSet, [](int i) { return i % 2 == 0; }); + UNIT_ASSERT_EQUAL(multiSet, expectedMultiSet); + + THashMap<int, int> hashMap{{1, 0}, {3, 0}, {4, 0}, {10, 0}, {2, 0}, {5, 2}}; + THashMap<int, int> expectedHashMap{{1, 0}, {3, 0}, {5, 2}}; + EraseNodesIf(hashMap, [](auto p) { return p.first % 2 == 0; }); + UNIT_ASSERT_EQUAL(hashMap, expectedHashMap); + + THashMultiMap<int, int> hashMultiMap{{1, 0}, {3, 0}, {4, 0}, {10, 0}, {2, 0}, {5, 0}, {1, 0}, {1, 0}, {2, 0}, {2, 2}}; + THashMultiMap<int, int> expectedHashMultiMap{{1, 0}, {1, 0}, {1, 0}, {3, 0}, {5, 0}}; + EraseNodesIf(hashMultiMap, [](auto p) { return p.first % 2 == 0; }); + UNIT_ASSERT_EQUAL(hashMultiMap, expectedHashMultiMap); + } + Y_UNIT_TEST(NthElementTest) { { TVector<TString> v; @@ -551,7 +551,7 @@ Y_UNIT_TEST_SUITE(TAlgorithm) { TVector<int>::iterator iter = CopyN(data, toCopy, result.begin()); UNIT_ASSERT_VALUES_EQUAL(iter - result.begin(), toCopy); - UNIT_ASSERT_VALUES_EQUAL(result.size(), 10); + UNIT_ASSERT_VALUES_EQUAL(result.size(), 10); for (size_t idx = 0; idx < toCopy; ++idx) { UNIT_ASSERT_VALUES_EQUAL(data[idx], result[idx]); } @@ -582,7 +582,7 @@ Y_UNIT_TEST_SUITE(TAlgorithm) { TVector<int> v(vSize, 0); TVector<int>::iterator iter = CopyIf(data, data + count, v.begin(), [](int x) { return !(x % 3); }); - UNIT_ASSERT_VALUES_EQUAL(v.size(), vSize); + UNIT_ASSERT_VALUES_EQUAL(v.size(), vSize); UNIT_ASSERT_VALUES_EQUAL(iter - v.begin(), 3); v.resize(iter - v.begin()); for (size_t idx = 0; idx < v.size(); ++idx) { diff --git a/util/generic/bitops.h b/util/generic/bitops.h index add0b75a17..2db15fc59b 100644 --- a/util/generic/bitops.h +++ b/util/generic/bitops.h @@ -424,31 +424,31 @@ constexpr T RotateBitsRightCT(T value, const ui8 shift) noexcept { // do trick with mask to avoid undefined behaviour return (value >> shift) | (value << ((-shift) & (sizeof(T) * 8 - 1))); } - -/* Remain `size` bits to current `offset` of `value` - size, offset are less than number of bits in size_type - */ + +/* Remain `size` bits to current `offset` of `value` + size, offset are less than number of bits in size_type + */ template <size_t Offset, size_t Size, class T> -Y_FORCE_INLINE T SelectBits(T value) { +Y_FORCE_INLINE T SelectBits(T value) { static_assert(Size < sizeof(T) * 8, "violated: Size < sizeof(T) * 8"); static_assert(Offset < sizeof(T) * 8, "violated: Offset < sizeof(T) * 8"); - T id = 1; - return (value >> Offset) & ((id << Size) - id); -} - -/* Set `size` bits of `bits` to current offset of `value`. Requires that bits <= (1 << size) - 1 - size, offset are less than number of bits in size_type - */ + T id = 1; + return (value >> Offset) & ((id << Size) - id); +} + +/* Set `size` bits of `bits` to current offset of `value`. Requires that bits <= (1 << size) - 1 + size, offset are less than number of bits in size_type + */ template <size_t Offset, size_t Size, class T> -void SetBits(T& value, T bits) { +void SetBits(T& value, T bits) { static_assert(Size < sizeof(T) * 8, "violated: Size < sizeof(T) * 8"); static_assert(Offset < sizeof(T) * 8, "violated: Offset < sizeof(T) * 8"); - T id = 1; - T maxValue = ((id << Size) - id); - Y_ASSERT(bits <= maxValue); - value &= ~(maxValue << Offset); - value |= bits << Offset; -} + T id = 1; + T maxValue = ((id << Size) - id); + Y_ASSERT(bits <= maxValue); + value &= ~(maxValue << Offset); + value |= bits << Offset; +} inline constexpr ui64 NthBit64(int bit) { return ui64(1) << bit; diff --git a/util/generic/bitops_ut.cpp b/util/generic/bitops_ut.cpp index 0f7872b8b0..d23c2b5c27 100644 --- a/util/generic/bitops_ut.cpp +++ b/util/generic/bitops_ut.cpp @@ -293,29 +293,29 @@ Y_UNIT_TEST_SUITE(TBitOpsTest) { UNIT_ASSERT_VALUES_EQUAL(RotateBitsRight<ui64>(0b1010000000000000000000000000000000000000000000000000000000000000u, 1), 0b0101000000000000000000000000000000000000000000000000000000000000u); UNIT_ASSERT_VALUES_EQUAL(RotateBitsRight<ui64>(0b0000000000000000000000000000000000000000000000000000000000000001u, 63), 0b0000000000000000000000000000000000000000000000000000000000000010u); } - + Y_UNIT_TEST(TestSelectBits) { ui8 firstui8Test = SelectBits<3, 4, ui8>(0b11111111u); ui8 secondui8Test = SelectBits<2, 5, ui8>(0b11101101u); UNIT_ASSERT_VALUES_EQUAL(firstui8Test, 0b00001111u); UNIT_ASSERT_VALUES_EQUAL(secondui8Test, 0b00011011u); - + ui16 firstui16Test = SelectBits<9, 2, ui16>(0b1111111111111111u); ui16 secondui16Test = SelectBits<3, 6, ui16>(0b1010011111010001u); UNIT_ASSERT_VALUES_EQUAL(firstui16Test, 0b0000000000000011u); UNIT_ASSERT_VALUES_EQUAL(secondui16Test, 0b0000000000111010u); - + ui32 firstui32Test = SelectBits<23, 31, ui32>(0b11111111111111111111111111111111u); ui32 secondui32Test = SelectBits<0, 31, ui32>(0b10001011101010011111010000111111u); UNIT_ASSERT_VALUES_EQUAL(firstui32Test, 0b00000000000000000000000111111111u); UNIT_ASSERT_VALUES_EQUAL(secondui32Test, 0b00001011101010011111010000111111); - + ui64 firstui64Test = SelectBits<1, 62, ui64>(0b1111000000000000000000000000000000000000000000000000000000000000u); ui64 secondui64Test = SelectBits<32, 43, ui64>(0b1111111111111111111111111111111111111111111111111111111111111111u); UNIT_ASSERT_VALUES_EQUAL(firstui64Test, 0b0011100000000000000000000000000000000000000000000000000000000000u); UNIT_ASSERT_VALUES_EQUAL(secondui64Test, 0b0000000000000000000000000000000011111111111111111111111111111111u); } - + Y_UNIT_TEST(TestSetBits) { ui8 firstui8Test = 0b11111111u; SetBits<3, 4, ui8>(firstui8Test, 0b00001111u); @@ -323,21 +323,21 @@ Y_UNIT_TEST_SUITE(TBitOpsTest) { SetBits<2, 7, ui8>(secondui8Test, 0b01110111u); UNIT_ASSERT_VALUES_EQUAL(firstui8Test, 0b11111111u); UNIT_ASSERT_VALUES_EQUAL(secondui8Test, 0b11011101u); - + ui16 firstui16Test = 0b1111111111111111u; SetBits<9, 4, ui16>(firstui16Test, 0b000000000000111u); ui16 secondui16Test = 0b1010011111010001u; SetBits<3, 15, ui16>(secondui16Test, 0b0010011111010001u); UNIT_ASSERT_VALUES_EQUAL(firstui16Test, 0b1110111111111111u); UNIT_ASSERT_VALUES_EQUAL(secondui16Test, 0b0011111010001001u); - + ui32 firstui32Test = 0b11111111111111111111111111111111u; SetBits<23, 31, ui32>(firstui32Test, 0b01100001111111111001111101111111u); ui32 secondui32Test = 0b10001011101010011111010000111111u; SetBits<0, 31, ui32>(secondui32Test, 0b01111111111111111111111111111111u); UNIT_ASSERT_VALUES_EQUAL(firstui32Test, 0b10111111111111111111111111111111u); UNIT_ASSERT_VALUES_EQUAL(secondui32Test, 0b11111111111111111111111111111111u); - + ui64 firstui64Test = 0b1111000000000000000000000000000000000000000000000000000000000000u; SetBits<1, 62, ui64>(firstui64Test, 0b0001000000000000000000000000000000000000000000000000000001010101u); ui64 secondui64Test = 0b1111111111111111111111111111111111111111111111111111111111111111u; diff --git a/util/generic/buffer.h b/util/generic/buffer.h index 38355d5258..9576467404 100644 --- a/util/generic/buffer.h +++ b/util/generic/buffer.h @@ -181,18 +181,18 @@ public: } } - inline char* data() noexcept { - return Data(); - } - - inline const char* data() const noexcept { - return Data(); - } - - inline size_t size() const noexcept { - return Size(); - } - + inline char* data() noexcept { + return Data(); + } + + inline const char* data() const noexcept { + return Data(); + } + + inline size_t size() const noexcept { + return Size(); + } + inline void Swap(TBuffer& r) noexcept { DoSwap(Data_, r.Data_); DoSwap(Len_, r.Len_); diff --git a/util/generic/buffer_ut.cpp b/util/generic/buffer_ut.cpp index df500cf1eb..437d7122ec 100644 --- a/util/generic/buffer_ut.cpp +++ b/util/generic/buffer_ut.cpp @@ -14,7 +14,7 @@ Y_UNIT_TEST_SUITE(TBufferTest) { buf.Resize(6); buf.EraseBack(2); - UNIT_ASSERT_EQUAL(TString(buf.data(), buf.size()), "1234"); + UNIT_ASSERT_EQUAL(TString(buf.data(), buf.size()), "1234"); } Y_UNIT_TEST(TestAppend) { @@ -32,7 +32,7 @@ Y_UNIT_TEST_SUITE(TBufferTest) { } } - UNIT_ASSERT_EQUAL(TString(buf.data(), buf.size()), str); + UNIT_ASSERT_EQUAL(TString(buf.data(), buf.size()), str); } Y_UNIT_TEST(TestReset) { @@ -55,17 +55,17 @@ Y_UNIT_TEST_SUITE(TBufferTest) { TBuffer buf; buf.Resize(10); - UNIT_ASSERT_VALUES_EQUAL(buf.size(), 10u); + UNIT_ASSERT_VALUES_EQUAL(buf.size(), 10u); buf.Resize(0); - UNIT_ASSERT_VALUES_EQUAL(buf.size(), 0u); + UNIT_ASSERT_VALUES_EQUAL(buf.size(), 0u); buf.Resize(9); - memcpy(buf.data(), content, 9); - UNIT_ASSERT_VALUES_EQUAL(TString(buf.data(), buf.size()), "some text"); + memcpy(buf.data(), content, 9); + UNIT_ASSERT_VALUES_EQUAL(TString(buf.data(), buf.size()), "some text"); buf.Resize(4); - UNIT_ASSERT_VALUES_EQUAL(TString(buf.data(), buf.size()), "some"); + UNIT_ASSERT_VALUES_EQUAL(TString(buf.data(), buf.size()), "some"); } Y_UNIT_TEST(TestReserve) { @@ -92,12 +92,12 @@ Y_UNIT_TEST_SUITE(TBufferTest) { buf.Append('a'); UNIT_ASSERT_EQUAL(buf.Capacity(), 256); TString tmp1 = "abcdef"; - buf.Append(tmp1.data(), tmp1.size()); + buf.Append(tmp1.data(), tmp1.size()); UNIT_ASSERT_EQUAL(buf.Capacity(), 256); TString tmp2 = "30498290sfokdsflj2308w"; buf.Resize(1020); - buf.Append(tmp2.data(), tmp2.size()); + buf.Append(tmp2.data(), tmp2.size()); UNIT_ASSERT_EQUAL(buf.Capacity(), 2048); } @@ -105,14 +105,14 @@ Y_UNIT_TEST_SUITE(TBufferTest) { TBuffer buf; TString content = "some text"; - buf.Append(content.data(), content.size()); + buf.Append(content.data(), content.size()); UNIT_ASSERT_EQUAL(buf.Size(), 9); UNIT_ASSERT_EQUAL(buf.Capacity(), 16); buf.ShrinkToFit(); UNIT_ASSERT_EQUAL(buf.Size(), 9); UNIT_ASSERT_EQUAL(buf.Capacity(), 9); - UNIT_ASSERT_EQUAL(TString(buf.data(), buf.size()), content); + UNIT_ASSERT_EQUAL(TString(buf.data(), buf.size()), content); const size_t MB = 1024 * 1024; buf.Resize(MB); @@ -184,10 +184,10 @@ Y_UNIT_TEST(TestSpeed) { buf.Append("Some ", 5); buf.Fill('!', 5); buf.Append(" text.", 6); - UNIT_ASSERT_VALUES_EQUAL(TString(buf.data(), buf.size()), "Some !!!!! text."); + UNIT_ASSERT_VALUES_EQUAL(TString(buf.data(), buf.size()), "Some !!!!! text."); buf.Chop(5, 6); - UNIT_ASSERT_VALUES_EQUAL(TString(buf.data(), buf.size()), "Some text."); + UNIT_ASSERT_VALUES_EQUAL(TString(buf.data(), buf.size()), "Some text."); } Y_UNIT_TEST(TestComparison) { diff --git a/util/generic/function.h b/util/generic/function.h index aa7bf8aa13..62fa84e0cb 100644 --- a/util/generic/function.h +++ b/util/generic/function.h @@ -21,26 +21,26 @@ namespace NPrivate { typedef R TSignature(Args...); }; - template <class T> - struct TRemoveNoExceptImpl { - using Type = T; - }; - - template <typename R, typename... Args> - struct TRemoveNoExceptImpl<R(Args...) noexcept> { - using Type = R(Args...); - }; - - template <typename R, typename C, typename... Args> - struct TRemoveNoExceptImpl<R (C::*)(Args...) noexcept> { - using Type = R (C::*)(Args...); - }; - - template <class T> - using TRemoveNoExcept = typename TRemoveNoExceptImpl<T>::Type; - + template <class T> + struct TRemoveNoExceptImpl { + using Type = T; + }; + + template <typename R, typename... Args> + struct TRemoveNoExceptImpl<R(Args...) noexcept> { + using Type = R(Args...); + }; + + template <typename R, typename C, typename... Args> + struct TRemoveNoExceptImpl<R (C::*)(Args...) noexcept> { + using Type = R (C::*)(Args...); + }; + + template <class T> + using TRemoveNoExcept = typename TRemoveNoExceptImpl<T>::Type; + template <class F> - using TRemoveClass = typename TRemoveClassImpl<TRemoveNoExcept<F>>::TSignature; + using TRemoveClass = typename TRemoveClassImpl<TRemoveNoExcept<F>>::TSignature; template <class C> struct TFuncInfo { diff --git a/util/generic/guid.cpp b/util/generic/guid.cpp index a0a25619bb..8b907457bc 100644 --- a/util/generic/guid.cpp +++ b/util/generic/guid.cpp @@ -44,8 +44,8 @@ TGUID TGUID::Create() { void CreateGuid(TGUID* res) { ui64* dw = reinterpret_cast<ui64*>(res->dw); - WriteUnaligned<ui64>(&dw[0], RandomNumber<ui64>()); - WriteUnaligned<ui64>(&dw[1], RandomNumber<ui64>()); + WriteUnaligned<ui64>(&dw[0], RandomNumber<ui64>()); + WriteUnaligned<ui64>(&dw[1], RandomNumber<ui64>()); } TGUID TGUID::CreateTimebased() { diff --git a/util/generic/is_in_ut.cpp b/util/generic/is_in_ut.cpp index 4fc257797e..c668bce807 100644 --- a/util/generic/is_in_ut.cpp +++ b/util/generic/is_in_ut.cpp @@ -91,7 +91,7 @@ Y_UNIT_TEST_SUITE(TIsIn) { const TStringBuf str = "abc////"; - UNIT_ASSERT(IsIn({"abc", "def"}, TStringBuf{str.data(), 3})); + UNIT_ASSERT(IsIn({"abc", "def"}, TStringBuf{str.data(), 3})); } Y_UNIT_TEST(ConfOfTest) { @@ -100,8 +100,8 @@ Y_UNIT_TEST_SUITE(TIsIn) { const TString b = "b"; - UNIT_ASSERT(!IsIn({"a", "b", "c"}, b.data())); // compares pointers by value. Whether it's good or not. - UNIT_ASSERT(IsIn(TVector<TStringBuf>({"a", "b", "c"}), b.data())); + UNIT_ASSERT(!IsIn({"a", "b", "c"}, b.data())); // compares pointers by value. Whether it's good or not. + UNIT_ASSERT(IsIn(TVector<TStringBuf>({"a", "b", "c"}), b.data())); UNIT_ASSERT(IsIn(TVector<TStringBuf>({"a", "b", "c"}), "b")); } diff --git a/util/generic/iterator_range.h b/util/generic/iterator_range.h index d89eaf7559..9f4d02da29 100644 --- a/util/generic/iterator_range.h +++ b/util/generic/iterator_range.h @@ -1,7 +1,7 @@ #pragma once -#include <util/system/yassert.h> - +#include <util/system/yassert.h> + #include <iterator> #include <utility> @@ -43,10 +43,10 @@ class TIteratorRange<TIterator, TIterator> { public: using iterator = TIterator; using const_iterator = TIterator; - using value_type = typename std::iterator_traits<iterator>::value_type; - using reference = typename std::iterator_traits<iterator>::reference; - using const_reference = typename std::iterator_traits<const_iterator>::reference; - using difference_type = typename std::iterator_traits<iterator>::difference_type; + using value_type = typename std::iterator_traits<iterator>::value_type; + using reference = typename std::iterator_traits<iterator>::reference; + using const_reference = typename std::iterator_traits<const_iterator>::reference; + using difference_type = typename std::iterator_traits<iterator>::difference_type; using size_type = std::size_t; TIteratorRange() @@ -74,15 +74,15 @@ public: } size_type size() const { - return End_ - Begin_; + return End_ - Begin_; + } + + reference operator[](size_t at) const { + Y_ASSERT(at < size()); + + return *(Begin_ + at); } - reference operator[](size_t at) const { - Y_ASSERT(at < size()); - - return *(Begin_ + at); - } - private: TIterator Begin_; TIterator End_; diff --git a/util/generic/iterator_range_ut.cpp b/util/generic/iterator_range_ut.cpp index a93dc2e119..a7e3670ae1 100644 --- a/util/generic/iterator_range_ut.cpp +++ b/util/generic/iterator_range_ut.cpp @@ -2,7 +2,7 @@ #include <library/cpp/testing/unittest/registar.h> #include <util/generic/algorithm.h> -#include <util/generic/vector.h> +#include <util/generic/vector.h> Y_UNIT_TEST_SUITE(IteratorRange) { Y_UNIT_TEST(DefaultConstructor) { @@ -70,24 +70,24 @@ Y_UNIT_TEST_SUITE(IteratorRange) { Y_UNIT_TEST(OperatorsAndReferences) { TVector<size_t> values{1, 2, 3, 4, 5}; - auto range = MakeIteratorRange(values.begin(), values.end()); - UNIT_ASSERT_VALUES_EQUAL(range[2], 3); - UNIT_ASSERT_VALUES_EQUAL(range[range[2]], 4); - *values.begin() = 100500; - UNIT_ASSERT_VALUES_EQUAL(range[0], 100500); - range[0] = 100501; - UNIT_ASSERT_VALUES_EQUAL(range[0], 100501); - + auto range = MakeIteratorRange(values.begin(), values.end()); + UNIT_ASSERT_VALUES_EQUAL(range[2], 3); + UNIT_ASSERT_VALUES_EQUAL(range[range[2]], 4); + *values.begin() = 100500; + UNIT_ASSERT_VALUES_EQUAL(range[0], 100500); + range[0] = 100501; + UNIT_ASSERT_VALUES_EQUAL(range[0], 100501); + TVector<bool> valuesBool{false, true, false, false, false, false, true}; - auto rangeBVector = MakeIteratorRange(valuesBool.begin(), valuesBool.end()); - UNIT_ASSERT_VALUES_EQUAL(rangeBVector[1], true); - rangeBVector[0] = true; - valuesBool.back() = false; - UNIT_ASSERT_VALUES_EQUAL(rangeBVector[0], true); - UNIT_ASSERT_VALUES_EQUAL(rangeBVector[2], false); - UNIT_ASSERT_VALUES_EQUAL(rangeBVector[6], false); - } - + auto rangeBVector = MakeIteratorRange(valuesBool.begin(), valuesBool.end()); + UNIT_ASSERT_VALUES_EQUAL(rangeBVector[1], true); + rangeBVector[0] = true; + valuesBool.back() = false; + UNIT_ASSERT_VALUES_EQUAL(rangeBVector[0], true); + UNIT_ASSERT_VALUES_EQUAL(rangeBVector[2], false); + UNIT_ASSERT_VALUES_EQUAL(rangeBVector[6], false); + } + Y_UNIT_TEST(CanUseInAlgorithms) { const int values[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; auto range = MakeIteratorRange(values, values + Y_ARRAY_SIZE(values)); diff --git a/util/generic/strbase.h b/util/generic/strbase.h index 7289e651ba..ab39fc7537 100644 --- a/util/generic/strbase.h +++ b/util/generic/strbase.h @@ -439,7 +439,7 @@ public: } inline TCharType operator[](size_t pos) const noexcept { - Y_ASSERT(pos < this->size()); + Y_ASSERT(pos < this->size()); return Ptr()[pos]; } diff --git a/util/generic/strbuf.h b/util/generic/strbuf.h index 595db8114c..70b9360d58 100644 --- a/util/generic/strbuf.h +++ b/util/generic/strbuf.h @@ -214,7 +214,7 @@ public: * @returns Whether the split was actually performed. */ inline bool TrySplit(TdSelf delim, TdSelf& l, TdSelf& r) const noexcept { - return TrySplitOn(TBase::find(delim), l, r, delim.size()); + return TrySplitOn(TBase::find(delim), l, r, delim.size()); } /** @@ -229,7 +229,7 @@ public: * @returns Whether the split was actually performed. */ inline bool TryRSplit(TdSelf delim, TdSelf& l, TdSelf& r) const noexcept { - return TrySplitOn(TBase::rfind(delim), l, r, delim.size()); + return TrySplitOn(TBase::rfind(delim), l, r, delim.size()); } inline void Split(TCharType delim, TdSelf& l, TdSelf& r) const noexcept { diff --git a/util/generic/strbuf_ut.cpp b/util/generic/strbuf_ut.cpp index fe2f7f1913..69cde785af 100644 --- a/util/generic/strbuf_ut.cpp +++ b/util/generic/strbuf_ut.cpp @@ -8,14 +8,14 @@ Y_UNIT_TEST_SUITE(TStrBufTest) { Y_UNIT_TEST(TestConstructorsAndOperators) { TStringBuf str("qwerty"); - UNIT_ASSERT_EQUAL(*str.data(), 'q'); - UNIT_ASSERT_EQUAL(str.size(), 6); + UNIT_ASSERT_EQUAL(*str.data(), 'q'); + UNIT_ASSERT_EQUAL(str.size(), 6); TStringBuf str1("qwe\0rty"sv); TStringBuf str2(str1.data()); UNIT_ASSERT_VALUES_UNEQUAL(str1, str2); - UNIT_ASSERT_VALUES_EQUAL(str1.size(), 7); - UNIT_ASSERT_VALUES_EQUAL(str2.size(), 3); + UNIT_ASSERT_VALUES_EQUAL(str1.size(), 7); + UNIT_ASSERT_VALUES_EQUAL(str2.size(), 3); std::string_view helloWorld("Hello, World!"); TStringBuf fromStringView(helloWorld); @@ -29,10 +29,10 @@ Y_UNIT_TEST_SUITE(TStrBufTest) { Y_UNIT_TEST(TestConstExpr) { static constexpr TStringBuf str1("qwe\0rty", 7); - static constexpr TStringBuf str2(str1.data(), str1.size()); + static constexpr TStringBuf str2(str1.data(), str1.size()); static constexpr TStringBuf str3 = "qwe\0rty"sv; - UNIT_ASSERT_VALUES_EQUAL(str1.size(), 7); + UNIT_ASSERT_VALUES_EQUAL(str1.size(), 7); UNIT_ASSERT_VALUES_EQUAL(str1, str2); UNIT_ASSERT_VALUES_EQUAL(str2, str3); @@ -136,7 +136,7 @@ Y_UNIT_TEST_SUITE(TStrBufTest) { } Y_UNIT_TEST(TestEmpty) { - UNIT_ASSERT(TStringBuf().empty()); + UNIT_ASSERT(TStringBuf().empty()); UNIT_ASSERT(!TStringBuf("q").empty()); } @@ -146,7 +146,7 @@ Y_UNIT_TEST_SUITE(TStrBufTest) { str = qw; str.Chop(10); - UNIT_ASSERT(str.empty()); + UNIT_ASSERT(str.empty()); str = qw; UNIT_ASSERT_EQUAL(str.SubStr(2), TStringBuf("erty")); @@ -172,7 +172,7 @@ Y_UNIT_TEST_SUITE(TStrBufTest) { rt = qw; lt = rt.NextTok('r'); TStringBuf ty = rt.NextTok('r'); // no 'r' in "ty" - UNIT_ASSERT_EQUAL(rt.size(), 0); + UNIT_ASSERT_EQUAL(rt.size(), 0); UNIT_ASSERT_EQUAL(ty, TStringBuf("ty")); } diff --git a/util/generic/string.cpp b/util/generic/string.cpp index 584f72675e..3c655f1f66 100644 --- a/util/generic/string.cpp +++ b/util/generic/string.cpp @@ -11,7 +11,7 @@ alignas(32) const char NULL_STRING_REPR[128] = {0}; std::ostream& operator<<(std::ostream& os, const TString& s) { - return os.write(s.data(), s.size()); + return os.write(s.data(), s.size()); } std::istream& operator>>(std::istream& is, TString& s) { diff --git a/util/generic/string_ut.cpp b/util/generic/string_ut.cpp index cd45b1d42c..ac82e9091d 100644 --- a/util/generic/string_ut.cpp +++ b/util/generic/string_ut.cpp @@ -29,7 +29,7 @@ public: void TestZero() { const char data[] = "abc\0def\0"; TString s(data, sizeof(data)); - UNIT_ASSERT(s.size() == sizeof(data)); + UNIT_ASSERT(s.size() == sizeof(data)); UNIT_ASSERT(s.StartsWith(s)); UNIT_ASSERT(s.EndsWith(s)); UNIT_ASSERT(s.Contains('\0')); @@ -48,7 +48,7 @@ public: UNIT_ASSERT_EQUAL(TString::npos, s.find(TString(nonSubstring, sizeof(nonSubstring)))); TString copy = s; - copy.replace(copy.size() - 1, 1, "z"); + copy.replace(copy.size() - 1, 1, "z"); UNIT_ASSERT(s != copy); copy.replace(copy.size() - 1, 1, "\0", 0, 1); UNIT_ASSERT(s == copy); @@ -57,8 +57,8 @@ public: UNIT_ASSERT(s.StartsWith(prefix)); UNIT_ASSERT(s != prefix); UNIT_ASSERT(s > prefix); - UNIT_ASSERT(s > s.data()); - UNIT_ASSERT(s == TString(s.data(), s.size())); + UNIT_ASSERT(s > s.data()); + UNIT_ASSERT(s == TString(s.data(), s.size())); UNIT_ASSERT(data < s); s.remove(5); @@ -552,13 +552,13 @@ protected: str2 = Data_.abcdef(); UNIT_ASSERT(str1.compare(str2) == 0); - UNIT_ASSERT(str1.compare(str2.data(), str2.size()) == 0); + UNIT_ASSERT(str1.compare(str2.data(), str2.size()) == 0); str2 = Data_.abcde(); UNIT_ASSERT(str1.compare(str2) > 0); - UNIT_ASSERT(str1.compare(str2.data(), str2.size()) > 0); + UNIT_ASSERT(str1.compare(str2.data(), str2.size()) > 0); str2 = Data_.abcdefg(); UNIT_ASSERT(str1.compare(str2) < 0); - UNIT_ASSERT(str1.compare(str2.data(), str2.size()) < 0); + UNIT_ASSERT(str1.compare(str2.data(), str2.size()) < 0); UNIT_ASSERT(str1.compare(Data_.abcdef()) == 0); UNIT_ASSERT(str1.compare(Data_.abcde()) > 0); @@ -889,7 +889,7 @@ private: UNIT_ASSERT(str == TUtf16String::FromAscii("X")); const TUtf16String hello = TUtf16String::FromAscii("hello"); - str = hello.data(); + str = hello.data(); UNIT_ASSERT(str == hello); str = hello; @@ -1087,7 +1087,7 @@ private: UNIT_ASSERT(str == TUtf32String::FromAscii("X")); const TUtf32String hello = TUtf32String::FromAscii("hello"); - str = hello.data(); + str = hello.data(); UNIT_ASSERT(str == hello); str = hello; diff --git a/util/generic/string_ut.h b/util/generic/string_ut.h index 95bc855cb2..44bb10bdeb 100644 --- a/util/generic/string_ut.h +++ b/util/generic/string_ut.h @@ -646,8 +646,8 @@ public: s = Data._012345(); UNIT_ASSERT(s.at(1) == *Data._1()); UNIT_ASSERT(s[1] == *Data._1()); - UNIT_ASSERT(s.at(s.size()) == 0); - UNIT_ASSERT(s[s.size()] == 0); + UNIT_ASSERT(s.at(s.size()) == 0); + UNIT_ASSERT(s[s.size()] == 0); } #ifndef TSTRING_IS_STD_STRING @@ -690,7 +690,7 @@ public: UNIT_ASSERT(s.find_first_of(TStringType(Data._389())) == 3); UNIT_ASSERT(s.find_first_of(Data._389()) == 3); - UNIT_ASSERT(s.find_first_of(Data._389(), s.size()) == TStringType::npos); + UNIT_ASSERT(s.find_first_of(Data._389(), s.size()) == TStringType::npos); UNIT_ASSERT(s.find_first_not_of(Data._123()) == 0); UNIT_ASSERT(s.find_first_of('6') == 6); UNIT_ASSERT(s.find_first_of('1', 2) == 8); @@ -820,10 +820,10 @@ public: void TestFuncs() { TStringType s(Data._0123456()); - UNIT_ASSERT(s.c_str() == s.data()); + UNIT_ASSERT(s.c_str() == s.data()); // length() - UNIT_ASSERT(s.length() == s.size()); + UNIT_ASSERT(s.length() == s.size()); UNIT_ASSERT(s.length() == traits_type::length(s.data())); // is_null() @@ -868,10 +868,10 @@ public: s2 = s3; // resize family - s2.resize(s2.size()); // without length change + s2.resize(s2.size()); // without length change UNIT_ASSERT(s2 == Data.Asdf1234qwer()); - s2.resize(s2.size() + 4, *Data.W()); + s2.resize(s2.size() + 4, *Data.W()); UNIT_ASSERT(s2 == Data.Asdf1234qwerWWWW()); s2.resize(4); diff --git a/util/generic/vector_ut.cpp b/util/generic/vector_ut.cpp index 865a00cd3a..0f6b4037a0 100644 --- a/util/generic/vector_ut.cpp +++ b/util/generic/vector_ut.cpp @@ -70,7 +70,7 @@ private: inline void TestTildeEmptyToNull() { TVector<int> v; - UNIT_ASSERT_EQUAL(nullptr, v.data()); + UNIT_ASSERT_EQUAL(nullptr, v.data()); } inline void TestTilde() { @@ -78,17 +78,17 @@ private: v.push_back(10); v.push_back(20); - UNIT_ASSERT_EQUAL(10, (v.data())[0]); - UNIT_ASSERT_EQUAL(20, (v.data())[1]); + UNIT_ASSERT_EQUAL(10, (v.data())[0]); + UNIT_ASSERT_EQUAL(20, (v.data())[1]); for (int i = 0; i < 10000; ++i) { v.push_back(99); } - UNIT_ASSERT_EQUAL(10, (v.data())[0]); - UNIT_ASSERT_EQUAL(20, (v.data())[1]); - UNIT_ASSERT_EQUAL(99, (v.data())[3]); - UNIT_ASSERT_EQUAL(99, (v.data())[4]); + UNIT_ASSERT_EQUAL(10, (v.data())[0]); + UNIT_ASSERT_EQUAL(20, (v.data())[1]); + UNIT_ASSERT_EQUAL(99, (v.data())[3]); + UNIT_ASSERT_EQUAL(99, (v.data())[4]); } // Copy-paste of STLPort tests diff --git a/util/memory/blob.cpp b/util/memory/blob.cpp index d7de94fe86..91da5cadca 100644 --- a/util/memory/blob.cpp +++ b/util/memory/blob.cpp @@ -395,7 +395,7 @@ TBlob ConstructFromString(S&& s) { using TBase = TStringBlobBase<TCounter>; auto base = MakeHolder<TBase>(std::forward<S>(s)); - TBlob ret(base->String().data(), base->String().size(), base.Get()); + TBlob ret(base->String().data(), base->String().size(), base.Get()); Y_UNUSED(base.Release()); return ret; diff --git a/util/memory/pool.h b/util/memory/pool.h index c906f6d208..13c8b6b9ed 100644 --- a/util/memory/pool.h +++ b/util/memory/pool.h @@ -225,10 +225,10 @@ public: template <typename TChar> inline TBasicStringBuf<TChar> AppendCString(const TBasicStringBuf<TChar>& buf) { - TChar* ret = static_cast<TChar*>(Allocate((buf.size() + 1) * sizeof(TChar))); + TChar* ret = static_cast<TChar*>(Allocate((buf.size() + 1) * sizeof(TChar))); std::char_traits<TChar>::copy(ret, buf.data(), buf.size()); - *(ret + buf.size()) = 0; + *(ret + buf.size()) = 0; return TBasicStringBuf<TChar>(ret, buf.size()); } diff --git a/util/memory/segmented_string_pool.h b/util/memory/segmented_string_pool.h index 4da0763afc..a40aa408f5 100644 --- a/util/memory/segmented_string_pool.h +++ b/util/memory/segmented_string_pool.h @@ -3,7 +3,7 @@ #include <util/system/align.h> #include <util/system/yassert.h> #include <util/system/defaults.h> -#include <util/generic/noncopyable.h> +#include <util/generic/noncopyable.h> #include <util/generic/vector.h> #include <util/generic/strbuf.h> @@ -172,7 +172,7 @@ public: return rv; } char* Append(const TStringBuf s) { - return append(s.data(), s.size()); + return append(s.data(), s.size()); } void align_4() { size_t t = (curseg->freepos + 3) & ~3; diff --git a/util/network/ip.h b/util/network/ip.h index fbabb76cbf..dc7c2d24a0 100644 --- a/util/network/ip.h +++ b/util/network/ip.h @@ -46,7 +46,7 @@ static inline TIpHost ResolveHost(const char* data, size_t len) { TIpHost ret; const TString s(data, len); - if (NResolver::GetHostIP(s.data(), &ret) != 0) { + if (NResolver::GetHostIP(s.data(), &ret) != 0) { ythrow TSystemError(NResolver::GetDnsError()) << "can not resolve(" << s << ")"; } @@ -70,7 +70,7 @@ struct TIpAddress: public sockaddr_in { } inline TIpAddress(TStringBuf ip, TIpPort port) { - Set(ResolveHost(ip.data(), ip.size()), port); + Set(ResolveHost(ip.data(), ip.size()), port); } inline TIpAddress(const char* ip, TIpPort port) { diff --git a/util/network/socket.cpp b/util/network/socket.cpp index 1440dd5363..4f6e804346 100644 --- a/util/network/socket.cpp +++ b/util/network/socket.cpp @@ -1070,12 +1070,12 @@ TNetworkAddress::TNetworkAddress(const TUnixSocketPath& unixSocketPath, int flag } TNetworkAddress::TNetworkAddress(const TString& host, ui16 port, int flags) - : Impl_(new TImpl(host.data(), port, flags)) + : Impl_(new TImpl(host.data(), port, flags)) { } TNetworkAddress::TNetworkAddress(const TString& host, ui16 port) - : Impl_(new TImpl(host.data(), port, 0)) + : Impl_(new TImpl(host.data(), port, 0)) { } diff --git a/util/network/socket_ut.cpp b/util/network/socket_ut.cpp index 7a03df97ea..6b20e11f70 100644 --- a/util/network/socket_ut.cpp +++ b/util/network/socket_ut.cpp @@ -48,7 +48,7 @@ void TSockTest::TestSock() { TSocketInput si(s); const TStringBuf req = "GET / HTTP/1.1\r\nHost: yandex.ru\r\n\r\n"; - so.Write(req.data(), req.size()); + so.Write(req.data(), req.size()); UNIT_ASSERT(!si.ReadLine().empty()); } diff --git a/util/random/entropy.cpp b/util/random/entropy.cpp index c3ae7a1718..3617edb83d 100644 --- a/util/random/entropy.cpp +++ b/util/random/entropy.cpp @@ -160,7 +160,7 @@ namespace { #define DO_STEP(type) \ while (len >= sizeof(type)) { \ - WriteUnaligned<type>(buf, RandomNumber<type>()); \ + WriteUnaligned<type>(buf, RandomNumber<type>()); \ buf += sizeof(type); \ len -= sizeof(type); \ } diff --git a/util/random/normal_ut.cpp b/util/random/normal_ut.cpp index 8968f9e571..42b6cc4ba2 100644 --- a/util/random/normal_ut.cpp +++ b/util/random/normal_ut.cpp @@ -31,13 +31,13 @@ Y_UNIT_TEST_SUITE(TestNormalDistribution) { mm += x; } - mm /= v.size(); + mm /= v.size(); for (auto x : v) { vv += (mm - x) * (mm - x); } - vv /= v.size(); + vv /= v.size(); long double dd = std::sqrt(vv); diff --git a/util/str_stl.h b/util/str_stl.h index a8fe450e62..f1e137181d 100644 --- a/util/str_stl.h +++ b/util/str_stl.h @@ -222,14 +222,14 @@ struct TCIEqualTo<const char*> { template <> struct TCIEqualTo<TStringBuf> { inline bool operator()(const TStringBuf a, const TStringBuf b) const { - return a.size() == b.size() && strnicmp(a.data(), b.data(), a.size()) == 0; + return a.size() == b.size() && strnicmp(a.data(), b.data(), a.size()) == 0; } }; template <> struct TCIEqualTo<TString> { inline bool operator()(const TString& a, const TString& b) const { - return a.size() == b.size() && strnicmp(a.data(), b.data(), a.size()) == 0; + return a.size() == b.size() && strnicmp(a.data(), b.data(), a.size()) == 0; } }; diff --git a/util/stream/buffer.cpp b/util/stream/buffer.cpp index d42b193a5f..2facece4ea 100644 --- a/util/stream/buffer.cpp +++ b/util/stream/buffer.cpp @@ -109,7 +109,7 @@ void TBufferInput::Rewind() noexcept { size_t TBufferInput::DoNext(const void** ptr, size_t len) { len = Min(Buf_.Size() - Readed_, len); - *ptr = Buf_.data() + Readed_; + *ptr = Buf_.data() + Readed_; Readed_ += len; return len; } diff --git a/util/stream/buffer_ut.cpp b/util/stream/buffer_ut.cpp index 28fe961809..3494696190 100644 --- a/util/stream/buffer_ut.cpp +++ b/util/stream/buffer_ut.cpp @@ -67,12 +67,12 @@ Y_UNIT_TEST_SUITE(TBufferTest) { << "4444" << "55555"; - UNIT_ASSERT(0 == memcmp(buffer.data(), "1" + UNIT_ASSERT(0 == memcmp(buffer.data(), "1" "22" "333" "4444" "55555", - buffer.size())); + buffer.size())); } Y_UNIT_TEST(WriteChars) { @@ -80,6 +80,6 @@ Y_UNIT_TEST_SUITE(TBufferTest) { TBufferOutput output(buffer); output << '1' << '2' << '3' << '4' << '5' << '6' << '7' << '8' << '9' << '0'; - UNIT_ASSERT(0 == memcmp(buffer.data(), "1234567890", buffer.size())); + UNIT_ASSERT(0 == memcmp(buffer.data(), "1234567890", buffer.size())); } } diff --git a/util/stream/buffered_ut.cpp b/util/stream/buffered_ut.cpp index ebcd31ae3f..41d2fc3030 100644 --- a/util/stream/buffered_ut.cpp +++ b/util/stream/buffered_ut.cpp @@ -18,7 +18,7 @@ Y_UNIT_TEST_SUITE(TestBufferedIO) { s.append('A' + (r.GenRand() % 10)); } - out.Write(s.data(), s.size()); + out.Write(s.data(), s.size()); } } diff --git a/util/stream/format.h b/util/stream/format.h index c88ea3a1e0..b033208a1b 100644 --- a/util/stream/format.h +++ b/util/stream/format.h @@ -144,7 +144,7 @@ namespace NFormatPrivate { template <typename Char, size_t Base> IOutputStream& operator<<(IOutputStream& os, const TBaseText<Char, Base>& text) { - for (size_t i = 0; i < text.Text.size(); ++i) { + for (size_t i = 0; i < text.Text.size(); ++i) { if (i != 0) { os << ' '; } diff --git a/util/stream/hex_ut.cpp b/util/stream/hex_ut.cpp index f788d38233..5074a0b616 100644 --- a/util/stream/hex_ut.cpp +++ b/util/stream/hex_ut.cpp @@ -7,13 +7,13 @@ Y_UNIT_TEST_SUITE(THexCodingTest) { void TestImpl(const TString& data) { TString encoded; TStringOutput encodedOut(encoded); - HexEncode(data.data(), data.size(), encodedOut); + HexEncode(data.data(), data.size(), encodedOut); - UNIT_ASSERT_EQUAL(encoded.size(), data.size() * 2); + UNIT_ASSERT_EQUAL(encoded.size(), data.size() * 2); TString decoded; TStringOutput decodedOut(decoded); - HexDecode(encoded.data(), encoded.size(), decodedOut); + HexDecode(encoded.data(), encoded.size(), decodedOut); UNIT_ASSERT_EQUAL(decoded, data); } diff --git a/util/stream/input_ut.cpp b/util/stream/input_ut.cpp index 8d3b1bad0d..4a93f5458e 100644 --- a/util/stream/input_ut.cpp +++ b/util/stream/input_ut.cpp @@ -23,7 +23,7 @@ public: template <typename FuncType> void ForInput(const TStringBuf text, const FuncType& func) { TFile tempFile(TFile::Temporary("input_ut")); - tempFile.Write(text.data(), text.size()); + tempFile.Write(text.data(), text.size()); tempFile.FlushData(); tempFile.Seek(0, sSet); diff --git a/util/stream/ios_ut.cpp b/util/stream/ios_ut.cpp index 2f08fc57ba..139f4296e5 100644 --- a/util/stream/ios_ut.cpp +++ b/util/stream/ios_ut.cpp @@ -191,7 +191,7 @@ public: s.append((const char*)p[i].buf, p[i].len); } - DoWrite(s.data(), s.size()); + DoWrite(s.data(), s.size()); } private: @@ -210,13 +210,13 @@ void TStreamsTest::TestBufferedIO() { TString str(" "); str += ToString(i % 10); - bo.Write(str.data(), str.size()); + bo.Write(str.data(), str.size()); } bo.Finish(); } - UNIT_ASSERT_EQUAL(s.size(), 2000); + UNIT_ASSERT_EQUAL(s.size(), 2000); { const size_t buflen = 11; @@ -248,7 +248,7 @@ void TStreamsTest::TestBufferedIO() { } for (size_t i = 0; i < 1000; ++i) { - bo.Write(f.data(), i); + bo.Write(f.data(), i); } bo.Finish(); @@ -259,13 +259,13 @@ void TStreamsTest::TestBufferStream() { TBufferStream stream; TString s = "test"; - stream.Write(s.data(), s.size()); + stream.Write(s.data(), s.size()); char buf[5]; size_t bytesRead = stream.Read(buf, 4); UNIT_ASSERT_EQUAL(4, bytesRead); - UNIT_ASSERT_EQUAL(0, strncmp(s.data(), buf, 4)); + UNIT_ASSERT_EQUAL(0, strncmp(s.data(), buf, 4)); - stream.Write(s.data(), s.size()); + stream.Write(s.data(), s.size()); bytesRead = stream.Read(buf, 2); UNIT_ASSERT_EQUAL(2, bytesRead); UNIT_ASSERT_EQUAL(0, strncmp("te", buf, 2)); @@ -382,9 +382,9 @@ namespace { void TestStreamReadTo(const TString& text, T test) { TStringInput is(text); test(is, "TStringInput"); - TMemoryInput mi(text.data(), text.size()); + TMemoryInput mi(text.data(), text.size()); test(mi, "TMemoryInput"); - TBuffer b(text.data(), text.size()); + TBuffer b(text.data(), text.size()); TBufferInput bi(b); test(bi, "TBufferInput"); TStringInput slave(text); @@ -409,7 +409,7 @@ void TStreamsTest::TestStrokaInput() { TString s; for (ui32 i = 0; i < 100000; ++i) { TVector<char> d(i % 1000, 'a'); - s.append(d.data(), d.size()); + s.append(d.data(), d.size()); s.append('\n'); } TestStreamReadTo(s, ::TestStrokaInput); diff --git a/util/stream/length_ut.cpp b/util/stream/length_ut.cpp index 11ff8e8c8a..8968448954 100644 --- a/util/stream/length_ut.cpp +++ b/util/stream/length_ut.cpp @@ -45,7 +45,7 @@ Y_UNIT_TEST_SUITE(TestLengthIO) { UNIT_ASSERT_VALUES_EQUAL(l1.Counter(), 5); TString buf("aaa"); - IOutputStream::TPart parts[] = {{buf.data(), buf.size()}, {buf.data(), buf.size()}, {buf.data(), buf.size()}}; + IOutputStream::TPart parts[] = {{buf.data(), buf.size()}, {buf.data(), buf.size()}, {buf.data(), buf.size()}}; l1.Write(parts, 3); UNIT_ASSERT_VALUES_EQUAL(l1.Counter(), 14); } diff --git a/util/stream/mem.cpp b/util/stream/mem.cpp index 279a276ee8..22a3339e27 100644 --- a/util/stream/mem.cpp +++ b/util/stream/mem.cpp @@ -15,8 +15,8 @@ TMemoryInput::TMemoryInput(const void* buf, size_t len) noexcept } TMemoryInput::TMemoryInput(const TStringBuf buf) noexcept - : Buf_(buf.data()) - , Len_(buf.size()) + : Buf_(buf.data()) + , Len_(buf.size()) { } diff --git a/util/stream/output.cpp b/util/stream/output.cpp index 2ca09137f8..db81b81b70 100644 --- a/util/stream/output.cpp +++ b/util/stream/output.cpp @@ -91,7 +91,7 @@ static void WriteString(IOutputStream& o, const wchar32* w, size_t n) { template <> void Out<TString>(IOutputStream& o, const TString& p) { - o.Write(p.data(), p.size()); + o.Write(p.data(), p.size()); } template <> diff --git a/util/stream/output.h b/util/stream/output.h index cf45957b99..00eef50b95 100644 --- a/util/stream/output.h +++ b/util/stream/output.h @@ -31,8 +31,8 @@ public: } inline TPart(const TStringBuf s) noexcept - : buf(s.data()) - , len(s.size()) + : buf(s.data()) + , len(s.size()) { } @@ -80,7 +80,7 @@ public: * @param st String to write. */ inline void Write(const TStringBuf st) { - Write(st.data(), st.size()); + Write(st.data(), st.size()); } /** diff --git a/util/stream/pipe.cpp b/util/stream/pipe.cpp index ecbb9b96d3..51be1934a7 100644 --- a/util/stream/pipe.cpp +++ b/util/stream/pipe.cpp @@ -15,7 +15,7 @@ public: ythrow TSystemError(EINVAL) << "pipe \"r+\" mode is implemented only on FreeBSD"; } #endif - Pipe_ = ::popen(command.data(), mode); + Pipe_ = ::popen(command.data(), mode); if (Pipe_ == nullptr) { ythrow TSystemError() << "failed to open pipe: " << command.Quote(); } diff --git a/util/stream/printf_ut.cpp b/util/stream/printf_ut.cpp index 847c45cfb3..0eab167062 100644 --- a/util/stream/printf_ut.cpp +++ b/util/stream/printf_ut.cpp @@ -26,7 +26,7 @@ Y_UNIT_TEST_SUITE(TStreamPrintfTest) { TString s = NUnitTest::RandomString(1000000); TStringStream ss; - Printf(ss, "%s", s.data()); + Printf(ss, "%s", s.data()); UNIT_ASSERT_EQUAL(ss.Str(), s); } diff --git a/util/stream/str.h b/util/stream/str.h index a956d1597d..028bd572c0 100644 --- a/util/stream/str.h +++ b/util/stream/str.h @@ -169,7 +169,7 @@ public: * to be null-terminated. */ inline const char* Data() const noexcept { - return Ptr()->data(); + return Ptr()->data(); } /** @@ -179,7 +179,7 @@ public: * available for reading. */ inline size_t Size() const noexcept { - return Ptr()->size(); + return Ptr()->size(); } /** diff --git a/util/stream/tokenizer_ut.cpp b/util/stream/tokenizer_ut.cpp index f149209fb0..afc566da86 100644 --- a/util/stream/tokenizer_ut.cpp +++ b/util/stream/tokenizer_ut.cpp @@ -8,7 +8,7 @@ #include "tokenizer.h" static inline void CheckIfNullTerminated(const TStringBuf str) { - UNIT_ASSERT_VALUES_EQUAL('\0', *(str.data() + str.size())); + UNIT_ASSERT_VALUES_EQUAL('\0', *(str.data() + str.size())); } Y_UNIT_TEST_SUITE(TStreamTokenizerTests) { diff --git a/util/stream/zlib.cpp b/util/stream/zlib.cpp index c672177880..60f4e9439f 100644 --- a/util/stream/zlib.cpp +++ b/util/stream/zlib.cpp @@ -215,8 +215,8 @@ public: deflateSetHeader(Z(), GZHeader_.Get()); } - if (p.Dict.size()) { - if (deflateSetDictionary(Z(), (const Bytef*)p.Dict.data(), p.Dict.size())) { + if (p.Dict.size()) { + if (deflateSetDictionary(Z(), (const Bytef*)p.Dict.data(), p.Dict.size())) { ythrow TZLibCompressorError() << "can not set deflate dictionary"; } } diff --git a/util/string/ascii_ut.cpp b/util/string/ascii_ut.cpp index 5c35f3bda5..89069fee50 100644 --- a/util/string/ascii_ut.cpp +++ b/util/string/ascii_ut.cpp @@ -74,9 +74,9 @@ Y_UNIT_TEST_SUITE(TAsciiTest) { TString z = "qQnB"; TString zz = "qQqq"; TString zzz = "qQqqq"; - TStringBuf xs = TStringBuf(x.data(), 3); - TStringBuf ys = TStringBuf(y.data(), 3); - TStringBuf zs = TStringBuf(z.data(), 3); + TStringBuf xs = TStringBuf(x.data(), 3); + TStringBuf ys = TStringBuf(y.data(), 3); + TStringBuf zs = TStringBuf(z.data(), 3); UNIT_ASSERT(AsciiCompareIgnoreCase(xs, ys) == 0); UNIT_ASSERT(AsciiCompareIgnoreCase(xs, zs) > 0); UNIT_ASSERT(AsciiCompareIgnoreCase(xs, zz) < 0); diff --git a/util/string/cast.h b/util/string/cast.h index a27f5838bd..90e925c194 100644 --- a/util/string/cast.h +++ b/util/string/cast.h @@ -152,12 +152,12 @@ inline T FromString(const TChar* data) { template <class T> inline T FromString(const TStringBuf& s) { - return ::FromString<T>(s.data(), s.size()); + return ::FromString<T>(s.data(), s.size()); } template <class T> inline T FromString(const TString& s) { - return ::FromString<T>(s.data(), s.size()); + return ::FromString<T>(s.data(), s.size()); } template <class T> @@ -172,7 +172,7 @@ inline TString FromString<TString>(const TString& s) { template <class T> inline T FromString(const TWtringBuf& s) { - return ::FromString<T, typename TWtringBuf::char_type>(s.data(), s.size()); + return ::FromString<T, typename TWtringBuf::char_type>(s.data(), s.size()); } template <class T> @@ -212,7 +212,7 @@ inline ::NPrivate::TFromString<TChar> FromString(const TChar* data) { template <typename T> inline ::NPrivate::TFromString<typename T::TChar> FromString(const T& s) { - return ::NPrivate::TFromString<typename T::TChar>(s.data(), s.size()); + return ::NPrivate::TFromString<typename T::TChar>(s.data(), s.size()); } // Conversion exception free versions @@ -247,12 +247,12 @@ inline bool TryFromString(const TChar* data, const size_t len, T& result, const template <class T> inline bool TryFromString(const TStringBuf& s, T& result) { - return TryFromString<T>(s.data(), s.size(), result); + return TryFromString<T>(s.data(), s.size(), result); } template <class T> inline bool TryFromString(const TString& s, T& result) { - return TryFromString<T>(s.data(), s.size(), result); + return TryFromString<T>(s.data(), s.size(), result); } template <class T> @@ -262,17 +262,17 @@ inline bool TryFromString(const std::string& s, T& result) { template <class T> inline bool TryFromString(const TWtringBuf& s, T& result) { - return TryFromString<T>(s.data(), s.size(), result); + return TryFromString<T>(s.data(), s.size(), result); } template <class T> inline bool TryFromString(const TUtf16String& s, T& result) { - return TryFromString<T>(s.data(), s.size(), result); + return TryFromString<T>(s.data(), s.size(), result); } template <class T, class TStringType> inline bool TryFromStringWithDefault(const TStringType& s, T& result, const T& def) { - return TryFromString<T>(s.data(), s.size(), result, def); + return TryFromString<T>(s.data(), s.size(), result, def); } template <class T> @@ -295,7 +295,7 @@ inline T FromString(const TChar* data, const size_t len, const T& def) { template <class T, class TStringType> inline T FromStringWithDefault(const TStringType& s, const T& def) { - return FromString<T>(s.data(), s.size(), def); + return FromString<T>(s.data(), s.size(), def); } template <class T> @@ -328,7 +328,7 @@ bool TryIntFromString(const TChar* data, size_t len, TInt& result); template <int base, class TInt, class TStringType> inline bool TryIntFromString(const TStringType& s, TInt& result) { - return TryIntFromString<base>(s.data(), s.size(), result); + return TryIntFromString<base>(s.data(), s.size(), result); } template <class TInt, int base, class TChar> @@ -341,7 +341,7 @@ inline TInt IntFromString(const TChar* str) { template <class TInt, int base, class TStringType> inline TInt IntFromString(const TStringType& str) { - return IntFromString<TInt, base>(str.data(), str.size()); + return IntFromString<TInt, base>(str.data(), str.size()); } static inline TString ToString(const TStringBuf str) { diff --git a/util/string/cast_ut.cpp b/util/string/cast_ut.cpp index 0b2ca39dc7..033450c38c 100644 --- a/util/string/cast_ut.cpp +++ b/util/string/cast_ut.cpp @@ -324,7 +324,7 @@ Y_UNIT_TEST_SUITE(TCastTest) { TString a = "xyz"; TStringBuf b = FromString<TStringBuf>(a); UNIT_ASSERT_VALUES_EQUAL(a, b); - UNIT_ASSERT_VALUES_EQUAL((void*)a.data(), (void*)b.data()); + UNIT_ASSERT_VALUES_EQUAL((void*)a.data(), (void*)b.data()); } #if 0 @@ -360,14 +360,14 @@ Y_UNIT_TEST_SUITE(TCastTest) { UNIT_ASSERT_VALUES_EQUAL(TryFromString(uw, uv), true); UNIT_ASSERT_VALUES_EQUAL(uv, 21474836470ull); - TWtringBuf bw(uw.data(), uw.size()); + TWtringBuf bw(uw.data(), uw.size()); uv = 0; UNIT_ASSERT_VALUES_EQUAL(TryFromString(uw, uv), true); UNIT_ASSERT_VALUES_EQUAL(uv, 21474836470ull); - const wchar16* beg = uw.data(); + const wchar16* beg = uw.data(); uv = 0; - UNIT_ASSERT_VALUES_EQUAL(TryFromString(beg, uw.size(), uv), true); + UNIT_ASSERT_VALUES_EQUAL(TryFromString(beg, uw.size(), uv), true); UNIT_ASSERT_VALUES_EQUAL(uv, 21474836470ull); } diff --git a/util/string/escape.cpp b/util/string/escape.cpp index 2e8428308e..cd09a7dbd0 100644 --- a/util/string/escape.cpp +++ b/util/string/escape.cpp @@ -401,33 +401,33 @@ template size_t UnescapeCCharLen<char>(const char* begin, const char* end); template size_t UnescapeCCharLen<TUtf16String::TChar>(const TUtf16String::TChar* begin, const TUtf16String::TChar* end); TString& EscapeC(const TStringBuf str, TString& s) { - return EscapeC(str.data(), str.size(), s); + return EscapeC(str.data(), str.size(), s); } TUtf16String& EscapeC(const TWtringBuf str, TUtf16String& w) { - return EscapeC(str.data(), str.size(), w); + return EscapeC(str.data(), str.size(), w); } TString EscapeC(const TString& str) { - return EscapeC(str.data(), str.size()); + return EscapeC(str.data(), str.size()); } TUtf16String EscapeC(const TUtf16String& str) { - return EscapeC(str.data(), str.size()); + return EscapeC(str.data(), str.size()); } TString& UnescapeC(const TStringBuf str, TString& s) { - return UnescapeC(str.data(), str.size(), s); + return UnescapeC(str.data(), str.size(), s); } TUtf16String& UnescapeC(const TWtringBuf str, TUtf16String& w) { - return UnescapeC(str.data(), str.size(), w); + return UnescapeC(str.data(), str.size(), w); } TString UnescapeC(const TStringBuf str) { - return UnescapeC(str.data(), str.size()); + return UnescapeC(str.data(), str.size()); } TUtf16String UnescapeC(const TWtringBuf str) { - return UnescapeC(str.data(), str.size()); + return UnescapeC(str.data(), str.size()); } diff --git a/util/string/escape.h b/util/string/escape.h index b45a4494b6..b01be65b0e 100644 --- a/util/string/escape.h +++ b/util/string/escape.h @@ -25,7 +25,7 @@ static inline TBasicString<TChar> EscapeC(const TChar* str, size_t len) { template <typename TChar> static inline TBasicString<TChar> EscapeC(const TBasicStringBuf<TChar>& str) { - return EscapeC(str.data(), str.size()); + return EscapeC(str.data(), str.size()); } template <typename TChar> diff --git a/util/string/escape_ut.cpp b/util/string/escape_ut.cpp index 9d557621c5..cd38ecffd3 100644 --- a/util/string/escape_ut.cpp +++ b/util/string/escape_ut.cpp @@ -135,7 +135,7 @@ Y_UNIT_TEST_SUITE(TEscapeCTest) { char buf[100000]; for (const auto& x : CommonTestData) { - char* end = UnescapeC(x.Expected.data(), x.Expected.size(), buf); + char* end = UnescapeC(x.Expected.data(), x.Expected.size(), buf); UNIT_ASSERT_VALUES_EQUAL(x.Source, TStringBuf(buf, end)); } diff --git a/util/string/hex.h b/util/string/hex.h index 212d22dcc5..af3d2d528f 100644 --- a/util/string/hex.h +++ b/util/string/hex.h @@ -31,7 +31,7 @@ char* HexEncode(const void* in, size_t len, char* out); TString HexEncode(const void* in, size_t len); inline TString HexEncode(const TStringBuf h) { - return HexEncode(h.data(), h.size()); + return HexEncode(h.data(), h.size()); } //! Convert a hex string @c in of @c len chars (case-insensitive) to array of ints stored at @c ptr and return this array. @@ -55,5 +55,5 @@ TString HexDecode(const void* in, size_t len); //! Convert an ASCII hex-string (case-insensitive) to the binary form. Note that h.Size() must be even (+h % 2 == 0). inline TString HexDecode(const TStringBuf h) { - return HexDecode(h.data(), h.size()); + return HexDecode(h.data(), h.size()); } diff --git a/util/string/split.cpp b/util/string/split.cpp index 9b193e9459..7d26857cc7 100644 --- a/util/string/split.cpp +++ b/util/string/split.cpp @@ -20,5 +20,5 @@ size_t Split(const char* ptr, const char* delim, TVector<TString>& values) { } size_t Split(const TString& in, const TString& delim, TVector<TString>& res) { - return Split(in.data(), delim.data(), res); + return Split(in.data(), delim.data(), res); } diff --git a/util/string/split.h b/util/string/split.h index 5e03d89344..bc46d9e64c 100644 --- a/util/string/split.h +++ b/util/string/split.h @@ -3,24 +3,24 @@ #include "strspn.h" #include "cast.h" -#include <util/generic/algorithm.h> +#include <util/generic/algorithm.h> #include <util/generic/fwd.h> -#include <util/generic/iterator.h> -#include <util/generic/iterator_range.h> -#include <util/generic/store_policy.h> -#include <util/generic/strbuf.h> +#include <util/generic/iterator.h> +#include <util/generic/iterator_range.h> +#include <util/generic/store_policy.h> +#include <util/generic/strbuf.h> #include <util/generic/string.h> #include <util/generic/typetraits.h> -#include <util/generic/vector.h> +#include <util/generic/vector.h> #include <util/generic/ylimits.h> -#include <util/system/compat.h> -#include <util/system/defaults.h> +#include <util/system/compat.h> +#include <util/system/defaults.h> -#include <utility> -#include <stlfwd> +#include <utility> +#include <stlfwd> + +// NOTE: Check StringSplitter below to get more convenient split string interface. -// NOTE: Check StringSplitter below to get more convenient split string interface. - namespace NStringSplitPrivate { template <class T, class I, class = void> @@ -420,7 +420,7 @@ inline size_t Split(const TStringBuf s, const TSetDelimiter<const char>& delim, res.clear(); TContainerConsumer<TVector<TStringBuf>> res1(&res); TSkipEmptyTokens<TContainerConsumer<TVector<TStringBuf>>> consumer(&res1); - SplitString(s.data(), s.data() + s.size(), delim, consumer); + SplitString(s.data(), s.data() + s.size(), delim, consumer); return res.size(); } @@ -455,218 +455,218 @@ void Split(TStringBuf s, D delim, P1& p1, P2& p2, Other&... other) { GetNext(s, delim, p1); Split(s, delim, p2, other...); } - -/** - * \fn auto StringSplitter(...) - * - * Creates a string splitter object. The only use for it is to call one of its - * `Split*` methods, and then do something with the resulting proxy range. - * - * Some examples: - * \code - * TVector<TStringBuf> values = StringSplitter("1\t2\t3").Split('\t'); - * - * for(TStringBuf part: StringSplitter("1::2::::3").SplitByString("::").SkipEmpty()) { - * Cerr << part; - * } - * - * TVector<TString> firstTwoValues = StringSplitter("1\t2\t3").Split('\t').Take(2); - * \endcode - * - * Use `Collect` or `AddTo` to store split results into an existing container: - * \code - * TVector<TStringBuf> values = {"0"}; - * StringSplitter("1\t2\t3").Split('\t').AddTo(&values); - * \endcode - * Note that `Collect` clears target container, while `AddTo` just inserts values. - * You can use these methods with any container that has `emplace` / `emplace_back`. - * - * Use `ParseInto` to also perform string conversions before inserting values - * into target container: - * \code - * TSet<int> values; - * StringSplitter("1\t2\t3").Split('\t').ParseInto(&values); - * \endcode - */ - + +/** + * \fn auto StringSplitter(...) + * + * Creates a string splitter object. The only use for it is to call one of its + * `Split*` methods, and then do something with the resulting proxy range. + * + * Some examples: + * \code + * TVector<TStringBuf> values = StringSplitter("1\t2\t3").Split('\t'); + * + * for(TStringBuf part: StringSplitter("1::2::::3").SplitByString("::").SkipEmpty()) { + * Cerr << part; + * } + * + * TVector<TString> firstTwoValues = StringSplitter("1\t2\t3").Split('\t').Take(2); + * \endcode + * + * Use `Collect` or `AddTo` to store split results into an existing container: + * \code + * TVector<TStringBuf> values = {"0"}; + * StringSplitter("1\t2\t3").Split('\t').AddTo(&values); + * \endcode + * Note that `Collect` clears target container, while `AddTo` just inserts values. + * You can use these methods with any container that has `emplace` / `emplace_back`. + * + * Use `ParseInto` to also perform string conversions before inserting values + * into target container: + * \code + * TSet<int> values; + * StringSplitter("1\t2\t3").Split('\t').ParseInto(&values); + * \endcode + */ + namespace NStringSplitPrivate { - Y_HAS_MEMBER(push_back, PushBack); - Y_HAS_MEMBER(insert, Insert); - Y_HAS_MEMBER(data, Data); - - /** - * This one is needed here so that `std::string_view -> std::string_view` - * conversion works. - */ + Y_HAS_MEMBER(push_back, PushBack); + Y_HAS_MEMBER(insert, Insert); + Y_HAS_MEMBER(data, Data); + + /** + * This one is needed here so that `std::string_view -> std::string_view` + * conversion works. + */ template <class Src, class Dst> - inline void DoFromString(const Src& src, Dst* dst) { - *dst = ::FromString<Dst>(src); - } - + inline void DoFromString(const Src& src, Dst* dst) { + *dst = ::FromString<Dst>(src); + } + template <class T> - inline void DoFromString(const T& src, T* dst) noexcept { - *dst = src; - } - + inline void DoFromString(const T& src, T* dst) noexcept { + *dst = src; + } + template <class T> inline void DoFromString(const T& src, decltype(std::ignore)* dst) noexcept { *dst = src; } template <class Src, class Dst> - inline Y_WARN_UNUSED_RESULT bool TryDoFromString(const Src& src, Dst* dst) noexcept { - return ::TryFromString(src, *dst); - } - + inline Y_WARN_UNUSED_RESULT bool TryDoFromString(const Src& src, Dst* dst) noexcept { + return ::TryFromString(src, *dst); + } + template <class T> - inline Y_WARN_UNUSED_RESULT bool TryDoFromString(const T& src, T* dst) noexcept { - *dst = src; - return true; - } - + inline Y_WARN_UNUSED_RESULT bool TryDoFromString(const T& src, T* dst) noexcept { + *dst = src; + return true; + } + template <class T> inline Y_WARN_UNUSED_RESULT bool TryDoFromString(const T& src, decltype(std::ignore)* dst) noexcept { *dst = src; return true; } - /** - * Consumer that places provided elements into a container. Not using - * `emplace(iterator)` for efficiency. - */ - template <class Container> - struct TContainerConsumer { - using value_type = typename Container::value_type; - - TContainerConsumer(Container* c) - : C_(c) - { - } - - // TODO: return bool (continue) + /** + * Consumer that places provided elements into a container. Not using + * `emplace(iterator)` for efficiency. + */ + template <class Container> + struct TContainerConsumer { + using value_type = typename Container::value_type; + + TContainerConsumer(Container* c) + : C_(c) + { + } + + // TODO: return bool (continue) template <class StringBuf> - void operator()(StringBuf e) const { - this->operator()(C_, e); - } - - private: + void operator()(StringBuf e) const { + this->operator()(C_, e); + } + + private: template <class OtherContainer, class StringBuf> - auto operator()(OtherContainer* c, StringBuf e) const -> decltype(c->emplace_back()) { - return c->emplace_back(value_type(e)); - } - + auto operator()(OtherContainer* c, StringBuf e) const -> decltype(c->emplace_back()) { + return c->emplace_back(value_type(e)); + } + template <class OtherContainer, class StringBuf> - auto operator()(OtherContainer* c, StringBuf e) const -> decltype(c->emplace()) { - return c->emplace(value_type(e)); - } - - Container* C_; - }; - - /** - * Consumer that converts provided elements via `FromString` and places them - * into a container. - */ - template <class Container> - struct TContainerConvertingConsumer { - using value_type = typename Container::value_type; - - TContainerConvertingConsumer(Container* c) - : C_(c) - { - } - - template <class StringBuf> - void operator()(StringBuf e) const { - this->operator()(C_, e); - } - - private: + auto operator()(OtherContainer* c, StringBuf e) const -> decltype(c->emplace()) { + return c->emplace(value_type(e)); + } + + Container* C_; + }; + + /** + * Consumer that converts provided elements via `FromString` and places them + * into a container. + */ + template <class Container> + struct TContainerConvertingConsumer { + using value_type = typename Container::value_type; + + TContainerConvertingConsumer(Container* c) + : C_(c) + { + } + + template <class StringBuf> + void operator()(StringBuf e) const { + this->operator()(C_, e); + } + + private: template <class OtherContainer, class StringBuf> - auto operator()(OtherContainer* c, StringBuf e) const -> decltype(c->emplace_back()) { - value_type v; - DoFromString(e, &v); - return c->emplace_back(std::move(v)); - } - + auto operator()(OtherContainer* c, StringBuf e) const -> decltype(c->emplace_back()) { + value_type v; + DoFromString(e, &v); + return c->emplace_back(std::move(v)); + } + template <class OtherContainer, class StringBuf> - auto operator()(OtherContainer* c, StringBuf e) const -> decltype(c->emplace()) { - value_type v; - DoFromString(e, &v); - return c->emplace(std::move(v)); - } - - Container* C_; - }; - - template <class String> - struct TStringBufOfImpl { - using type = std::conditional_t< - THasData<String>::value, - TBasicStringBuf<typename String::value_type>, + auto operator()(OtherContainer* c, StringBuf e) const -> decltype(c->emplace()) { + value_type v; + DoFromString(e, &v); + return c->emplace(std::move(v)); + } + + Container* C_; + }; + + template <class String> + struct TStringBufOfImpl { + using type = std::conditional_t< + THasData<String>::value, + TBasicStringBuf<typename String::value_type>, TIteratorRange<typename String::const_iterator>>; - }; - - template <class Char, class Traits, class Allocator> - struct TStringBufOfImpl<std::basic_string<Char, Traits, Allocator>> { - using type = std::basic_string_view<Char, Traits>; - }; - - template <class Char, class Traits> - struct TStringBufOfImpl<std::basic_string_view<Char, Traits>> { - using type = std::basic_string_view<Char, Traits>; - }; - - /** - * Metafunction that returns a string buffer for the given type. This is to - * make sure that splitting `std::string` returns `std::string_view`. - */ + }; + + template <class Char, class Traits, class Allocator> + struct TStringBufOfImpl<std::basic_string<Char, Traits, Allocator>> { + using type = std::basic_string_view<Char, Traits>; + }; + + template <class Char, class Traits> + struct TStringBufOfImpl<std::basic_string_view<Char, Traits>> { + using type = std::basic_string_view<Char, Traits>; + }; + + /** + * Metafunction that returns a string buffer for the given type. This is to + * make sure that splitting `std::string` returns `std::string_view`. + */ template <class String> - using TStringBufOf = typename TStringBufOfImpl<String>::type; - + using TStringBufOf = typename TStringBufOfImpl<String>::type; + template <class StringBuf, class Iterator> - StringBuf DoMakeStringBuf(Iterator b, Iterator e, StringBuf*) { - return StringBuf(b, e); - } - + StringBuf DoMakeStringBuf(Iterator b, Iterator e, StringBuf*) { + return StringBuf(b, e); + } + template <class Char, class Traits, class Iterator> - std::basic_string_view<Char, Traits> DoMakeStringBuf(Iterator b, Iterator e, std::basic_string_view<Char, Traits>*) { - return std::basic_string_view<Char, Traits>(b, e - b); - } - + std::basic_string_view<Char, Traits> DoMakeStringBuf(Iterator b, Iterator e, std::basic_string_view<Char, Traits>*) { + return std::basic_string_view<Char, Traits>(b, e - b); + } + template <class StringBuf, class Iterator> - StringBuf MakeStringBuf(Iterator b, Iterator e) { - return DoMakeStringBuf(b, e, static_cast<StringBuf*>(nullptr)); - } - + StringBuf MakeStringBuf(Iterator b, Iterator e) { + return DoMakeStringBuf(b, e, static_cast<StringBuf*>(nullptr)); + } + template <class String> - struct TIteratorOfImpl { - using type = std::conditional_t< - THasData<String>::value, - const typename String::value_type*, + struct TIteratorOfImpl { + using type = std::conditional_t< + THasData<String>::value, + const typename String::value_type*, typename String::const_iterator>; - }; - + }; + template <class String> - using TIteratorOf = typename TIteratorOfImpl<String>::type; - + using TIteratorOf = typename TIteratorOfImpl<String>::type; + template <class String> class TStringSplitter; template <class String> struct TIterState: public TStringBufOf<String> { public: - using TStringBufType = TStringBufOf<String>; - using TIterator = TIteratorOf<String>; + using TStringBufType = TStringBufOf<String>; + using TIterator = TIteratorOf<String>; friend class TStringSplitter<String>; - - TIterState(const String& string) noexcept + + TIterState(const String& string) noexcept : TStringBufType() , DelimiterEnd_(std::begin(string)) , OriginEnd_(std::end(string)) - { - } - + { + } + template < typename Other, typename = std::enable_if_t< @@ -675,397 +675,397 @@ namespace NStringSplitPrivate { return TStringBufType(*this) == TStringBufType(toCompare); } - TIterator TokenStart() const noexcept { + TIterator TokenStart() const noexcept { return this->begin(); - } - - TIterator TokenDelim() const noexcept { + } + + TIterator TokenDelim() const noexcept { return this->end(); - } - - TStringBufType Token() const noexcept { + } + + TStringBufType Token() const noexcept { return *this; - } - - TStringBufType Delim() const noexcept { + } + + TStringBufType Delim() const noexcept { return MakeStringBuf<TStringBufType>(TokenDelim(), DelimiterEnd_); - } - - private: + } + + private: void UpdateParentBuf(TIterator tokenStart, TIterator tokenDelim) noexcept { *static_cast<TStringBufType*>(this) = MakeStringBuf<TStringBufType>(tokenStart, tokenDelim); - } - + } + bool DelimiterIsEmpty() const noexcept { return TokenDelim() == DelimiterEnd_; - } + } private: TIterator DelimiterEnd_; const TIterator OriginEnd_; - }; - - template <class Base> + }; + + template <class Base> class TSplitRange: public Base, public TInputRangeAdaptor<TSplitRange<Base>> { - using TStringBufType = decltype(std::declval<Base>().Next()->Token()); - - public: - template <typename... Args> - inline TSplitRange(Args&&... args) - : Base(std::forward<Args>(args)...) - { - } - - template <class Consumer, std::enable_if_t<std::is_same<decltype(std::declval<Consumer>()(std::declval<TStringBufType>())), void>::value, int>* = nullptr> - inline void Consume(Consumer&& f) { - for (auto&& it : *this) { - f(it.Token()); - } - } - - template <class Consumer, std::enable_if_t<std::is_same<decltype(std::declval<Consumer>()(std::declval<TStringBufType>())), bool>::value, int>* = nullptr> - inline bool Consume(Consumer&& f) { - for (auto&& it : *this) { - if (!f(it.Token())) { - return false; - } - } - return true; - } - + using TStringBufType = decltype(std::declval<Base>().Next()->Token()); + + public: + template <typename... Args> + inline TSplitRange(Args&&... args) + : Base(std::forward<Args>(args)...) + { + } + + template <class Consumer, std::enable_if_t<std::is_same<decltype(std::declval<Consumer>()(std::declval<TStringBufType>())), void>::value, int>* = nullptr> + inline void Consume(Consumer&& f) { + for (auto&& it : *this) { + f(it.Token()); + } + } + + template <class Consumer, std::enable_if_t<std::is_same<decltype(std::declval<Consumer>()(std::declval<TStringBufType>())), bool>::value, int>* = nullptr> + inline bool Consume(Consumer&& f) { + for (auto&& it : *this) { + if (!f(it.Token())) { + return false; + } + } + return true; + } + template <class Container, class = std::enable_if_t<THasInsert<Container>::value || THasPushBack<Container>::value>> - operator Container() { - Container result; - AddTo(&result); - return result; - } - - template <class S> - inline TVector<S> ToList() { - TVector<S> result; - for (auto&& it : *this) { - result.push_back(S(it.Token())); - } - return result; - } - - template <class Container> - inline void Collect(Container* c) { - Y_ASSERT(c); - c->clear(); - AddTo(c); - } - - template <class Container> - inline void AddTo(Container* c) { - Y_ASSERT(c); - TContainerConsumer<Container> consumer(c); - Consume(consumer); - } - - template <class Container> - inline void ParseInto(Container* c) { - Y_ASSERT(c); - TContainerConvertingConsumer<Container> consumer(c); - Consume(consumer); - } - - // TODO: this is actually TryParseInto - /** - * Same as `CollectInto`, just doesn't throw. - * - * \param[out] args Output arguments. - * \returns Whether parsing was successful. - */ - template <typename... Args> - inline bool TryCollectInto(Args*... args) noexcept { - size_t successfullyFilled = 0; - auto it = this->begin(); - - //FIXME: actually, some kind of TryApplyToMany is needed in order to stop iteration upon first failure - ApplyToMany([&](auto&& arg) { - if (it != this->end()) { - if (TryDoFromString(it->Token(), arg)) { - ++successfullyFilled; - } - ++it; - } + operator Container() { + Container result; + AddTo(&result); + return result; + } + + template <class S> + inline TVector<S> ToList() { + TVector<S> result; + for (auto&& it : *this) { + result.push_back(S(it.Token())); + } + return result; + } + + template <class Container> + inline void Collect(Container* c) { + Y_ASSERT(c); + c->clear(); + AddTo(c); + } + + template <class Container> + inline void AddTo(Container* c) { + Y_ASSERT(c); + TContainerConsumer<Container> consumer(c); + Consume(consumer); + } + + template <class Container> + inline void ParseInto(Container* c) { + Y_ASSERT(c); + TContainerConvertingConsumer<Container> consumer(c); + Consume(consumer); + } + + // TODO: this is actually TryParseInto + /** + * Same as `CollectInto`, just doesn't throw. + * + * \param[out] args Output arguments. + * \returns Whether parsing was successful. + */ + template <typename... Args> + inline bool TryCollectInto(Args*... args) noexcept { + size_t successfullyFilled = 0; + auto it = this->begin(); + + //FIXME: actually, some kind of TryApplyToMany is needed in order to stop iteration upon first failure + ApplyToMany([&](auto&& arg) { + if (it != this->end()) { + if (TryDoFromString(it->Token(), arg)) { + ++successfullyFilled; + } + ++it; + } }, args...); - - return successfullyFilled == sizeof...(args) && it == this->end(); - } - - // TODO: this is actually ParseInto - /** - * Splits and parses everything that's in this splitter into `args`. - * - * Example usage: - * \code - * int l, r; - * StringSplitter("100*200").Split('*').CollectInto(&l, &r); - * \endcode - * - * \param[out] args Output arguments. - * \throws If not all items were parsed, or - * if there were too many items in the split. - */ - template <typename... Args> - inline void CollectInto(Args*... args) { - Y_ENSURE(TryCollectInto<Args...>(args...)); - } - - inline size_t Count() const { - size_t cnt = 0; - for (auto&& it : *this) { - Y_UNUSED(it); - ++cnt; - } - return cnt; - } - }; - - template <class String> - class TStringSplitter { - using TStringType = String; - using TChar = typename TStringType::value_type; - using TIteratorState = TIterState<TStringType>; + + return successfullyFilled == sizeof...(args) && it == this->end(); + } + + // TODO: this is actually ParseInto + /** + * Splits and parses everything that's in this splitter into `args`. + * + * Example usage: + * \code + * int l, r; + * StringSplitter("100*200").Split('*').CollectInto(&l, &r); + * \endcode + * + * \param[out] args Output arguments. + * \throws If not all items were parsed, or + * if there were too many items in the split. + */ + template <typename... Args> + inline void CollectInto(Args*... args) { + Y_ENSURE(TryCollectInto<Args...>(args...)); + } + + inline size_t Count() const { + size_t cnt = 0; + for (auto&& it : *this) { + Y_UNUSED(it); + ++cnt; + } + return cnt; + } + }; + + template <class String> + class TStringSplitter { + using TStringType = String; + using TChar = typename TStringType::value_type; + using TIteratorState = TIterState<TStringType>; using TStringBufType = typename TIteratorState::TStringBufType; using TIterator = typename TIteratorState::TIterator; - - /** - * Base class for all split ranges that actually does the splitting. - */ - template <class DelimStorage> - struct TSplitRangeBase { - template <class OtherString, class... Args> - inline TSplitRangeBase(OtherString&& s, Args&&... args) - : String_(std::forward<OtherString>(s)) - , State_(String_) + + /** + * Base class for all split ranges that actually does the splitting. + */ + template <class DelimStorage> + struct TSplitRangeBase { + template <class OtherString, class... Args> + inline TSplitRangeBase(OtherString&& s, Args&&... args) + : String_(std::forward<OtherString>(s)) + , State_(String_) , Delimiter_(std::forward<Args>(args)...) - { - } - - inline TIteratorState* Next() { + { + } + + inline TIteratorState* Next() { if (State_.DelimiterIsEmpty()) { - return nullptr; - } - + return nullptr; + } + const auto tokenBegin = State_.DelimiterEnd_; const auto tokenEnd = Delimiter_.Ptr()->Find(State_.DelimiterEnd_, State_.OriginEnd_); State_.UpdateParentBuf(tokenBegin, tokenEnd); - - return &State_; - } - - private: - TStringType String_; - TIteratorState State_; + + return &State_; + } + + private: + TStringType String_; + TIteratorState State_; DelimStorage Delimiter_; - }; - - template <class Base, class Filter> + }; + + template <class Base, class Filter> struct TFilterRange: public Base { - template <class... Args> - inline TFilterRange(const Base& base, Args&&... args) - : Base(base) - , Filter_(std::forward<Args>(args)...) - { - } - - inline TIteratorState* Next() { - TIteratorState* ret; - - do { - ret = Base::Next(); - } while (ret && !Filter_.Accept(ret)); - - return ret; - } - - Filter Filter_; - }; - - struct TNonEmptyFilter { - template <class TToken> - inline bool Accept(const TToken* token) noexcept { + template <class... Args> + inline TFilterRange(const Base& base, Args&&... args) + : Base(base) + , Filter_(std::forward<Args>(args)...) + { + } + + inline TIteratorState* Next() { + TIteratorState* ret; + + do { + ret = Base::Next(); + } while (ret && !Filter_.Accept(ret)); + + return ret; + } + + Filter Filter_; + }; + + struct TNonEmptyFilter { + template <class TToken> + inline bool Accept(const TToken* token) noexcept { return !token->empty(); - } - }; - - template <class TIter> - struct TStopIteration; - - template <class Base> + } + }; + + template <class TIter> + struct TStopIteration; + + template <class Base> struct TFilters: public Base { - template <class TFilter> - using TIt = TSplitRange<TStopIteration<TFilters<TFilterRange<Base, TFilter>>>>; - - template <typename... Args> - inline TFilters(Args&&... args) - : Base(std::forward<Args>(args)...) - { - } - - inline TIt<TNonEmptyFilter> SkipEmpty() const { + template <class TFilter> + using TIt = TSplitRange<TStopIteration<TFilters<TFilterRange<Base, TFilter>>>>; + + template <typename... Args> + inline TFilters(Args&&... args) + : Base(std::forward<Args>(args)...) + { + } + + inline TIt<TNonEmptyFilter> SkipEmpty() const { return {*this}; - } - }; - - template <class Base, class Stopper> + } + }; + + template <class Base, class Stopper> struct TStopRange: public Base { - template <typename... Args> - inline TStopRange(const Base& base, Args&&... args) - : Base(base) - , Stopper_(std::forward<Args>(args)...) - { - } - - inline TIteratorState* Next() { - TIteratorState* ret = Base::Next(); - if (!ret || Stopper_.Stop(ret)) { - return nullptr; - } - return ret; - } - - Stopper Stopper_; - }; - - struct TTake { - TTake() = default; - - TTake(size_t count) - : Count(count) - { - } - - template <class TToken> - inline bool Stop(TToken*) noexcept { - if (Count > 0) { - --Count; - return false; - } else { - return true; - } - } - - size_t Count = 0; - }; - - struct TLimit { - TLimit() = default; - - TLimit(size_t count) - : Count(count) - { - Y_ASSERT(Count > 0); - } - - template <class TToken> - inline bool Stop(TToken* token) noexcept { - if (Count > 1) { - --Count; - return false; - } else if (Count == 1) { + template <typename... Args> + inline TStopRange(const Base& base, Args&&... args) + : Base(base) + , Stopper_(std::forward<Args>(args)...) + { + } + + inline TIteratorState* Next() { + TIteratorState* ret = Base::Next(); + if (!ret || Stopper_.Stop(ret)) { + return nullptr; + } + return ret; + } + + Stopper Stopper_; + }; + + struct TTake { + TTake() = default; + + TTake(size_t count) + : Count(count) + { + } + + template <class TToken> + inline bool Stop(TToken*) noexcept { + if (Count > 0) { + --Count; + return false; + } else { + return true; + } + } + + size_t Count = 0; + }; + + struct TLimit { + TLimit() = default; + + TLimit(size_t count) + : Count(count) + { + Y_ASSERT(Count > 0); + } + + template <class TToken> + inline bool Stop(TToken* token) noexcept { + if (Count > 1) { + --Count; + return false; + } else if (Count == 1) { token->DelimiterEnd_ = token->OriginEnd_; token->UpdateParentBuf(token->TokenStart(), token->DelimiterEnd_); - return false; - } - return true; - } - - size_t Count = 0; - }; - - template <class Base> + return false; + } + return true; + } + + size_t Count = 0; + }; + + template <class Base> struct TStopIteration: public Base { - template <class TStopper> - using TIt = TSplitRange<TStopIteration<TFilters<TStopRange<Base, TStopper>>>>; - - template <typename... Args> - inline TStopIteration(Args&&... args) - : Base(std::forward<Args>(args)...) - { - } - - inline TIt<TTake> Take(size_t count) { + template <class TStopper> + using TIt = TSplitRange<TStopIteration<TFilters<TStopRange<Base, TStopper>>>>; + + template <typename... Args> + inline TStopIteration(Args&&... args) + : Base(std::forward<Args>(args)...) + { + } + + inline TIt<TTake> Take(size_t count) { return {*this, count}; - } - - inline TIt<TLimit> Limit(size_t count) { + } + + inline TIt<TLimit> Limit(size_t count) { return {*this, count}; - } - }; - - template <class TPolicy> - using TIt = TSplitRange<TStopIteration<TFilters<TSplitRangeBase<TPolicy>>>>; - - public: + } + }; + + template <class TPolicy> + using TIt = TSplitRange<TStopIteration<TFilters<TSplitRangeBase<TPolicy>>>>; + + public: template <class OtherString> - explicit TStringSplitter(OtherString&& s) - : String_(std::forward<OtherString>(s)) - { - } - - //does not own TDelim - template <class TDelim> - inline TIt<TPtrPolicy<const TDelim>> Split(const TDelim& d) const noexcept { + explicit TStringSplitter(OtherString&& s) + : String_(std::forward<OtherString>(s)) + { + } + + //does not own TDelim + template <class TDelim> + inline TIt<TPtrPolicy<const TDelim>> Split(const TDelim& d) const noexcept { return {String_, &d}; - } - - inline TIt<TEmbedPolicy<TCharDelimiter<const TChar>>> Split(TChar ch) const noexcept { + } + + inline TIt<TEmbedPolicy<TCharDelimiter<const TChar>>> Split(TChar ch) const noexcept { return {String_, ch}; - } - - inline TIt<TSimpleRefPolicy<TSetDelimiter<const TChar>>> SplitBySet(const TChar* set) const noexcept { + } + + inline TIt<TSimpleRefPolicy<TSetDelimiter<const TChar>>> SplitBySet(const TChar* set) const noexcept { return {String_, set}; - } - - inline TIt<TEmbedPolicy<TStringDelimiter<const TChar>>> SplitByString(const TStringBufType& str) const noexcept { + } + + inline TIt<TEmbedPolicy<TStringDelimiter<const TChar>>> SplitByString(const TStringBufType& str) const noexcept { return {String_, str.data(), str.size()}; - } - - template <class TFunc> - inline TIt<TEmbedPolicy<TFuncDelimiter<TIterator, TFunc>>> SplitByFunc(TFunc f) const noexcept { + } + + template <class TFunc> + inline TIt<TEmbedPolicy<TFuncDelimiter<TIterator, TFunc>>> SplitByFunc(TFunc f) const noexcept { return {String_, f}; - } - - private: - TStringType String_; - }; - + } + + private: + TStringType String_; + }; + template <class String> - auto MakeStringSplitter(String&& s) { - return TStringSplitter<std::remove_reference_t<String>>(std::forward<String>(s)); - } -} - -template <class Iterator> -auto StringSplitter(Iterator begin, Iterator end) { + auto MakeStringSplitter(String&& s) { + return TStringSplitter<std::remove_reference_t<String>>(std::forward<String>(s)); + } +} + +template <class Iterator> +auto StringSplitter(Iterator begin, Iterator end) { return ::NStringSplitPrivate::MakeStringSplitter(TIteratorRange<Iterator>(begin, end)); -} - -template <class Char> -auto StringSplitter(const Char* begin, const Char* end) { +} + +template <class Char> +auto StringSplitter(const Char* begin, const Char* end) { return ::NStringSplitPrivate::MakeStringSplitter(TBasicStringBuf<Char>(begin, end)); -} - -template <class Char> -auto StringSplitter(const Char* begin, size_t len) { +} + +template <class Char> +auto StringSplitter(const Char* begin, size_t len) { return ::NStringSplitPrivate::MakeStringSplitter(TBasicStringBuf<Char>(begin, len)); -} - -template <class Char> -auto StringSplitter(const Char* str) { +} + +template <class Char> +auto StringSplitter(const Char* str) { return ::NStringSplitPrivate::MakeStringSplitter(TBasicStringBuf<Char>(str)); -} - -template <class String, std::enable_if_t<!std::is_pointer<std::remove_reference_t<String>>::value, int> = 0> -auto StringSplitter(String& s) { +} + +template <class String, std::enable_if_t<!std::is_pointer<std::remove_reference_t<String>>::value, int> = 0> +auto StringSplitter(String& s) { return ::NStringSplitPrivate::MakeStringSplitter(::NStringSplitPrivate::TStringBufOf<String>(s.data(), s.size())); -} - -template <class String, std::enable_if_t<!std::is_pointer<std::remove_reference_t<String>>::value, int> = 0> -auto StringSplitter(String&& s) { +} + +template <class String, std::enable_if_t<!std::is_pointer<std::remove_reference_t<String>>::value, int> = 0> +auto StringSplitter(String&& s) { return ::NStringSplitPrivate::MakeStringSplitter(std::move(s)); -} +} diff --git a/util/string/split_ut.cpp b/util/string/split_ut.cpp index f8cd78cb88..43e59f2d75 100644 --- a/util/string/split_ut.cpp +++ b/util/string/split_ut.cpp @@ -7,9 +7,9 @@ #include <util/datetime/cputimer.h> #include <util/generic/maybe.h> -#include <string> -#include <string_view> - +#include <string> +#include <string_view> + template <typename T> static inline void OldSplit(char* pszBuf, T* pRes) { pRes->resize(0); @@ -126,8 +126,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TVector<TString> good(canonic, canonic + 4); TCharDelimiter<const char> delim(' '); - TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); - TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); + TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); + TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); } Y_UNIT_TEST(TestWideSingleDelimiter) { @@ -136,8 +136,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TVector<TUtf16String> good(canonic, canonic + 4); TCharDelimiter<const wchar16> delim(' '); - TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); - TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); + TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); + TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); } Y_UNIT_TEST(TestConvertToIntCharSingleDelimiter) { @@ -146,8 +146,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TVector<i32> good(canonic, canonic + 4); TCharDelimiter<const char> delim(' '); - TestDelimiterOnString<TContainerConvertingConsumer>(good, data.data(), delim); - TestDelimiterOnRange<TContainerConvertingConsumer>(good, data.data(), data.end(), delim); + TestDelimiterOnString<TContainerConvertingConsumer>(good, data.data(), delim); + TestDelimiterOnRange<TContainerConvertingConsumer>(good, data.data(), data.end(), delim); } Y_UNIT_TEST(TestCharSkipEmpty) { @@ -155,8 +155,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TString canonic[] = {"qw", "ab", "qwabcab"}; TVector<TString> good(canonic, canonic + 3); - TestConsumerOnString<TSkipEmptyTokens<TStrokaConsumer>>(good, data.data(), " "); - TestConsumerOnRange<TSkipEmptyTokens<TStrokaConsumer>>(good, data.data(), data.end(), " "); + TestConsumerOnString<TSkipEmptyTokens<TStrokaConsumer>>(good, data.data(), " "); + TestConsumerOnRange<TSkipEmptyTokens<TStrokaConsumer>>(good, data.data(), data.end(), " "); } Y_UNIT_TEST(TestCharKeepDelimiters) { @@ -164,8 +164,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TString canonic[] = {"qw", " ", "ab", " ", "", " ", "qwabcab", " ", ""}; TVector<TString> good(canonic, canonic + 9); - TestConsumerOnString<TKeepDelimiters<TStrokaConsumer>>(good, data.data(), " "); - TestConsumerOnRange<TKeepDelimiters<TStrokaConsumer>>(good, data.data(), data.end(), " "); + TestConsumerOnString<TKeepDelimiters<TStrokaConsumer>>(good, data.data(), " "); + TestConsumerOnRange<TKeepDelimiters<TStrokaConsumer>>(good, data.data(), data.end(), " "); } Y_UNIT_TEST(TestCharLimit) { @@ -173,8 +173,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TString canonic[] = {"qw", "ab"}; TVector<TString> good(canonic, canonic + 2); - TestLimitingConsumerOnString(good, data.data(), " ", 3, " qwabcab "); - TestLimitingConsumerOnRange(good, data.data(), data.end(), " ", 3, " qwabcab "); + TestLimitingConsumerOnString(good, data.data(), " ", 3, " qwabcab "); + TestLimitingConsumerOnRange(good, data.data(), data.end(), " ", 3, " qwabcab "); } Y_UNIT_TEST(TestCharStringDelimiter) { @@ -183,8 +183,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TVector<TString> good(canonic, canonic + 5); TStringDelimiter<const char> delim("ab"); - TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); - TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); + TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); + TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); } Y_UNIT_TEST(TestWideStringDelimiter) { @@ -194,8 +194,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TUtf16String wideDelim(u"ab"); TStringDelimiter<const wchar16> delim(wideDelim.data()); - TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); - TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); + TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); + TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); } Y_UNIT_TEST(TestCharSetDelimiter) { @@ -204,8 +204,8 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TVector<TString> good(canonic, canonic + 5); TSetDelimiter<const char> delim("wc"); - TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); - TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); + TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); + TestDelimiterOnRange<TContainerConsumer>(good, data.data(), data.end(), delim); } Y_UNIT_TEST(TestWideSetDelimiter) { @@ -215,7 +215,7 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TUtf16String wideDelim(u"wc"); TSetDelimiter<const wchar16> delim(wideDelim.data()); - TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); + TestDelimiterOnString<TContainerConsumer>(good, data.data(), delim); } Y_UNIT_TEST(TestWideSetDelimiterRange) { @@ -227,18 +227,18 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { TVector<TUtf16String> test; TContainerConsumer<TVector<TUtf16String>> consumer(&test); - SplitString(data.data(), data.data(), delim, consumer); // Empty string is still inserted into consumer + SplitString(data.data(), data.data(), delim, consumer); // Empty string is still inserted into consumer Cmp(good, test); good.assign(canonic, canonic + 4); good.push_back(TUtf16String()); test.clear(); - SplitString(data.data(), data.end() - 2, delim, consumer); + SplitString(data.data(), data.end() - 2, delim, consumer); Cmp(good, test); } Y_UNIT_TEST(TestSplit) { - TString data("qw ab qwababcba"); + TString data("qw ab qwababcba"); TString canonic[] = {"qw ", " qw", "c"}; TVector<TString> good(canonic, canonic + 3); TString delim = "ab"; @@ -247,7 +247,7 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { Cmp(good, test); TVector<TStringBuf> test1; - Split(data, delim.data(), test1); + Split(data, delim.data(), test1); Cmp(good, test1); } @@ -302,263 +302,263 @@ Y_UNIT_TEST_SUITE(SplitStringTest) { UNIT_ASSERT_EXCEPTION(Split(data, ' ', s1, s2, m1, m2, m1, m1, m1, m1, s1), yexception); } } - -template <typename I, typename C> -void TestStringSplitterCount(I* str, C delim, size_t good) { - size_t res = StringSplitter(str).Split(delim).Count(); - UNIT_ASSERT_VALUES_EQUAL(res, good); -} - -Y_UNIT_TEST_SUITE(StringSplitter) { - Y_UNIT_TEST(TestSplit) { - int sum = 0; - - for (const auto& it : StringSplitter("1,2,3").Split(',')) { - sum += FromString<int>(it.Token()); - } - - UNIT_ASSERT_VALUES_EQUAL(sum, 6); - } - - Y_UNIT_TEST(TestSplit1) { - int cnt = 0; - - for (const auto& it : StringSplitter(" ").Split(' ')) { - (void)it; - - ++cnt; - } - - UNIT_ASSERT_VALUES_EQUAL(cnt, 2); - } - - Y_UNIT_TEST(TestSplitLimited) { - TVector<TString> expected = {"1", "2", "3,4,5"}; - TVector<TString> actual = StringSplitter("1,2,3,4,5").Split(',').Limit(3).ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestSplitLimitedWithEmptySkip) { - TVector<TString> expected = {"1", "2", "3,4,5"}; - TVector<TString> actual = StringSplitter("1,,,2,,,,3,4,5").Split(',').SkipEmpty().Limit(3).ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - - expected = {"1", "2", ",,,3,4,5"}; - actual = StringSplitter("1,2,,,,3,4,5").Split(',').Limit(3).SkipEmpty().ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestSplitBySet) { - int sum = 0; - - for (const auto& it : StringSplitter("1,2:3").SplitBySet(",:")) { - sum += FromString<int>(it.Token()); - } - - UNIT_ASSERT_VALUES_EQUAL(sum, 6); - } - - Y_UNIT_TEST(TestSplitBySetLimited) { - TVector<TString> expected = {"1", "2", "3,4:5"}; - TVector<TString> actual = StringSplitter("1,2:3,4:5").SplitBySet(",:").Limit(3).ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestSplitBySetLimitedWithEmptySkip) { - TVector<TString> expected = {"1", "2", "3,4:5"}; - TVector<TString> actual = StringSplitter("1,:,2::::,3,4:5").SplitBySet(",:").SkipEmpty().Limit(3).ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - - expected = {"1", ",2::::,3,4:5"}; - actual = StringSplitter("1,:,2::::,3,4:5").SplitBySet(",:").Limit(3).SkipEmpty().ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestSplitByString) { - int sum = 0; - - for (const auto& it : StringSplitter("1ab2ab3").SplitByString("ab")) { - sum += FromString<int>(it.Token()); - } - - UNIT_ASSERT_VALUES_EQUAL(sum, 6); - } - - Y_UNIT_TEST(TestSplitByStringLimited) { - TVector<TString> expected = {"1", "2", "3ab4ab5"}; - TVector<TString> actual = StringSplitter("1ab2ab3ab4ab5").SplitByString("ab").Limit(3).ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestSplitByStringLimitedWithEmptySkip) { - TVector<TString> expected = {"1", "2", "3ab4ab5"}; - TVector<TString> actual = StringSplitter("1abab2ababababab3ab4ab5").SplitByString("ab").SkipEmpty().Limit(3).ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestSplitByFunc) { - TString s = "123 456 \t\n789\n10\t 20"; - TVector<TString> pattern = {"123", "456", "789", "10", "20"}; - - TVector<TString> tokens; - auto f = [](char a) { return a == ' ' || a == '\t' || a == '\n'; }; - for (auto v : StringSplitter(s).SplitByFunc(f)) { + +template <typename I, typename C> +void TestStringSplitterCount(I* str, C delim, size_t good) { + size_t res = StringSplitter(str).Split(delim).Count(); + UNIT_ASSERT_VALUES_EQUAL(res, good); +} + +Y_UNIT_TEST_SUITE(StringSplitter) { + Y_UNIT_TEST(TestSplit) { + int sum = 0; + + for (const auto& it : StringSplitter("1,2,3").Split(',')) { + sum += FromString<int>(it.Token()); + } + + UNIT_ASSERT_VALUES_EQUAL(sum, 6); + } + + Y_UNIT_TEST(TestSplit1) { + int cnt = 0; + + for (const auto& it : StringSplitter(" ").Split(' ')) { + (void)it; + + ++cnt; + } + + UNIT_ASSERT_VALUES_EQUAL(cnt, 2); + } + + Y_UNIT_TEST(TestSplitLimited) { + TVector<TString> expected = {"1", "2", "3,4,5"}; + TVector<TString> actual = StringSplitter("1,2,3,4,5").Split(',').Limit(3).ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestSplitLimitedWithEmptySkip) { + TVector<TString> expected = {"1", "2", "3,4,5"}; + TVector<TString> actual = StringSplitter("1,,,2,,,,3,4,5").Split(',').SkipEmpty().Limit(3).ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + + expected = {"1", "2", ",,,3,4,5"}; + actual = StringSplitter("1,2,,,,3,4,5").Split(',').Limit(3).SkipEmpty().ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestSplitBySet) { + int sum = 0; + + for (const auto& it : StringSplitter("1,2:3").SplitBySet(",:")) { + sum += FromString<int>(it.Token()); + } + + UNIT_ASSERT_VALUES_EQUAL(sum, 6); + } + + Y_UNIT_TEST(TestSplitBySetLimited) { + TVector<TString> expected = {"1", "2", "3,4:5"}; + TVector<TString> actual = StringSplitter("1,2:3,4:5").SplitBySet(",:").Limit(3).ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestSplitBySetLimitedWithEmptySkip) { + TVector<TString> expected = {"1", "2", "3,4:5"}; + TVector<TString> actual = StringSplitter("1,:,2::::,3,4:5").SplitBySet(",:").SkipEmpty().Limit(3).ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + + expected = {"1", ",2::::,3,4:5"}; + actual = StringSplitter("1,:,2::::,3,4:5").SplitBySet(",:").Limit(3).SkipEmpty().ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestSplitByString) { + int sum = 0; + + for (const auto& it : StringSplitter("1ab2ab3").SplitByString("ab")) { + sum += FromString<int>(it.Token()); + } + + UNIT_ASSERT_VALUES_EQUAL(sum, 6); + } + + Y_UNIT_TEST(TestSplitByStringLimited) { + TVector<TString> expected = {"1", "2", "3ab4ab5"}; + TVector<TString> actual = StringSplitter("1ab2ab3ab4ab5").SplitByString("ab").Limit(3).ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestSplitByStringLimitedWithEmptySkip) { + TVector<TString> expected = {"1", "2", "3ab4ab5"}; + TVector<TString> actual = StringSplitter("1abab2ababababab3ab4ab5").SplitByString("ab").SkipEmpty().Limit(3).ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestSplitByFunc) { + TString s = "123 456 \t\n789\n10\t 20"; + TVector<TString> pattern = {"123", "456", "789", "10", "20"}; + + TVector<TString> tokens; + auto f = [](char a) { return a == ' ' || a == '\t' || a == '\n'; }; + for (auto v : StringSplitter(s).SplitByFunc(f)) { if (v) { - tokens.emplace_back(v); + tokens.emplace_back(v); } - } - - UNIT_ASSERT(tokens == pattern); - } - - Y_UNIT_TEST(TestSplitByFuncLimited) { - TVector<TString> expected = {"1", "2", "3a4b5"}; - auto f = [](char a) { return a == 'a' || a == 'b'; }; - TVector<TString> actual = StringSplitter("1a2b3a4b5").SplitByFunc(f).Limit(3).ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestSplitByFuncLimitedWithEmptySkip) { - TVector<TString> expected = {"1", "2", "3a4b5"}; - auto f = [](char a) { return a == 'a' || a == 'b'; }; - TVector<TString> actual = StringSplitter("1aaba2bbababa3a4b5").SplitByFunc(f).SkipEmpty().Limit(3).Take(3).ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestSkipEmpty) { - int sum = 0; - - for (const auto& it : StringSplitter(" 1 2 3 ").Split(' ').SkipEmpty()) { - sum += FromString<int>(it.Token()); - } - - UNIT_ASSERT_VALUES_EQUAL(sum, 6); - - // double - sum = 0; - for (const auto& it : StringSplitter(" 1 2 3 ").Split(' ').SkipEmpty().SkipEmpty()) { - sum += FromString<int>(it.Token()); - } - UNIT_ASSERT_VALUES_EQUAL(sum, 6); - } - - Y_UNIT_TEST(TestTake) { - TVector<TString> expected = {"1", "2", "3"}; - UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter("1 2 3 4 5 6 7 8 9 10").Split(' ').Take(3).ToList<TString>()); - - expected = {"1", "2"}; - UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter(" 1 2 3 ").Split(' ').SkipEmpty().Take(2).ToList<TString>()); - - expected = {"1", "2", "3"}; - UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter("1 2 3 4 5 6 7 8 9 10").Split(' ').Take(5).Take(3).ToList<TString>()); - UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter("1 2 3 4 5 6 7 8 9 10").Split(' ').Take(3).Take(5).ToList<TString>()); - - expected = {"1", "2"}; - UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter(" 1 2 3 ").Split(' ').Take(4).SkipEmpty().ToList<TString>()); - - expected = {"1"}; - UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter(" 1 2 3 ").Split(' ').Take(4).SkipEmpty().Take(1).ToList<TString>()); - } - - Y_UNIT_TEST(TestCompile) { + } + + UNIT_ASSERT(tokens == pattern); + } + + Y_UNIT_TEST(TestSplitByFuncLimited) { + TVector<TString> expected = {"1", "2", "3a4b5"}; + auto f = [](char a) { return a == 'a' || a == 'b'; }; + TVector<TString> actual = StringSplitter("1a2b3a4b5").SplitByFunc(f).Limit(3).ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestSplitByFuncLimitedWithEmptySkip) { + TVector<TString> expected = {"1", "2", "3a4b5"}; + auto f = [](char a) { return a == 'a' || a == 'b'; }; + TVector<TString> actual = StringSplitter("1aaba2bbababa3a4b5").SplitByFunc(f).SkipEmpty().Limit(3).Take(3).ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestSkipEmpty) { + int sum = 0; + + for (const auto& it : StringSplitter(" 1 2 3 ").Split(' ').SkipEmpty()) { + sum += FromString<int>(it.Token()); + } + + UNIT_ASSERT_VALUES_EQUAL(sum, 6); + + // double + sum = 0; + for (const auto& it : StringSplitter(" 1 2 3 ").Split(' ').SkipEmpty().SkipEmpty()) { + sum += FromString<int>(it.Token()); + } + UNIT_ASSERT_VALUES_EQUAL(sum, 6); + } + + Y_UNIT_TEST(TestTake) { + TVector<TString> expected = {"1", "2", "3"}; + UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter("1 2 3 4 5 6 7 8 9 10").Split(' ').Take(3).ToList<TString>()); + + expected = {"1", "2"}; + UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter(" 1 2 3 ").Split(' ').SkipEmpty().Take(2).ToList<TString>()); + + expected = {"1", "2", "3"}; + UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter("1 2 3 4 5 6 7 8 9 10").Split(' ').Take(5).Take(3).ToList<TString>()); + UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter("1 2 3 4 5 6 7 8 9 10").Split(' ').Take(3).Take(5).ToList<TString>()); + + expected = {"1", "2"}; + UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter(" 1 2 3 ").Split(' ').Take(4).SkipEmpty().ToList<TString>()); + + expected = {"1"}; + UNIT_ASSERT_VALUES_EQUAL(expected, StringSplitter(" 1 2 3 ").Split(' ').Take(4).SkipEmpty().Take(1).ToList<TString>()); + } + + Y_UNIT_TEST(TestCompile) { (void)StringSplitter(TString()); (void)StringSplitter(TStringBuf()); (void)StringSplitter("", 0); - } - - Y_UNIT_TEST(TestStringSplitterCountEmpty) { - TCharDelimiter<const char> delim(' '); - TestStringSplitterCount("", delim, 1); - } - - Y_UNIT_TEST(TestStringSplitterCountOne) { - TCharDelimiter<const char> delim(' '); - TestStringSplitterCount("one", delim, 1); - } - - Y_UNIT_TEST(TestStringSplitterCountWithOneDelimiter) { - TCharDelimiter<const char> delim(' '); - TestStringSplitterCount("one two", delim, 2); - } - - Y_UNIT_TEST(TestStringSplitterCountWithTrailing) { - TCharDelimiter<const char> delim(' '); - TestStringSplitterCount(" one ", delim, 3); - } - - Y_UNIT_TEST(TestStringSplitterConsume) { - TVector<TString> expected = {"1", "2", "3"}; - TVector<TString> actual; - auto func = [&actual](const TBasicStringBuf<char>& token) { - actual.push_back(TString(token)); - }; - StringSplitter("1 2 3").Split(' ').Consume(func); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestStringSplitterConsumeConditional) { + } + + Y_UNIT_TEST(TestStringSplitterCountEmpty) { + TCharDelimiter<const char> delim(' '); + TestStringSplitterCount("", delim, 1); + } + + Y_UNIT_TEST(TestStringSplitterCountOne) { + TCharDelimiter<const char> delim(' '); + TestStringSplitterCount("one", delim, 1); + } + + Y_UNIT_TEST(TestStringSplitterCountWithOneDelimiter) { + TCharDelimiter<const char> delim(' '); + TestStringSplitterCount("one two", delim, 2); + } + + Y_UNIT_TEST(TestStringSplitterCountWithTrailing) { + TCharDelimiter<const char> delim(' '); + TestStringSplitterCount(" one ", delim, 3); + } + + Y_UNIT_TEST(TestStringSplitterConsume) { + TVector<TString> expected = {"1", "2", "3"}; + TVector<TString> actual; + auto func = [&actual](const TBasicStringBuf<char>& token) { + actual.push_back(TString(token)); + }; + StringSplitter("1 2 3").Split(' ').Consume(func); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestStringSplitterConsumeConditional) { TVector<TString> expected = {"1", "2"}; - TVector<TString> actual; - auto func = [&actual](const TBasicStringBuf<char>& token) { + TVector<TString> actual; + auto func = [&actual](const TBasicStringBuf<char>& token) { if (token == "3") { - return false; + return false; } - actual.push_back(TString(token)); - return true; - }; - bool completed = StringSplitter("1 2 3 4 5").Split(' ').Consume(func); - UNIT_ASSERT(!completed); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestStringSplitterToList) { - TVector<TString> expected = {"1", "2", "3"}; - TVector<TString> actual = StringSplitter("1 2 3").Split(' ').ToList<TString>(); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestStringSplitterCollectPushBack) { - TVector<TString> expected = {"1", "2", "3"}; - TVector<TString> actual; - StringSplitter("1 2 3").Split(' ').Collect(&actual); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestStringSplitterCollectInsert) { - TSet<TString> expected = {"1", "2", "3"}; - TSet<TString> actual; - StringSplitter("1 2 3 1 2 3").Split(' ').Collect(&actual); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestStringSplitterCollectClears) { - TVector<TString> v; - StringSplitter("1 2 3").Split(' ').Collect(&v); - UNIT_ASSERT_VALUES_EQUAL(v.size(), 3); - StringSplitter("4 5").Split(' ').Collect(&v); - UNIT_ASSERT_VALUES_EQUAL(v.size(), 2); - } - - Y_UNIT_TEST(TestStringSplitterAddToDoesntClear) { - TVector<TString> v; - StringSplitter("1 2 3").Split(' ').AddTo(&v); - UNIT_ASSERT_VALUES_EQUAL(v.size(), 3); - StringSplitter("4 5").Split(' ').AddTo(&v); - UNIT_ASSERT_VALUES_EQUAL(v.size(), 5); - } - - Y_UNIT_TEST(TestSplitStringInto) { - int a = -1; - TStringBuf s; - double d = -1; - StringSplitter("2 substr 1.02").Split(' ').CollectInto(&a, &s, &d); - UNIT_ASSERT_VALUES_EQUAL(a, 2); - UNIT_ASSERT_VALUES_EQUAL(s, "substr"); - UNIT_ASSERT_DOUBLES_EQUAL(d, 1.02, 0.0001); - UNIT_ASSERT_EXCEPTION(StringSplitter("1").Split(' ').CollectInto(&a, &a), yexception); - UNIT_ASSERT_EXCEPTION(StringSplitter("1 2 3").Split(' ').CollectInto(&a, &a), yexception); - } - + actual.push_back(TString(token)); + return true; + }; + bool completed = StringSplitter("1 2 3 4 5").Split(' ').Consume(func); + UNIT_ASSERT(!completed); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestStringSplitterToList) { + TVector<TString> expected = {"1", "2", "3"}; + TVector<TString> actual = StringSplitter("1 2 3").Split(' ').ToList<TString>(); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestStringSplitterCollectPushBack) { + TVector<TString> expected = {"1", "2", "3"}; + TVector<TString> actual; + StringSplitter("1 2 3").Split(' ').Collect(&actual); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestStringSplitterCollectInsert) { + TSet<TString> expected = {"1", "2", "3"}; + TSet<TString> actual; + StringSplitter("1 2 3 1 2 3").Split(' ').Collect(&actual); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestStringSplitterCollectClears) { + TVector<TString> v; + StringSplitter("1 2 3").Split(' ').Collect(&v); + UNIT_ASSERT_VALUES_EQUAL(v.size(), 3); + StringSplitter("4 5").Split(' ').Collect(&v); + UNIT_ASSERT_VALUES_EQUAL(v.size(), 2); + } + + Y_UNIT_TEST(TestStringSplitterAddToDoesntClear) { + TVector<TString> v; + StringSplitter("1 2 3").Split(' ').AddTo(&v); + UNIT_ASSERT_VALUES_EQUAL(v.size(), 3); + StringSplitter("4 5").Split(' ').AddTo(&v); + UNIT_ASSERT_VALUES_EQUAL(v.size(), 5); + } + + Y_UNIT_TEST(TestSplitStringInto) { + int a = -1; + TStringBuf s; + double d = -1; + StringSplitter("2 substr 1.02").Split(' ').CollectInto(&a, &s, &d); + UNIT_ASSERT_VALUES_EQUAL(a, 2); + UNIT_ASSERT_VALUES_EQUAL(s, "substr"); + UNIT_ASSERT_DOUBLES_EQUAL(d, 1.02, 0.0001); + UNIT_ASSERT_EXCEPTION(StringSplitter("1").Split(' ').CollectInto(&a, &a), yexception); + UNIT_ASSERT_EXCEPTION(StringSplitter("1 2 3").Split(' ').CollectInto(&a, &a), yexception); + } + Y_UNIT_TEST(TestSplitStringWithIgnore) { TStringBuf s; StringSplitter("x y z").Split(' ').CollectInto(&std::ignore, &s, &std::ignore); @@ -567,265 +567,265 @@ Y_UNIT_TEST_SUITE(StringSplitter) { UNIT_ASSERT_EXCEPTION(StringSplitter("ignored != non-requred").Split(':').CollectInto(&s, &std::ignore), yexception); } - Y_UNIT_TEST(TestTryCollectInto) { - int a, b, c; - bool parsingSucceeded; - parsingSucceeded = StringSplitter("100,500,3").Split(',').TryCollectInto(&a, &b, &c); - UNIT_ASSERT(parsingSucceeded); - UNIT_ASSERT_VALUES_EQUAL(a, 100); - UNIT_ASSERT_VALUES_EQUAL(b, 500); - UNIT_ASSERT_VALUES_EQUAL(c, 3); - - //not enough tokens - parsingSucceeded = StringSplitter("3,14").Split(',').TryCollectInto(&a, &b, &c); - UNIT_ASSERT(!parsingSucceeded); - - //too many tokens - parsingSucceeded = StringSplitter("3,14,15,92,6").Split(',').TryCollectInto(&a, &b, &c); - UNIT_ASSERT(!parsingSucceeded); - - //where single TryFromString fails - parsingSucceeded = StringSplitter("ot topota kopyt pyl po polu letit").Split(' ').TryCollectInto(&a, &b, &c); - UNIT_ASSERT(!parsingSucceeded); - } - - Y_UNIT_TEST(TestOwningSplit1) { - int sum = 0; - - for (const auto& it : StringSplitter(TString("1,2,3")).Split(',')) { - sum += FromString<int>(it.Token()); - } - - UNIT_ASSERT_VALUES_EQUAL(sum, 6); - } - - Y_UNIT_TEST(TestOwningSplit2) { - int sum = 0; - - TString str("1,2,3"); - for (const auto& it : StringSplitter(str).Split(',')) { - sum += FromString<int>(it.Token()); - } - - UNIT_ASSERT_VALUES_EQUAL(sum, 6); - } - - Y_UNIT_TEST(TestOwningSplit3) { - int sum = 0; - - const TString str("1,2,3"); - for (const auto& it : StringSplitter(str).Split(',')) { - sum += FromString<int>(it.Token()); - } - - UNIT_ASSERT_VALUES_EQUAL(sum, 6); - } - - Y_UNIT_TEST(TestAssigment) { + Y_UNIT_TEST(TestTryCollectInto) { + int a, b, c; + bool parsingSucceeded; + parsingSucceeded = StringSplitter("100,500,3").Split(',').TryCollectInto(&a, &b, &c); + UNIT_ASSERT(parsingSucceeded); + UNIT_ASSERT_VALUES_EQUAL(a, 100); + UNIT_ASSERT_VALUES_EQUAL(b, 500); + UNIT_ASSERT_VALUES_EQUAL(c, 3); + + //not enough tokens + parsingSucceeded = StringSplitter("3,14").Split(',').TryCollectInto(&a, &b, &c); + UNIT_ASSERT(!parsingSucceeded); + + //too many tokens + parsingSucceeded = StringSplitter("3,14,15,92,6").Split(',').TryCollectInto(&a, &b, &c); + UNIT_ASSERT(!parsingSucceeded); + + //where single TryFromString fails + parsingSucceeded = StringSplitter("ot topota kopyt pyl po polu letit").Split(' ').TryCollectInto(&a, &b, &c); + UNIT_ASSERT(!parsingSucceeded); + } + + Y_UNIT_TEST(TestOwningSplit1) { + int sum = 0; + + for (const auto& it : StringSplitter(TString("1,2,3")).Split(',')) { + sum += FromString<int>(it.Token()); + } + + UNIT_ASSERT_VALUES_EQUAL(sum, 6); + } + + Y_UNIT_TEST(TestOwningSplit2) { + int sum = 0; + + TString str("1,2,3"); + for (const auto& it : StringSplitter(str).Split(',')) { + sum += FromString<int>(it.Token()); + } + + UNIT_ASSERT_VALUES_EQUAL(sum, 6); + } + + Y_UNIT_TEST(TestOwningSplit3) { + int sum = 0; + + const TString str("1,2,3"); + for (const auto& it : StringSplitter(str).Split(',')) { + sum += FromString<int>(it.Token()); + } + + UNIT_ASSERT_VALUES_EQUAL(sum, 6); + } + + Y_UNIT_TEST(TestAssigment) { TVector<TString> expected0 = {"1", "2", "3", "4"}; - TVector<TString> actual0 = StringSplitter("1 2 3 4").Split(' '); - UNIT_ASSERT_VALUES_EQUAL(expected0, actual0); - + TVector<TString> actual0 = StringSplitter("1 2 3 4").Split(' '); + UNIT_ASSERT_VALUES_EQUAL(expected0, actual0); + TSet<TString> expected1 = {"11", "22", "33", "44"}; - TSet<TString> actual1 = StringSplitter("11 22 33 44").Split(' '); - UNIT_ASSERT_VALUES_EQUAL(expected1, actual1); - + TSet<TString> actual1 = StringSplitter("11 22 33 44").Split(' '); + UNIT_ASSERT_VALUES_EQUAL(expected1, actual1); + TSet<TString> expected2 = {"11", "aa"}; - auto actual2 = static_cast<TSet<TString>>(StringSplitter("11 aa 11 11 aa").Split(' ')); - UNIT_ASSERT_VALUES_EQUAL(expected2, actual2); - + auto actual2 = static_cast<TSet<TString>>(StringSplitter("11 aa 11 11 aa").Split(' ')); + UNIT_ASSERT_VALUES_EQUAL(expected2, actual2); + TVector<TString> expected3 = {"dd", "bb"}; - auto actual3 = TVector<TString>(StringSplitter("dd\tbb").Split('\t')); - UNIT_ASSERT_VALUES_EQUAL(expected3, actual3); - } - - Y_UNIT_TEST(TestRangeBasedFor) { + auto actual3 = TVector<TString>(StringSplitter("dd\tbb").Split('\t')); + UNIT_ASSERT_VALUES_EQUAL(expected3, actual3); + } + + Y_UNIT_TEST(TestRangeBasedFor) { TVector<TString> actual0 = {"11", "22", "33", "44"}; - size_t num = 0; - for (TStringBuf elem : StringSplitter("11 22 33 44").Split(' ')) { - UNIT_ASSERT_VALUES_EQUAL(elem, actual0[num++]); - } - + size_t num = 0; + for (TStringBuf elem : StringSplitter("11 22 33 44").Split(' ')) { + UNIT_ASSERT_VALUES_EQUAL(elem, actual0[num++]); + } + TVector<TString> actual1 = {"another", "one,", "and", "another", "one"}; - num = 0; + num = 0; for (TStringBuf elem : StringSplitter(TStringBuf("another one, and \n\n another one")).SplitBySet(" \n").SkipEmpty()) { - UNIT_ASSERT_VALUES_EQUAL(elem, actual1[num++]); - } - + UNIT_ASSERT_VALUES_EQUAL(elem, actual1[num++]); + } + TVector<TUtf16String> actual2 = {u"привет,", u"как", u"дела"}; - num = 0; + num = 0; for (TWtringBuf elem : StringSplitter(u"привет, как дела").Split(wchar16(' '))) { - UNIT_ASSERT_VALUES_EQUAL(elem, actual2[num++]); - } - - TVector<TString> copy(4); - auto v = StringSplitter("11 22 33 44").Split(' '); - Copy(v.begin(), v.end(), copy.begin()); - UNIT_ASSERT_VALUES_EQUAL(actual0, copy); - } - - Y_UNIT_TEST(TestParseInto) { + UNIT_ASSERT_VALUES_EQUAL(elem, actual2[num++]); + } + + TVector<TString> copy(4); + auto v = StringSplitter("11 22 33 44").Split(' '); + Copy(v.begin(), v.end(), copy.begin()); + UNIT_ASSERT_VALUES_EQUAL(actual0, copy); + } + + Y_UNIT_TEST(TestParseInto) { TVector<int> actual0 = {1, 2, 3, 4}; - TVector<int> answer0; - - StringSplitter("1 2 3 4").Split(' ').ParseInto(&answer0); - UNIT_ASSERT_VALUES_EQUAL(actual0, answer0); - + TVector<int> answer0; + + StringSplitter("1 2 3 4").Split(' ').ParseInto(&answer0); + UNIT_ASSERT_VALUES_EQUAL(actual0, answer0); + TVector<int> actual1 = {42, 1, 2, 3, 4}; TVector<int> answer1 = {42}; - StringSplitter("1 2 3 4").Split(' ').ParseInto(&answer1); - UNIT_ASSERT_VALUES_EQUAL(actual1, answer1); - - answer1.clear(); - UNIT_ASSERT_EXCEPTION(StringSplitter("1 2 3 4").Split(' ').ParseInto(&answer1), yexception); - + StringSplitter("1 2 3 4").Split(' ').ParseInto(&answer1); + UNIT_ASSERT_VALUES_EQUAL(actual1, answer1); + + answer1.clear(); + UNIT_ASSERT_EXCEPTION(StringSplitter("1 2 3 4").Split(' ').ParseInto(&answer1), yexception); + answer1 = {42}; - StringSplitter(" 1 2 3 4").Split(' ').SkipEmpty().ParseInto(&answer1); - UNIT_ASSERT_VALUES_EQUAL(actual1, answer1); - - answer1.clear(); - StringSplitter(" \n 1 2 \n\n\n 3 4\n ").SplitBySet(" \n").SkipEmpty().ParseInto(&answer1); - UNIT_ASSERT_VALUES_EQUAL(actual0, answer1); - } - - Y_UNIT_TEST(TestStdString) { - std::vector<std::string_view> r0, r1, answer = {"lol", "zomg"}; - std::string s = "lol zomg"; - for (std::string_view ss : StringSplitter(s).Split(' ')) { - r0.push_back(ss); - } - StringSplitter(s).Split(' ').Collect(&r1); - - UNIT_ASSERT_VALUES_EQUAL(r0, answer); - UNIT_ASSERT_VALUES_EQUAL(r1, answer); - } - - Y_UNIT_TEST(TestStdStringView) { - std::string_view s = "aaacccbbb"; - std::vector<std::string_view> expected = {"aaa", "bbb"}; - std::vector<std::string_view> actual = StringSplitter(s).SplitByString("ccc"); - UNIT_ASSERT_VALUES_EQUAL(expected, actual); - } - - Y_UNIT_TEST(TestStdSplitAfterSplit) { - std::string_view input = "a*b+a*b"; + StringSplitter(" 1 2 3 4").Split(' ').SkipEmpty().ParseInto(&answer1); + UNIT_ASSERT_VALUES_EQUAL(actual1, answer1); + + answer1.clear(); + StringSplitter(" \n 1 2 \n\n\n 3 4\n ").SplitBySet(" \n").SkipEmpty().ParseInto(&answer1); + UNIT_ASSERT_VALUES_EQUAL(actual0, answer1); + } + + Y_UNIT_TEST(TestStdString) { + std::vector<std::string_view> r0, r1, answer = {"lol", "zomg"}; + std::string s = "lol zomg"; + for (std::string_view ss : StringSplitter(s).Split(' ')) { + r0.push_back(ss); + } + StringSplitter(s).Split(' ').Collect(&r1); + + UNIT_ASSERT_VALUES_EQUAL(r0, answer); + UNIT_ASSERT_VALUES_EQUAL(r1, answer); + } + + Y_UNIT_TEST(TestStdStringView) { + std::string_view s = "aaacccbbb"; + std::vector<std::string_view> expected = {"aaa", "bbb"}; + std::vector<std::string_view> actual = StringSplitter(s).SplitByString("ccc"); + UNIT_ASSERT_VALUES_EQUAL(expected, actual); + } + + Y_UNIT_TEST(TestStdSplitAfterSplit) { + std::string_view input = "a*b+a*b"; for (std::string_view summand : StringSplitter(input).Split('+')) { - //FIXME: std::string is used to workaround MSVC ICE - UNIT_ASSERT_VALUES_EQUAL(std::string(summand), "a*b"); - std::string_view multiplier1, multiplier2; - bool splitResult = StringSplitter(summand).Split('*').TryCollectInto(&multiplier1, &multiplier2); - UNIT_ASSERT(splitResult); - UNIT_ASSERT_VALUES_EQUAL(std::string(multiplier1), "a"); - UNIT_ASSERT_VALUES_EQUAL(std::string(multiplier2), "b"); - } - } - - Y_UNIT_TEST(TestStdSplitWithParsing) { - std::string_view input = "1,2,3,4"; - TVector<ui64> numbers; - const TVector<ui64> expected{1, 2, 3, 4}; - StringSplitter(input).Split(',').ParseInto(&numbers); - UNIT_ASSERT_VALUES_EQUAL(numbers, expected); - } - - Y_UNIT_TEST(TestArcadiaStdInterop) { + //FIXME: std::string is used to workaround MSVC ICE + UNIT_ASSERT_VALUES_EQUAL(std::string(summand), "a*b"); + std::string_view multiplier1, multiplier2; + bool splitResult = StringSplitter(summand).Split('*').TryCollectInto(&multiplier1, &multiplier2); + UNIT_ASSERT(splitResult); + UNIT_ASSERT_VALUES_EQUAL(std::string(multiplier1), "a"); + UNIT_ASSERT_VALUES_EQUAL(std::string(multiplier2), "b"); + } + } + + Y_UNIT_TEST(TestStdSplitWithParsing) { + std::string_view input = "1,2,3,4"; + TVector<ui64> numbers; + const TVector<ui64> expected{1, 2, 3, 4}; + StringSplitter(input).Split(',').ParseInto(&numbers); + UNIT_ASSERT_VALUES_EQUAL(numbers, expected); + } + + Y_UNIT_TEST(TestArcadiaStdInterop) { TVector<TString> expected0 = {"a", "b"}; TVector<TStringBuf> expected1 = {"a", "b"}; - std::string src1("a b"); - std::string_view src2("a b"); - TVector<TString> actual0 = StringSplitter(src1).Split(' ').SkipEmpty(); - TVector<TString> actual1 = StringSplitter(src2).Split(' ').SkipEmpty(); - TVector<TStringBuf> actual2 = StringSplitter(src1).Split(' ').SkipEmpty(); - TVector<TStringBuf> actual3 = StringSplitter(src2).Split(' ').SkipEmpty(); - UNIT_ASSERT_VALUES_EQUAL(expected0, actual0); - UNIT_ASSERT_VALUES_EQUAL(expected0, actual1); - UNIT_ASSERT_VALUES_EQUAL(expected1, actual2); - UNIT_ASSERT_VALUES_EQUAL(expected1, actual3); - } - - Y_UNIT_TEST(TestConstCString) { - const char* b = "a;b"; - const char* e = b + 3; - - std::vector<TStringBuf> v; - StringSplitter(b, e).Split(';').AddTo(&v); - + std::string src1("a b"); + std::string_view src2("a b"); + TVector<TString> actual0 = StringSplitter(src1).Split(' ').SkipEmpty(); + TVector<TString> actual1 = StringSplitter(src2).Split(' ').SkipEmpty(); + TVector<TStringBuf> actual2 = StringSplitter(src1).Split(' ').SkipEmpty(); + TVector<TStringBuf> actual3 = StringSplitter(src2).Split(' ').SkipEmpty(); + UNIT_ASSERT_VALUES_EQUAL(expected0, actual0); + UNIT_ASSERT_VALUES_EQUAL(expected0, actual1); + UNIT_ASSERT_VALUES_EQUAL(expected1, actual2); + UNIT_ASSERT_VALUES_EQUAL(expected1, actual3); + } + + Y_UNIT_TEST(TestConstCString) { + const char* b = "a;b"; + const char* e = b + 3; + + std::vector<TStringBuf> v; + StringSplitter(b, e).Split(';').AddTo(&v); + std::vector<TStringBuf> expected = {"a", "b"}; - UNIT_ASSERT_VALUES_EQUAL(v, expected); - } - - Y_UNIT_TEST(TestCStringRef) { - TString s = "lol"; - char* str = s.Detach(); - - std::vector<TStringBuf> v = StringSplitter(str).Split('o'); + UNIT_ASSERT_VALUES_EQUAL(v, expected); + } + + Y_UNIT_TEST(TestCStringRef) { + TString s = "lol"; + char* str = s.Detach(); + + std::vector<TStringBuf> v = StringSplitter(str).Split('o'); std::vector<TStringBuf> expected = {"l", "l"}; - UNIT_ASSERT_VALUES_EQUAL(v, expected); - } - - Y_UNIT_TEST(TestSplitVector) { + UNIT_ASSERT_VALUES_EQUAL(v, expected); + } + + Y_UNIT_TEST(TestSplitVector) { std::vector<char> buffer = {'a', ';', 'b'}; - - std::vector<TStringBuf> v = StringSplitter(buffer).Split(';'); - + + std::vector<TStringBuf> v = StringSplitter(buffer).Split(';'); + std::vector<TStringBuf> expected = {"a", "b"}; - UNIT_ASSERT_VALUES_EQUAL(v, expected); - } - - class TDoubleIterator { - public: - using iterator_category = std::input_iterator_tag; - using value_type = int; - using pointer = void; - using reference = int; - using const_reference = int; - using difference_type = ptrdiff_t; - - TDoubleIterator() = default; - + UNIT_ASSERT_VALUES_EQUAL(v, expected); + } + + class TDoubleIterator { + public: + using iterator_category = std::input_iterator_tag; + using value_type = int; + using pointer = void; + using reference = int; + using const_reference = int; + using difference_type = ptrdiff_t; + + TDoubleIterator() = default; + TDoubleIterator(const char* ptr) : Ptr_(ptr) { } - - TDoubleIterator operator++() { - Ptr_ += 2; - return *this; - } - - TDoubleIterator operator++(int) { - TDoubleIterator tmp = *this; - ++*this; - return tmp; - } - - friend bool operator==(TDoubleIterator l, TDoubleIterator r) { - return l.Ptr_ == r.Ptr_; - } - - friend bool operator!=(TDoubleIterator l, TDoubleIterator r) { - return l.Ptr_ != r.Ptr_; - } - - int operator*() const { - return (*Ptr_ - '0') * 10 + *(Ptr_ + 1) - '0'; - } - - private: - const char* Ptr_ = nullptr; - }; - - Y_UNIT_TEST(TestInputIterator) { - const char* beg = "1213002233000011"; - const char* end = beg + strlen(beg); - + + TDoubleIterator operator++() { + Ptr_ += 2; + return *this; + } + + TDoubleIterator operator++(int) { + TDoubleIterator tmp = *this; + ++*this; + return tmp; + } + + friend bool operator==(TDoubleIterator l, TDoubleIterator r) { + return l.Ptr_ == r.Ptr_; + } + + friend bool operator!=(TDoubleIterator l, TDoubleIterator r) { + return l.Ptr_ != r.Ptr_; + } + + int operator*() const { + return (*Ptr_ - '0') * 10 + *(Ptr_ + 1) - '0'; + } + + private: + const char* Ptr_ = nullptr; + }; + + Y_UNIT_TEST(TestInputIterator) { + const char* beg = "1213002233000011"; + const char* end = beg + strlen(beg); + std::vector<std::vector<int>> expected = {{12, 13}, {22, 33}, {}, {11}}; - int i = 0; - - for (TIteratorRange<TDoubleIterator> part : StringSplitter(TDoubleIterator(beg), TDoubleIterator(end)).SplitByFunc([](int value) { return value == 0; })) { - UNIT_ASSERT(std::equal(part.begin(), part.end(), expected[i].begin(), expected[i].end())); - i++; - } - UNIT_ASSERT_VALUES_EQUAL(i, expected.size()); - } -} + int i = 0; + + for (TIteratorRange<TDoubleIterator> part : StringSplitter(TDoubleIterator(beg), TDoubleIterator(end)).SplitByFunc([](int value) { return value == 0; })) { + UNIT_ASSERT(std::equal(part.begin(), part.end(), expected[i].begin(), expected[i].end())); + i++; + } + UNIT_ASSERT_VALUES_EQUAL(i, expected.size()); + } +} diff --git a/util/string/strip.cpp b/util/string/strip.cpp index f53b9ee896..c921571cf0 100644 --- a/util/string/strip.cpp +++ b/util/string/strip.cpp @@ -10,7 +10,7 @@ bool Collapse(const TString& from, TString& to, size_t maxLen) { void CollapseText(const TString& from, TString& to, size_t maxLen) { Collapse(from, to, maxLen); StripInPlace(to); - if (to.size() >= maxLen) { + if (to.size() >= maxLen) { to.remove(maxLen - 5); // " ..." ReverseInPlace(to); size_t pos = to.find_first_of(" .,;"); diff --git a/util/string/strip.h b/util/string/strip.h index 0769ed5afe..d5ef6da96d 100644 --- a/util/string/strip.h +++ b/util/string/strip.h @@ -218,7 +218,7 @@ size_t CollapseImpl(TChar* s, size_t n, const TWhitespaceFunc& isWhitespace) { template <class TStringType, class TWhitespaceFunc> bool CollapseImpl(const TStringType& from, TStringType& to, size_t maxLen, const TWhitespaceFunc& isWhitespace) { to = from; - maxLen = maxLen ? Min(maxLen, to.size()) : to.size(); + maxLen = maxLen ? Min(maxLen, to.size()) : to.size(); for (size_t i = 0; i < maxLen; ++i) { if (isWhitespace(to[i]) && (to[i] != ' ' || isWhitespace(to[i + 1]))) { size_t tailSize = maxLen - i; diff --git a/util/string/subst.cpp b/util/string/subst.cpp index d86f939e25..b2df328dc1 100644 --- a/util/string/subst.cpp +++ b/util/string/subst.cpp @@ -67,7 +67,7 @@ static inline size_t SubstGlobalImpl(TStringType& s, const TStringViewType from, result.reserve(s.size() + s.size() / 3); } result.append(s.begin() + srcPos, s.begin() + off); - result.append(to.data(), to.size()); + result.append(to.data(), to.size()); srcPos = off + fromSize; ++replacementsCount; } diff --git a/util/string/subst_ut.cpp b/util/string/subst_ut.cpp index a4db704938..21eccef779 100644 --- a/util/string/subst_ut.cpp +++ b/util/string/subst_ut.cpp @@ -26,7 +26,7 @@ Y_UNIT_TEST_SUITE(TStringSubst) { Y_UNIT_TEST(TestSubstGlobalNoSubstA) { for (const auto& from : ALL_FROM) { - const size_t fromSz = from.size(); + const size_t fromSz = from.size(); const size_t minSz = fromSz; const size_t maxSz = fromSz + MIN_FROM_CTX; for (size_t sz = minSz; sz <= maxSz; ++sz) { @@ -42,7 +42,7 @@ Y_UNIT_TEST_SUITE(TStringSubst) { Y_UNIT_TEST(TestSubstGlobalNoSubstB) { for (const auto& from : ALL_FROM) { - const size_t fromSz = from.size(); + const size_t fromSz = from.size(); const size_t minSz = fromSz; const size_t maxSz = fromSz + MIN_FROM_CTX; for (size_t sz = minSz; sz <= maxSz; ++sz) { @@ -64,7 +64,7 @@ Y_UNIT_TEST_SUITE(TStringSubst) { static void DoTestSubstGlobal(TVector<TString>& parts, const size_t minBeg, const size_t sz, const TString& from, const size_t fromPos, const size_t numSubst) { const size_t numLeft = numSubst - parts.size(); - for (size_t fromBeg = minBeg; fromBeg <= sz - numLeft * from.size(); ++fromBeg) { + for (size_t fromBeg = minBeg; fromBeg <= sz - numLeft * from.size(); ++fromBeg) { if (parts.empty()) { parts.emplace_back(fromBeg, '.'); } else { @@ -72,16 +72,16 @@ Y_UNIT_TEST_SUITE(TStringSubst) { } if (numLeft == 1) { - parts.emplace_back(sz - fromBeg - from.size(), '.'); + parts.emplace_back(sz - fromBeg - from.size(), '.'); TString sFrom = JoinSeq(from, parts); - UNIT_ASSERT_VALUES_EQUAL_C(sFrom.size(), sz, sFrom); + UNIT_ASSERT_VALUES_EQUAL_C(sFrom.size(), sz, sFrom); for (const auto& to : ALL_TO) { TString sTo = JoinSeq(to, parts); AssertSubstGlobal(sFrom, sTo, from, to, fromPos, numSubst); } parts.pop_back(); } else { - DoTestSubstGlobal(parts, fromBeg + from.size(), sz, from, fromPos, numSubst); + DoTestSubstGlobal(parts, fromBeg + from.size(), sz, from, fromPos, numSubst); } parts.pop_back(); @@ -91,7 +91,7 @@ Y_UNIT_TEST_SUITE(TStringSubst) { static void DoTestSubstGlobal(size_t numSubst) { TVector<TString> parts; for (const auto& from : ALL_FROM) { - const size_t fromSz = from.size(); + const size_t fromSz = from.size(); const size_t minSz = numSubst * fromSz; const size_t maxSz = numSubst * (fromSz + MIN_FROM_CTX); for (size_t sz = minSz; sz <= maxSz; ++sz) { diff --git a/util/string/type.h b/util/string/type.h index ff6767415f..d6cb29ea58 100644 --- a/util/string/type.h +++ b/util/string/type.h @@ -6,7 +6,7 @@ Y_PURE_FUNCTION bool IsSpace(const char* s, size_t len) noexcept; /// Checks if a string is a set of only space symbols. Y_PURE_FUNCTION static inline bool IsSpace(const TStringBuf s) noexcept { - return IsSpace(s.data(), s.size()); + return IsSpace(s.data(), s.size()); } /// Returns "true" if the given string is an arabic number ([0-9]+) diff --git a/util/string/vector.cpp b/util/string/vector.cpp index 3e78fce9c4..9ba401f0a2 100644 --- a/util/string/vector.cpp +++ b/util/string/vector.cpp @@ -11,12 +11,12 @@ static inline void DoSplit2(TConsumer& c, TDelim& d, const TBasicStringBuf<TChr> template <class TConsumer, class TDelim, typename TChr> static inline void DoSplit1(TConsumer& cc, TDelim& d, const TBasicStringBuf<TChr> str, int opts) { - if (opts & KEEP_EMPTY_TOKENS) { + if (opts & KEEP_EMPTY_TOKENS) { DoSplit2(cc, d, str, opts); } else { TSkipEmptyTokens<TConsumer> sc(&cc); - DoSplit2(sc, d, str, opts); + DoSplit2(sc, d, str, opts); } } @@ -84,8 +84,8 @@ TUtf16String JoinStrings(const TVector<TUtf16String>& v, const TWtringBuf delim) } TUtf16String JoinStrings(const TVector<TUtf16String>& v, size_t index, size_t count, const TWtringBuf delim) { - const size_t f = Min(index, v.size()); - const size_t l = f + Min(count, v.size() - f); + const size_t f = Min(index, v.size()); + const size_t l = f + Min(count, v.size() - f); return JoinStrings(v.begin() + f, v.begin() + l, delim); } diff --git a/util/string/vector.h b/util/string/vector.h index 78e01efa08..e36c348bbe 100644 --- a/util/string/vector.h +++ b/util/string/vector.h @@ -1,7 +1,7 @@ #pragma once #include "cast.h" -#include "split.h" +#include "split.h" #include <util/generic/map.h> #include <util/generic/strbuf.h> @@ -13,7 +13,7 @@ #define KEEP_EMPTY_TOKENS 0x01 // -// NOTE: Check StringSplitter below to get more convenient split string interface. +// NOTE: Check StringSplitter below to get more convenient split string interface. namespace NPrivate { @@ -46,7 +46,7 @@ TVector<typename ::NPrivate::TStringDeducer<C>::type> SplitString(const C* ptr, const C* delimiter, size_t maxFields = 0, int options = 0) { TVector<typename ::NPrivate::TStringDeducer<C>::type> res; - ::NPrivate::SplitStringImpl(&res, ptr, delimiter, maxFields, options); + ::NPrivate::SplitStringImpl(&res, ptr, delimiter, maxFields, options); return res; } @@ -55,7 +55,7 @@ TVector<typename ::NPrivate::TStringDeducer<C>::type> SplitString(const C* ptr, size_t len, const C* delimiter, size_t maxFields = 0, int options = 0) { TVector<typename ::NPrivate::TStringDeducer<C>::type> res; - ::NPrivate::SplitStringImpl(&res, ptr, len, delimiter, maxFields, options); + ::NPrivate::SplitStringImpl(&res, ptr, len, delimiter, maxFields, options); return res; } @@ -63,7 +63,7 @@ template <typename C> TVector<typename ::NPrivate::TStringDeducer<C>::type> SplitString(const typename ::NPrivate::TStringDeducer<C>::type& str, const C* delimiter, size_t maxFields = 0, int options = 0) { - return SplitString(str.data(), str.size(), delimiter, maxFields, options); + return SplitString(str.data(), str.size(), delimiter, maxFields, options); } template <class TIter> diff --git a/util/system/atexit.cpp b/util/system/atexit.cpp index 1714784f29..74fb10b6b1 100644 --- a/util/system/atexit.cpp +++ b/util/system/atexit.cpp @@ -60,7 +60,7 @@ namespace { inline void Register(TAtExitFunc func, void* ctx, size_t priority) { with_lock (Lock_) { - Store_.push_back({func, ctx, priority, Store_.size()}); + Store_.push_back({func, ctx, priority, Store_.size()}); Items_.push(&Store_.back()); } } diff --git a/util/system/compat.cpp b/util/system/compat.cpp index 00eac400d7..18fbfa296a 100644 --- a/util/system/compat.cpp +++ b/util/system/compat.cpp @@ -18,7 +18,7 @@ #ifndef HAVE_NATIVE_GETPROGNAME const char* getprogname() { - return GetProgramName().data(); + return GetProgramName().data(); } #endif diff --git a/util/system/dynlib.cpp b/util/system/dynlib.cpp index f5084f2f68..9d2541c25f 100644 --- a/util/system/dynlib.cpp +++ b/util/system/dynlib.cpp @@ -53,7 +53,7 @@ private: (void)flags; if (!Module) { - ythrow yexception() << DLLERR().data(); + ythrow yexception() << DLLERR().data(); } } @@ -81,7 +81,7 @@ public: void* symbol = SymOptional(name); if (symbol == nullptr) { - ythrow yexception() << DLLERR().data(); + ythrow yexception() << DLLERR().data(); } return symbol; @@ -100,7 +100,7 @@ TDynamicLibrary::TDynamicLibrary() noexcept { } TDynamicLibrary::TDynamicLibrary(const TString& path, int flags) { - Open(path.data(), flags); + Open(path.data(), flags); } TDynamicLibrary::~TDynamicLibrary() = default; diff --git a/util/system/dynlib.h b/util/system/dynlib.h index 6515df903a..66eaf4a5c1 100644 --- a/util/system/dynlib.h +++ b/util/system/dynlib.h @@ -56,7 +56,7 @@ public: PLib = nullptr; DLib = nullptr; if (es.IsDynamic()) - Open(es.LibName().data(), es.VtblName().data()); + Open(es.LibName().data(), es.VtblName().data()); else if (es.IsStatic()) SetSym(es.Symbol()); } @@ -64,7 +64,7 @@ public: if (this != &es) { Close(); if (es.IsDynamic()) - Open(es.LibName().data(), es.VtblName().data()); + Open(es.LibName().data(), es.VtblName().data()); else if (es.IsStatic()) SetSym(es.Symbol()); } diff --git a/util/system/env.cpp b/util/system/env.cpp index 483b000d34..ead9b566a5 100644 --- a/util/system/env.cpp +++ b/util/system/env.cpp @@ -23,7 +23,7 @@ TString GetEnv(const TString& key, const TString& def) { #ifdef _win_ - size_t len = GetEnvironmentVariableA(key.data(), nullptr, 0); + size_t len = GetEnvironmentVariableA(key.data(), nullptr, 0); if (len == 0) { if (GetLastError() == ERROR_ENVVAR_NOT_FOUND) { @@ -36,7 +36,7 @@ TString GetEnv(const TString& key, const TString& def) { size_t bufferSize; do { bufferSize = buffer.size(); - len = GetEnvironmentVariableA(key.data(), buffer.data(), static_cast<DWORD>(bufferSize)); + len = GetEnvironmentVariableA(key.data(), buffer.data(), static_cast<DWORD>(bufferSize)); if (len > bufferSize) { buffer.resize(len); } @@ -44,7 +44,7 @@ TString GetEnv(const TString& key, const TString& def) { return TString(buffer.data(), len); #else - const char* env = getenv(key.data()); + const char* env = getenv(key.data()); return env ? TString(env) : def; #endif } @@ -53,12 +53,12 @@ void SetEnv(const TString& key, const TString& value) { bool isOk = false; int errorCode = 0; #ifdef _win_ - isOk = SetEnvironmentVariable(key.data(), value.data()); + isOk = SetEnvironmentVariable(key.data(), value.data()); if (!isOk) { errorCode = GetLastError(); } #else - isOk = (0 == setenv(key.data(), value.data(), true /*replace*/)); + isOk = (0 == setenv(key.data(), value.data(), true /*replace*/)); if (!isOk) { errorCode = errno; } diff --git a/util/system/file.cpp b/util/system/file.cpp index 743e8f67f2..4a261d020c 100644 --- a/util/system/file.cpp +++ b/util/system/file.cpp @@ -260,7 +260,7 @@ TFileHandle::TFileHandle(const TString& fName, EOpenMode oMode) noexcept { //temp file if (Fd_ >= 0 && (oMode & Transient)) { - unlink(fName.data()); + unlink(fName.data()); } #else #error unsupported platform diff --git a/util/system/filemap.h b/util/system/filemap.h index b084c060a3..11be64bff4 100644 --- a/util/system/filemap.h +++ b/util/system/filemap.h @@ -4,7 +4,7 @@ #include "align.h" #include "yassert.h" -#include <util/generic/noncopyable.h> +#include <util/generic/noncopyable.h> #include <util/generic/ptr.h> #include <util/generic/utility.h> #include <util/generic/yexception.h> diff --git a/util/system/fs.cpp b/util/system/fs.cpp index e2db6cd403..d2611a8ccc 100644 --- a/util/system/fs.cpp +++ b/util/system/fs.cpp @@ -20,7 +20,7 @@ bool NFs::Remove(const TString& path) { #if defined(_win_) return NFsPrivate::WinRemove(path); #else - return ::remove(path.data()) == 0; + return ::remove(path.data()) == 0; #endif } @@ -58,7 +58,7 @@ bool NFs::MakeDirectory(const TString& path, EFilePermissions mode) { Y_UNUSED(mode); return NFsPrivate::WinMakeDirectory(path); #else - return mkdir(path.data(), mode) == 0; + return mkdir(path.data(), mode) == 0; #endif } @@ -88,7 +88,7 @@ bool NFs::Rename(const TString& oldPath, const TString& newPath) { #if defined(_win_) return NFsPrivate::WinRename(oldPath, newPath); #else - return ::rename(oldPath.data(), newPath.data()) == 0; + return ::rename(oldPath.data(), newPath.data()) == 0; #endif } @@ -102,7 +102,7 @@ bool NFs::HardLink(const TString& existingPath, const TString& newPath) { #if defined(_win_) return NFsPrivate::WinHardLink(existingPath, newPath); #elif defined(_unix_) - return (0 == link(existingPath.data(), newPath.data())); + return (0 == link(existingPath.data(), newPath.data())); #endif } @@ -110,7 +110,7 @@ bool NFs::SymLink(const TString& targetPath, const TString& linkPath) { #if defined(_win_) return NFsPrivate::WinSymLink(targetPath, linkPath); #elif defined(_unix_) - return 0 == symlink(targetPath.data(), linkPath.data()); + return 0 == symlink(targetPath.data(), linkPath.data()); #endif } @@ -120,7 +120,7 @@ TString NFs::ReadLink(const TString& path) { #elif defined(_unix_) TTempBuf buf; while (true) { - ssize_t r = readlink(path.data(), buf.Data(), buf.Size()); + ssize_t r = readlink(path.data(), buf.Data(), buf.Size()); if (r < 0) { ythrow yexception() << "can't read link " << path << ", errno = " << errno; } @@ -150,7 +150,7 @@ bool NFs::Exists(const TString& path) { #if defined(_win_) return NFsPrivate::WinExists(path); #elif defined(_unix_) - return access(path.data(), F_OK) == 0; + return access(path.data(), F_OK) == 0; #endif } @@ -171,7 +171,7 @@ void NFs::SetCurrentWorkingDirectory(TString path) { #ifdef _win_ bool ok = NFsPrivate::WinSetCurrentWorkingDirectory(path); #else - bool ok = !chdir(path.data()); + bool ok = !chdir(path.data()); #endif if (!ok) { ythrow TSystemError() << "failed to change directory to " << path.Quote(); diff --git a/util/system/fs_ut.cpp b/util/system/fs_ut.cpp index 7ed677bce0..de071ebf55 100644 --- a/util/system/fs_ut.cpp +++ b/util/system/fs_ut.cpp @@ -71,10 +71,10 @@ void TFsTest::TestCreateRemove() { UNIT_ASSERT(!NFs::MakeDirectoryRecursive(file1, NFs::FP_COMMON_FILE, false)); TString longUtf8Name = ""; - while (longUtf8Name.size() < 255) { + while (longUtf8Name.size() < 255) { longUtf8Name = longUtf8Name + "fф"; } - UNIT_ASSERT_EQUAL(longUtf8Name.size(), 255); + UNIT_ASSERT_EQUAL(longUtf8Name.size(), 255); TFsPath longfile = dir1 / longUtf8Name; Touch(longfile); diff --git a/util/system/fs_win.cpp b/util/system/fs_win.cpp index 9360677e82..a410ccac06 100644 --- a/util/system/fs_win.cpp +++ b/util/system/fs_win.cpp @@ -10,13 +10,13 @@ namespace NFsPrivate { static LPCWSTR UTF8ToWCHAR(const TStringBuf str, TUtf16String& wstr) { - wstr.resize(str.size()); + wstr.resize(str.size()); size_t written = 0; - if (!UTF8ToWide(str.data(), str.size(), wstr.begin(), written)) + if (!UTF8ToWide(str.data(), str.size(), wstr.begin(), written)) return nullptr; wstr.erase(written); static_assert(sizeof(WCHAR) == sizeof(wchar16), "expect sizeof(WCHAR) == sizeof(wchar16)"); - return (const WCHAR*)wstr.data(); + return (const WCHAR*)wstr.data(); } static TString WCHARToUTF8(const LPWSTR wstr, size_t len) { diff --git a/util/system/fstat.cpp b/util/system/fstat.cpp index c413e552c6..81e98cbc6b 100644 --- a/util/system/fstat.cpp +++ b/util/system/fstat.cpp @@ -121,11 +121,11 @@ void TFileStat::MakeFromFileName(const char* fileName, bool nofollow) { } TFileStat::TFileStat(const TFsPath& fileName, bool nofollow) { - MakeFromFileName(fileName.GetPath().data(), nofollow); + MakeFromFileName(fileName.GetPath().data(), nofollow); } TFileStat::TFileStat(const TString& fileName, bool nofollow) { - MakeFromFileName(fileName.data(), nofollow); + MakeFromFileName(fileName.data(), nofollow); } TFileStat::TFileStat(const char* fileName, bool nofollow) { @@ -211,5 +211,5 @@ i64 GetFileLength(const char* name) { } i64 GetFileLength(const TString& name) { - return GetFileLength(name.data()); + return GetFileLength(name.data()); } diff --git a/util/system/fstat_ut.cpp b/util/system/fstat_ut.cpp index 81a0dbcb1d..160ecd936e 100644 --- a/util/system/fstat_ut.cpp +++ b/util/system/fstat_ut.cpp @@ -13,7 +13,7 @@ Y_UNIT_TEST_SUITE(TestFileStat) { TString fileName = "f1.txt"; TFileStat oFs; { - TFile file(fileName.data(), OpenAlways | WrOnly); + TFile file(fileName.data(), OpenAlways | WrOnly); file.Write("1234567", 7); { @@ -43,7 +43,7 @@ Y_UNIT_TEST_SUITE(TestFileStat) { UNIT_ASSERT_VALUES_EQUAL(cFs.Uid, oFs.Uid); UNIT_ASSERT_VALUES_EQUAL(cFs.Gid, oFs.Gid); UNIT_ASSERT_VALUES_EQUAL(cFs.INode, oFs.INode); - UNIT_ASSERT(unlink(fileName.data()) == 0); + UNIT_ASSERT(unlink(fileName.data()) == 0); } Y_UNIT_TEST(DirTest) { diff --git a/util/system/hi_lo.h b/util/system/hi_lo.h index 452b3c697a..f86870534f 100644 --- a/util/system/hi_lo.h +++ b/util/system/hi_lo.h @@ -41,7 +41,7 @@ namespace NHiLoPrivate { } TIntRef& operator=(TRepr value) { - WriteUnaligned<TRepr>(GetPtr(), value); + WriteUnaligned<TRepr>(GetPtr(), value); return *this; } diff --git a/util/system/hostname.cpp b/util/system/hostname.cpp index 9d6a1333fe..386f646d6b 100644 --- a/util/system/hostname.cpp +++ b/util/system/hostname.cpp @@ -69,7 +69,7 @@ const TString& HostName() { } const char* GetHostName() { - return HostName().data(); + return HostName().data(); } const TString& FQDNHostName() { @@ -77,7 +77,7 @@ const TString& FQDNHostName() { } const char* GetFQDNHostName() { - return FQDNHostName().data(); + return FQDNHostName().data(); } bool IsFQDN(const TString& name) { diff --git a/util/system/progname.cpp b/util/system/progname.cpp index 5a2b3e805b..2c29119320 100644 --- a/util/system/progname.cpp +++ b/util/system/progname.cpp @@ -9,7 +9,7 @@ static const char* Argv0; namespace { struct TProgramNameHolder { inline TProgramNameHolder() - : ProgName(GetFileNameComponent(Argv0 ? Argv0 : GetExecPath().data())) + : ProgName(GetFileNameComponent(Argv0 ? Argv0 : GetExecPath().data())) { } diff --git a/util/system/protect.cpp b/util/system/protect.cpp index 20a4ba5a08..bbb8d410df 100644 --- a/util/system/protect.cpp +++ b/util/system/protect.cpp @@ -29,7 +29,7 @@ static TString ModeToString(const EProtectMemory mode) { if (mode & PM_EXEC) { strMode += "PM_EXEC|"; } - return strMode.substr(0, strMode.size() - 1); + return strMode.substr(0, strMode.size() - 1); } void ProtectMemory(void* addr, const size_t length, const EProtectMemory mode) { diff --git a/util/system/shellcommand.cpp b/util/system/shellcommand.cpp index aa84ea1661..b1989b5c8c 100644 --- a/util/system/shellcommand.cpp +++ b/util/system/shellcommand.cpp @@ -563,13 +563,13 @@ void TShellCommand::TImpl::StartProcess(TShellCommand::TImpl::TPipes& pipes) { Y_ENSURE_EX(cmd.size() < MAX_COMMAND_LINE, yexception() << "Command is too long (length=" << cmd.size() << ")"); TTempArray<wchar_t> cmdcopy(MAX_COMMAND_LINE); - Copy(cmd.data(), cmd.data() + cmd.size(), cmdcopy.Data()); - *(cmdcopy.Data() + cmd.size()) = 0; + Copy(cmd.data(), cmd.data() + cmd.size(), cmdcopy.Data()); + *(cmdcopy.Data() + cmd.size()) = 0; const wchar_t* cwd = NULL; std::wstring cwdBuff; - if (WorkDir.size()) { - cwdBuff = GetWString(WorkDir.data()); + if (WorkDir.size()) { + cwdBuff = GetWString(WorkDir.data()); cwd = cwdBuff.c_str(); } @@ -580,7 +580,7 @@ void TShellCommand::TImpl::StartProcess(TShellCommand::TImpl::TPipes& pipes) { env += e->first + '=' + e->second + '\0'; } env += '\0'; - lpEnvironment = const_cast<char*>(env.data()); + lpEnvironment = const_cast<char*>(env.data()); } // disable messagebox (may be in debug too) @@ -602,9 +602,9 @@ void TShellCommand::TImpl::StartProcess(TShellCommand::TImpl::TPipes& pipes) { &process_info); } else { res = CreateProcessWithLogonW( - GetWString(User.Name.data()).c_str(), + GetWString(User.Name.data()).c_str(), nullptr, // domain (if this parameter is NULL, the user name must be specified in UPN format) - GetWString(User.Password.data()).c_str(), + GetWString(User.Password.data()).c_str(), 0, // logon flags NULL, // image name cmdcopy.Data(), @@ -796,12 +796,12 @@ void TShellCommand::TImpl::Run() { qargv.push_back(const_cast<char*>("-c")); // two args for 'sh -c -- ', // one for program name, and one for NULL at the end - qargv.push_back(const_cast<char*>(shellArg.data())); + qargv.push_back(const_cast<char*>(shellArg.data())); } else { qargv.reserve(Arguments.size() + 2); - qargv.push_back(const_cast<char*>(Command.data())); + qargv.push_back(const_cast<char*>(Command.data())); for (auto& i : Arguments) { - qargv.push_back(const_cast<char*>(i.data())); + qargv.push_back(const_cast<char*>(i.data())); } } @@ -812,7 +812,7 @@ void TShellCommand::TImpl::Run() { if (!Environment.empty()) { for (auto& env : Environment) { envHolder.emplace_back(env.first + '=' + env.second); - envp.push_back(const_cast<char*>(envHolder.back().data())); + envp.push_back(const_cast<char*>(envHolder.back().data())); } envp.push_back(nullptr); } diff --git a/util/system/shellcommand_ut.cpp b/util/system/shellcommand_ut.cpp index cea2777100..9d849279d2 100644 --- a/util/system/shellcommand_ut.cpp +++ b/util/system/shellcommand_ut.cpp @@ -139,7 +139,7 @@ Y_UNIT_TEST_SUITE(TShellCommandTest) { << "sort"; cmd.Run(); UNIT_ASSERT(TShellCommand::SHELL_FINISHED == cmd.GetStatus()); - UNIT_ASSERT_VALUES_EQUAL(cmd.GetError().size(), 0u); + UNIT_ASSERT_VALUES_EQUAL(cmd.GetError().size(), 0u); UNIT_ASSERT(cmd.GetExitCode().Defined() && 0 == cmd.GetExitCode()); } } @@ -164,7 +164,7 @@ Y_UNIT_TEST_SUITE(TShellCommandTest) { UNIT_ASSERT_VALUES_EQUAL(cmd.GetError(), ""); #if !defined(_win_) UNIT_ASSERT(TShellCommand::SHELL_FINISHED == cmd.GetStatus()); - UNIT_ASSERT_VALUES_EQUAL(cmd.GetOutput().size(), 0u); + UNIT_ASSERT_VALUES_EQUAL(cmd.GetOutput().size(), 0u); UNIT_ASSERT(cmd.GetExitCode().Defined() && 0 == cmd.GetExitCode()); #endif } @@ -183,20 +183,20 @@ Y_UNIT_TEST_SUITE(TShellCommandTest) { #else UNIT_ASSERT_VALUES_EQUAL(input, output); #endif - UNIT_ASSERT_VALUES_EQUAL(cmd.GetError().size(), 0u); + UNIT_ASSERT_VALUES_EQUAL(cmd.GetError().size(), 0u); } Y_UNIT_TEST(TestRunNonexistent) { TShellCommand cmd("iwerognweiofnewio"); // some nonexistent command name cmd.Run().Wait(); UNIT_ASSERT(TShellCommand::SHELL_ERROR == cmd.GetStatus()); - UNIT_ASSERT_VALUES_UNEQUAL(cmd.GetError().size(), 0u); + UNIT_ASSERT_VALUES_UNEQUAL(cmd.GetError().size(), 0u); UNIT_ASSERT(cmd.GetExitCode().Defined() && 0 != cmd.GetExitCode()); } Y_UNIT_TEST(TestExitCode) { TShellCommand cmd("grep qwerty qwerty"); // some nonexistent file name cmd.Run().Wait(); UNIT_ASSERT(TShellCommand::SHELL_ERROR == cmd.GetStatus()); - UNIT_ASSERT_VALUES_UNEQUAL(cmd.GetError().size(), 0u); + UNIT_ASSERT_VALUES_UNEQUAL(cmd.GetError().size(), 0u); UNIT_ASSERT(cmd.GetExitCode().Defined() && 2 == cmd.GetExitCode()); } // 'type con' and 'copy con con' want real console, not stdin, use sort @@ -208,7 +208,7 @@ Y_UNIT_TEST_SUITE(TShellCommandTest) { TShellCommand cmd(catCommand, options); cmd.Run().Wait(); UNIT_ASSERT_VALUES_EQUAL(input, cmd.GetOutput()); - UNIT_ASSERT_VALUES_EQUAL(cmd.GetError().size(), 0u); + UNIT_ASSERT_VALUES_EQUAL(cmd.GetError().size(), 0u); } Y_UNIT_TEST(TestOutput) { TShellCommandOptions options; @@ -221,7 +221,7 @@ Y_UNIT_TEST_SUITE(TShellCommandTest) { TShellCommand cmd(catCommand, options); cmd.Run().Wait(); UNIT_ASSERT_VALUES_EQUAL(input, output); - UNIT_ASSERT_VALUES_EQUAL(cmd.GetError().size(), 0u); + UNIT_ASSERT_VALUES_EQUAL(cmd.GetError().size(), 0u); } Y_UNIT_TEST(TestIO) { // descriptive test: use all options @@ -390,7 +390,7 @@ Y_UNIT_TEST_SUITE(TShellCommandTest) { TShellCommand cmd(catCommand, options); cmd.Run().Wait(); UNIT_ASSERT(TShellCommand::SHELL_INTERNAL_ERROR == cmd.GetStatus()); - UNIT_ASSERT_VALUES_UNEQUAL(cmd.GetInternalError().size(), 0u); + UNIT_ASSERT_VALUES_UNEQUAL(cmd.GetInternalError().size(), 0u); } Y_UNIT_TEST(TestHugeOutput) { TShellCommandOptions options; diff --git a/util/system/shmat.cpp b/util/system/shmat.cpp index 6795f17164..07ff0d6caa 100644 --- a/util/system/shmat.cpp +++ b/util/system/shmat.cpp @@ -170,7 +170,7 @@ static key_t GetKey(const TGUID& id) { } bool TSharedMemory::Open(const TGUID& id, int size) { - Y_VERIFY(id, "invalid shared memory guid: %s", GetGuidAsString(id).data()); + Y_VERIFY(id, "invalid shared memory guid: %s", GetGuidAsString(id).data()); //Y_ASSERT(Data == 0); Size = size; diff --git a/util/system/unaligned_mem.h b/util/system/unaligned_mem.h index 61433ccfbe..4b84686f2f 100644 --- a/util/system/unaligned_mem.h +++ b/util/system/unaligned_mem.h @@ -16,11 +16,11 @@ inline T ReadUnaligned(const void* from) noexcept { return ret; } -// std::remove_reference_t for non-deduced context to prevent such code to blow below: -// ui8 first = f(); ui8 second = g(); -// WriteUnaligned(to, first - second) (int will be deduced) +// std::remove_reference_t for non-deduced context to prevent such code to blow below: +// ui8 first = f(); ui8 second = g(); +// WriteUnaligned(to, first - second) (int will be deduced) template <class T> -inline void WriteUnaligned(void* to, const std::remove_reference_t<T>& t) noexcept { +inline void WriteUnaligned(void* to, const std::remove_reference_t<T>& t) noexcept { memcpy(to, &t, sizeof(T)); } diff --git a/util/system/unaligned_mem_ut.cpp b/util/system/unaligned_mem_ut.cpp index 3b4ebd8887..9de3f3e931 100644 --- a/util/system/unaligned_mem_ut.cpp +++ b/util/system/unaligned_mem_ut.cpp @@ -33,9 +33,9 @@ Y_UNIT_TEST_SUITE(UnalignedMem) { Y_UNIT_TEST(TestReadWrite) { alignas(ui64) char buf[100]; - WriteUnaligned<ui16>(buf + 1, (ui16)1); - WriteUnaligned<ui32>(buf + 1 + 2, (ui32)2); - WriteUnaligned<ui64>(buf + 1 + 2 + 4, (ui64)3); + WriteUnaligned<ui16>(buf + 1, (ui16)1); + WriteUnaligned<ui32>(buf + 1 + 2, (ui32)2); + WriteUnaligned<ui64>(buf + 1 + 2 + 4, (ui64)3); UNIT_ASSERT_VALUES_EQUAL(ReadUnaligned<ui16>(buf + 1), 1); UNIT_ASSERT_VALUES_EQUAL(ReadUnaligned<ui32>(buf + 1 + 2), 2); @@ -48,9 +48,9 @@ Y_UNIT_TEST_SUITE(UnalignedMem) { alignas(ui64) static char buf[100] = {0}; // static is required for Clobber to work - WriteUnaligned<ui16>(buf + 1, (ui16)1); - WriteUnaligned<ui32>(buf + 1 + 2, (ui32)2); - WriteUnaligned<ui64>(buf + 1 + 2 + 4, (ui64)3); + WriteUnaligned<ui16>(buf + 1, (ui16)1); + WriteUnaligned<ui32>(buf + 1 + 2, (ui32)2); + WriteUnaligned<ui64>(buf + 1 + 2 + 4, (ui64)3); NBench::Clobber(); auto val1 = ReadUnaligned<ui16>(buf + 1); @@ -72,7 +72,7 @@ Y_UNIT_TEST_SUITE(UnalignedMem) { Y_UNIT_TEST(TestReadWrite128) { alignas(TUInt128) char buf[100] = {0}; - WriteUnaligned<TUInt128>(buf + 1, TUInt128::Max()); + WriteUnaligned<TUInt128>(buf + 1, TUInt128::Max()); auto val = ReadUnaligned<TUInt128>(buf + 1); UNIT_ASSERT(val == TUInt128::Max()); } @@ -82,7 +82,7 @@ Y_UNIT_TEST_SUITE(UnalignedMem) { alignas(TUInt128) static char buf[100] = {0}; // static is required for Clobber to work - WriteUnaligned<TUInt128>(buf + 1, TUInt128::Max()); + WriteUnaligned<TUInt128>(buf + 1, TUInt128::Max()); NBench::Clobber(); auto val = ReadUnaligned<TUInt128>(buf + 1); diff --git a/util/ysaveload_ut.cpp b/util/ysaveload_ut.cpp index 4030241313..723c68f391 100644 --- a/util/ysaveload_ut.cpp +++ b/util/ysaveload_ut.cpp @@ -253,7 +253,7 @@ private: TVector<ui16> vec; Load(&S_, vec); - UNIT_ASSERT_EQUAL(vec.size(), 3); + UNIT_ASSERT_EQUAL(vec.size(), 3); UNIT_ASSERT_EQUAL(vec[0], 1); UNIT_ASSERT_EQUAL(vec[1], 2); UNIT_ASSERT_EQUAL(vec[2], 4); @@ -306,8 +306,8 @@ private: TBuffer buf; Load(&S_, buf); - UNIT_ASSERT_EQUAL(buf.size(), 4); - UNIT_ASSERT_EQUAL(memcmp(buf.data(), "asdf", 4), 0); + UNIT_ASSERT_EQUAL(buf.size(), 4); + UNIT_ASSERT_EQUAL(memcmp(buf.data(), "asdf", 4), 0); } { @@ -316,7 +316,7 @@ private: Load(&S_, vec, pool); - UNIT_ASSERT_EQUAL(vec.size(), 3); + UNIT_ASSERT_EQUAL(vec.size(), 3); UNIT_ASSERT_EQUAL(vec[0], TString("1")); UNIT_ASSERT_EQUAL(vec[1], TString("123")); UNIT_ASSERT_EQUAL(vec[2], TString("4567")); @@ -327,7 +327,7 @@ private: Load(&S_, deq); - UNIT_ASSERT_EQUAL(deq.size(), 4); + UNIT_ASSERT_EQUAL(deq.size(), 4); UNIT_ASSERT_EQUAL(deq[0], 1); UNIT_ASSERT_EQUAL(deq[1], 2); UNIT_ASSERT_EQUAL(deq[2], 4); |