aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/on_disk/chunks
diff options
context:
space:
mode:
authorAnton Samokhvalov <pg83@yandex.ru>2022-02-10 16:45:15 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:45:15 +0300
commit72cb13b4aff9bc9cf22e49251bc8fd143f82538f (patch)
treeda2c34829458c7d4e74bdfbdf85dff449e9e7fb8 /library/cpp/on_disk/chunks
parent778e51ba091dc39e7b7fcab2b9cf4dbedfb6f2b5 (diff)
downloadydb-72cb13b4aff9bc9cf22e49251bc8fd143f82538f.tar.gz
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 1 of 2.
Diffstat (limited to 'library/cpp/on_disk/chunks')
-rw-r--r--library/cpp/on_disk/chunks/chunked_helpers.cpp4
-rw-r--r--library/cpp/on_disk/chunks/chunked_helpers.h238
-rw-r--r--library/cpp/on_disk/chunks/chunks_ut.cpp32
-rw-r--r--library/cpp/on_disk/chunks/reader.h64
-rw-r--r--library/cpp/on_disk/chunks/writer.h64
-rw-r--r--library/cpp/on_disk/chunks/ya.make2
6 files changed, 202 insertions, 202 deletions
diff --git a/library/cpp/on_disk/chunks/chunked_helpers.cpp b/library/cpp/on_disk/chunks/chunked_helpers.cpp
index b7adba2753..9671529fe8 100644
--- a/library/cpp/on_disk/chunks/chunked_helpers.cpp
+++ b/library/cpp/on_disk/chunks/chunked_helpers.cpp
@@ -12,7 +12,7 @@ TBlob GetBlock(const TBlob& blob, size_t index) {
/*************************** TNamedChunkedDataReader ***************************/
-static const char* NamedChunkedDataMagic = "NamedChunkedData";
+static const char* NamedChunkedDataMagic = "NamedChunkedData";
TNamedChunkedDataReader::TNamedChunkedDataReader(const TBlob& blob)
: TChunkedDataReader(blob)
@@ -25,7 +25,7 @@ TNamedChunkedDataReader::TNamedChunkedDataReader(const TBlob& blob)
if (GetBlockLen(block) < magicLen || memcmp(GetBlock(block), NamedChunkedDataMagic, magicLen) != 0)
throw yexception() << "Not a valid named chunked data file";
- TMemoryInput input(static_cast<const char*>(GetBlock(block)) + magicLen, GetBlockLen(block) - magicLen);
+ TMemoryInput input(static_cast<const char*>(GetBlock(block)) + magicLen, GetBlockLen(block) - magicLen);
Load(&input, Names);
size_t index = 0;
diff --git a/library/cpp/on_disk/chunks/chunked_helpers.h b/library/cpp/on_disk/chunks/chunked_helpers.h
index 5fa96afdca..4f5421c71d 100644
--- a/library/cpp/on_disk/chunks/chunked_helpers.h
+++ b/library/cpp/on_disk/chunks/chunked_helpers.h
@@ -2,9 +2,9 @@
#include <util/generic/vector.h>
#include <util/generic/buffer.h>
-#include <util/generic/hash_set.h>
+#include <util/generic/hash_set.h>
#include <util/generic/cast.h>
-#include <util/generic/ymath.h>
+#include <util/generic/ymath.h>
#include <util/memory/blob.h>
#include <util/stream/buffer.h>
#include <util/stream/mem.h>
@@ -17,7 +17,7 @@
#include <cmath>
#include <cstddef>
-template <typename T>
+template <typename T>
class TYVector {
private:
ui32 Size;
@@ -26,7 +26,7 @@ private:
public:
TYVector(const TBlob& blob)
: Size(IntegerCast<ui32>(ReadUnaligned<ui64>(blob.Data())))
- , Data((const T*)((const char*)blob.Data() + sizeof(ui64)))
+ , Data((const T*)((const char*)blob.Data() + sizeof(ui64)))
{
}
@@ -45,13 +45,13 @@ public:
}
size_t RealSize() const {
- return sizeof(ui64) + Size * sizeof(T);
+ return sizeof(ui64) + Size * sizeof(T);
}
~TYVector() = default;
};
-template <typename T>
+template <typename T>
class TYVectorWriter {
private:
TVector<T> Vector;
@@ -90,21 +90,21 @@ public:
void Resize(size_t size) {
Vector.resize(size);
}
-
+
void Resize(size_t size, const T& value) {
Vector.resize(size, value);
}
};
-template <typename T, bool>
+template <typename T, bool>
struct TYVectorG;
-template <typename X>
+template <typename X>
struct TYVectorG<X, false> {
typedef TYVector<X> T;
};
-template <typename X>
+template <typename X>
struct TYVectorG<X, true> {
typedef TYVectorWriter<X> T;
};
@@ -116,18 +116,18 @@ struct TIsMemsetThisWithZeroesSupported {
};
};
-#define MEMSET_THIS_WITH_ZEROES_SUPPORTED(type) \
- template <> \
- struct TIsMemsetThisWithZeroesSupported<type> { \
- enum { \
- Result = true \
- }; \
+#define MEMSET_THIS_WITH_ZEROES_SUPPORTED(type) \
+ template <> \
+ struct TIsMemsetThisWithZeroesSupported<type> { \
+ enum { \
+ Result = true \
+ }; \
};
class TPlainHashCommon {
protected:
#pragma pack(push, 8)
- template <typename TKey, typename TValue>
+ template <typename TKey, typename TValue>
class TPackedPair {
private:
typedef TPackedPair<TKey, TValue> TThis;
@@ -135,8 +135,8 @@ protected:
TValue Value;
private:
- static_assert(TIsMemsetThisWithZeroesSupported<TKey>::Result, "expect TIsMemsetThisWithZeroesSupported<TKey>::Result");
- static_assert(TIsMemsetThisWithZeroesSupported<TValue>::Result, "expect TIsMemsetThisWithZeroesSupported<TValue>::Result");
+ static_assert(TIsMemsetThisWithZeroesSupported<TKey>::Result, "expect TIsMemsetThisWithZeroesSupported<TKey>::Result");
+ static_assert(TIsMemsetThisWithZeroesSupported<TValue>::Result, "expect TIsMemsetThisWithZeroesSupported<TValue>::Result");
/// to aviod uninitialized bytes
void Init(const TKey& key, const TValue& value) {
@@ -217,9 +217,9 @@ protected:
}
};
#pragma pack(pop)
- static_assert(8 == sizeof(TInterval), "expect 8 == sizeof(TInterval)");
+ static_assert(8 == sizeof(TInterval), "expect 8 == sizeof(TInterval)");
- template <typename TKey>
+ template <typename TKey>
static ui32 KeyHash(typename TTypeTraits<TKey>::TFuncParam key, ui16 bits) {
Y_ASSERT(bits < 32);
const ui32 res = ui32(key) & ((ui32(1) << bits) - 1);
@@ -229,7 +229,7 @@ protected:
}
};
-template <typename TKey, typename TValue>
+template <typename TKey, typename TValue>
class TPlainHashWriter : TPlainHashCommon {
private:
typedef TPackedPair<TKey, TValue> TKeyValuePair;
@@ -250,7 +250,7 @@ private:
public:
void Add(const TKey& key, const TValue& value) {
- Data.push_back(TKeyValuePair(key, value));
+ Data.push_back(TKeyValuePair(key, value));
}
void Save(IOutputStream& out) const {
@@ -262,8 +262,8 @@ public:
ui16 bits;
if (!Data.empty()) {
- bits = (ui16)(log((float)Data.size()) / log(2.f));
- while ((bits < 22) && !IsPlainEnought(bits))
+ bits = (ui16)(log((float)Data.size()) / log(2.f));
+ while ((bits < 22) && !IsPlainEnought(bits))
++bits;
} else {
bits = 0;
@@ -298,7 +298,7 @@ public:
}
};
-template <typename TKey, typename TValue>
+template <typename TKey, typename TValue>
class TPlainHash : TPlainHashCommon {
private:
typedef TPackedPair<TKey, TValue> TKeyValuePair;
@@ -321,9 +321,9 @@ private:
return (const TKeyValuePair*)(GetIntervals() + (1ULL << GetBits()));
}
- template <typename T>
+ template <typename T>
void Init(const T* p) {
- static_assert(sizeof(T) == 1, "expect sizeof(T) == 1");
+ static_assert(sizeof(T) == 1, "expect sizeof(T) == 1");
P = reinterpret_cast<const char*>(p);
#ifndef NDEBUG
ui16 version = ReadUnaligned<ui16>(p);
@@ -383,24 +383,24 @@ public:
}
size_t ByteSize() const {
- return 12 + sizeof(TInterval) * (size_t(1) << GetBits()) + sizeof(TKeyValuePair) * GetSize();
+ return 12 + sizeof(TInterval) * (size_t(1) << GetBits()) + sizeof(TKeyValuePair) * GetSize();
}
};
-template <typename Key, typename Value, bool>
+template <typename Key, typename Value, bool>
struct TPlainHashG;
-template <typename Key, typename Value>
+template <typename Key, typename Value>
struct TPlainHashG<Key, Value, false> {
typedef TPlainHash<Key, Value> T;
};
-template <typename Key, typename Value>
+template <typename Key, typename Value>
struct TPlainHashG<Key, Value, true> {
typedef TPlainHashWriter<Key, Value> T;
};
-template <typename T>
+template <typename T>
class TSingleValue {
private:
const T* Value;
@@ -417,7 +417,7 @@ public:
}
};
-template <typename T>
+template <typename T>
class TSingleValueWriter {
private:
T Value;
@@ -425,7 +425,7 @@ private:
public:
TSingleValueWriter() = default;
- TSingleValueWriter(const T& value)
+ TSingleValueWriter(const T& value)
: Value(value)
{
}
@@ -441,13 +441,13 @@ public:
TBlob GetBlock(const TBlob& data, size_t index);
-template <class T>
+template <class T>
void WriteBlock(TChunkedDataWriter& writer, const T& t) {
writer.NewBlock();
t.Save(writer);
}
-template <class T>
+template <class T>
void WriteBlock(TChunkedDataWriter& writer, T& t) {
writer.NewBlock();
t.Save(writer);
@@ -455,78 +455,78 @@ void WriteBlock(TChunkedDataWriter& writer, T& t) {
// Extends TChunkedDataWriter, allowing user to name blocks with arbitrary strings.
class TNamedChunkedDataWriter: public TChunkedDataWriter {
-public:
- TNamedChunkedDataWriter(IOutputStream& slave);
- ~TNamedChunkedDataWriter() override;
+public:
+ TNamedChunkedDataWriter(IOutputStream& slave);
+ ~TNamedChunkedDataWriter() override;
- // Start a new unnamed block, overrides TChunkedDataReader::NewBlock().
- void NewBlock();
+ // Start a new unnamed block, overrides TChunkedDataReader::NewBlock().
+ void NewBlock();
- // Start a new block with given name (possibly empty, in which case block is unnamed).
- // Throws an exception if name is a duplicate.
- void NewBlock(const TString& name);
+ // Start a new block with given name (possibly empty, in which case block is unnamed).
+ // Throws an exception if name is a duplicate.
+ void NewBlock(const TString& name);
- void WriteFooter();
+ void WriteFooter();
-private:
- TVector<TString> Names;
- THashMap<TString, size_t> NameToIndex;
+private:
+ TVector<TString> Names;
+ THashMap<TString, size_t> NameToIndex;
};
-class TNamedChunkedDataReader: public TChunkedDataReader {
-public:
- TNamedChunkedDataReader(const TBlob& blob);
-
- inline bool HasBlock(const char* name) const {
- return NameToIndex.find(name) != NameToIndex.end();
- }
-
- inline size_t GetIndexByName(const char* name) const {
- THashMap<TString, size_t>::const_iterator it = NameToIndex.find(name);
- if (it == NameToIndex.end())
- throw yexception() << "Block \"" << name << "\" is not found";
- else
- return it->second;
- }
-
- // Returns number of blocks written to the file by user of TNamedChunkedDataReader.
- inline size_t GetBlocksCount() const {
- // Last block is for internal usage
- return TChunkedDataReader::GetBlocksCount() - 1;
- }
-
- inline const char* GetBlockName(size_t index) const {
- Y_ASSERT(index < GetBlocksCount());
+class TNamedChunkedDataReader: public TChunkedDataReader {
+public:
+ TNamedChunkedDataReader(const TBlob& blob);
+
+ inline bool HasBlock(const char* name) const {
+ return NameToIndex.find(name) != NameToIndex.end();
+ }
+
+ inline size_t GetIndexByName(const char* name) const {
+ THashMap<TString, size_t>::const_iterator it = NameToIndex.find(name);
+ if (it == NameToIndex.end())
+ throw yexception() << "Block \"" << name << "\" is not found";
+ else
+ return it->second;
+ }
+
+ // Returns number of blocks written to the file by user of TNamedChunkedDataReader.
+ inline size_t GetBlocksCount() const {
+ // Last block is for internal usage
+ return TChunkedDataReader::GetBlocksCount() - 1;
+ }
+
+ inline const char* GetBlockName(size_t index) const {
+ Y_ASSERT(index < GetBlocksCount());
return Names[index].data();
- }
-
- inline const void* GetBlockByName(const char* name) const {
- return GetBlock(GetIndexByName(name));
- }
-
- inline size_t GetBlockLenByName(const char* name) const {
- return GetBlockLen(GetIndexByName(name));
- }
-
- inline TBlob GetBlobByName(const char* name) const {
- size_t id = GetIndexByName(name);
- return TBlob::NoCopy(GetBlock(id), GetBlockLen(id));
- }
-
- inline bool GetBlobByName(const char* name, TBlob& blob) const {
- THashMap<TString, size_t>::const_iterator it = NameToIndex.find(name);
- if (it == NameToIndex.end())
- return false;
- blob = TBlob::NoCopy(GetBlock(it->second), GetBlockLen(it->second));
- return true;
- }
-
-private:
- TVector<TString> Names;
- THashMap<TString, size_t> NameToIndex;
+ }
+
+ inline const void* GetBlockByName(const char* name) const {
+ return GetBlock(GetIndexByName(name));
+ }
+
+ inline size_t GetBlockLenByName(const char* name) const {
+ return GetBlockLen(GetIndexByName(name));
+ }
+
+ inline TBlob GetBlobByName(const char* name) const {
+ size_t id = GetIndexByName(name);
+ return TBlob::NoCopy(GetBlock(id), GetBlockLen(id));
+ }
+
+ inline bool GetBlobByName(const char* name, TBlob& blob) const {
+ THashMap<TString, size_t>::const_iterator it = NameToIndex.find(name);
+ if (it == NameToIndex.end())
+ return false;
+ blob = TBlob::NoCopy(GetBlock(it->second), GetBlockLen(it->second));
+ return true;
+ }
+
+private:
+ TVector<TString> Names;
+ THashMap<TString, size_t> NameToIndex;
};
-template <class T>
+template <class T>
struct TSaveLoadVectorNonPodElement {
static inline void Save(IOutputStream* out, const T& t) {
TSerializer<T>::Save(out, t);
@@ -538,7 +538,7 @@ struct TSaveLoadVectorNonPodElement {
}
};
-template <class T, bool isPod>
+template <class T, bool isPod>
class TVectorTakingIntoAccountThePodType {
private:
ui64 SizeofOffsets;
@@ -550,7 +550,7 @@ public:
SizeofOffsets = ReadUnaligned<ui64>(blob.Begin());
Y_ASSERT(SizeofOffsets > 0);
Offsets = reinterpret_cast<const ui64*>(blob.Begin() + sizeof(ui64));
- Data = reinterpret_cast<const char*>(blob.Begin() + sizeof(ui64) + SizeofOffsets * sizeof(ui64));
+ Data = reinterpret_cast<const char*>(blob.Begin() + sizeof(ui64) + SizeofOffsets * sizeof(ui64));
}
size_t GetSize() const {
@@ -576,11 +576,11 @@ public:
}
size_t RealSize() const {
- return sizeof(ui64) * (SizeofOffsets + 1) + ReadUnaligned<ui64>(Offsets + SizeofOffsets - 1);
+ return sizeof(ui64) * (SizeofOffsets + 1) + ReadUnaligned<ui64>(Offsets + SizeofOffsets - 1);
}
};
-template <class T, bool isPod>
+template <class T, bool isPod>
class TVectorTakingIntoAccountThePodTypeWriter : TNonCopyable {
private:
typedef TVector<ui64> TOffsets;
@@ -613,8 +613,8 @@ public:
}
};
-template <class T>
-class TVectorTakingIntoAccountThePodType<T, true>: public TYVector<T> {
+template <class T>
+class TVectorTakingIntoAccountThePodType<T, true>: public TYVector<T> {
public:
TVectorTakingIntoAccountThePodType(const TBlob& blob)
: TYVector<T>(blob)
@@ -622,14 +622,14 @@ public:
}
};
-template <class T>
-class TVectorTakingIntoAccountThePodTypeWriter<T, true>: public TYVectorWriter<T> {
+template <class T>
+class TVectorTakingIntoAccountThePodTypeWriter<T, true>: public TYVectorWriter<T> {
};
-template <typename T>
-class TGeneralVector: public TVectorTakingIntoAccountThePodType<T, TTypeTraits<T>::IsPod> {
+template <typename T>
+class TGeneralVector: public TVectorTakingIntoAccountThePodType<T, TTypeTraits<T>::IsPod> {
typedef TVectorTakingIntoAccountThePodType<T, TTypeTraits<T>::IsPod> TBase;
-
+
public:
TGeneralVector(const TBlob& blob)
: TBase(blob)
@@ -637,24 +637,24 @@ public:
}
};
-template <typename T>
-class TGeneralVectorWriter: public TVectorTakingIntoAccountThePodTypeWriter<T, TTypeTraits<T>::IsPod> {
+template <typename T>
+class TGeneralVectorWriter: public TVectorTakingIntoAccountThePodTypeWriter<T, TTypeTraits<T>::IsPod> {
};
-template <typename TItem, bool>
+template <typename TItem, bool>
struct TGeneralVectorG;
-template <typename TItem>
+template <typename TItem>
struct TGeneralVectorG<TItem, false> {
typedef TGeneralVector<TItem> T;
};
-template <typename TItem>
+template <typename TItem>
struct TGeneralVectorG<TItem, true> {
typedef TGeneralVectorWriter<TItem> T;
};
-template <>
+template <>
struct TSaveLoadVectorNonPodElement<TString> {
static inline void Save(IOutputStream* out, const TString& s) {
out->Write(s.data(), s.size() + 1);
@@ -666,8 +666,8 @@ struct TSaveLoadVectorNonPodElement<TString> {
}
};
-template <bool G>
-struct TStringsVectorG: public TGeneralVectorG<TString, G> {
+template <bool G>
+struct TStringsVectorG: public TGeneralVectorG<TString, G> {
};
using TStringsVector = TGeneralVector<TString>;
diff --git a/library/cpp/on_disk/chunks/chunks_ut.cpp b/library/cpp/on_disk/chunks/chunks_ut.cpp
index f727647f7f..4161851f7d 100644
--- a/library/cpp/on_disk/chunks/chunks_ut.cpp
+++ b/library/cpp/on_disk/chunks/chunks_ut.cpp
@@ -17,7 +17,7 @@ struct TPodStruct {
}
};
/// And its serialization
-template <>
+template <>
struct TSaveLoadVectorNonPodElement<TPodStruct> {
typedef TPodStruct TItem;
static inline void Save(IOutputStream* out, const TItem& item) {
@@ -32,14 +32,14 @@ struct TSaveLoadVectorNonPodElement<TPodStruct> {
}
};
-class TChunkedHelpersTest: public TTestBase {
+class TChunkedHelpersTest: public TTestBase {
UNIT_TEST_SUITE(TChunkedHelpersTest);
- UNIT_TEST(TestHash)
- UNIT_TEST(TestGeneralVector)
- UNIT_TEST(TestStrings);
- UNIT_TEST(TestNamedChunkedData);
+ UNIT_TEST(TestHash)
+ UNIT_TEST(TestGeneralVector)
+ UNIT_TEST(TestStrings);
+ UNIT_TEST(TestNamedChunkedData);
UNIT_TEST_SUITE_END();
-
+
public:
void TestHash() {
{
@@ -54,7 +54,7 @@ public:
TBlob temp = TBlob::FromStreamSingleThreaded(stream);
TPlainHash<ui64, ui16> reader(temp);
ui16 value = 0;
- UNIT_ASSERT(reader.Find(5, &value));
+ UNIT_ASSERT(reader.Find(5, &value));
UNIT_ASSERT_EQUAL(7, value);
UNIT_ASSERT(!reader.Find(6, &value));
}
@@ -99,7 +99,7 @@ public:
UNIT_ASSERT_EQUAL(value, i);
UNIT_ASSERT_EQUAL(reader.At(i), i);
}
- UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) + N * sizeof(ui32));
+ UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) + N * sizeof(ui32));
}
}
{ /// TString
@@ -121,7 +121,7 @@ public:
UNIT_ASSERT_EQUAL(value, ToString(i));
UNIT_ASSERT_EQUAL(reader.Get(i), ToString(i));
}
- UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) * (N + 2) + N * 2);
+ UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) * (N + 2) + N * 2);
}
}
{ /// some other struct
@@ -146,7 +146,7 @@ public:
reader.Get(1, value);
UNIT_ASSERT(value.x == 3 && value.y == 4.0);
- UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) * (N + 2) + N * sizeof(TItem));
+ UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) * (N + 2) + N * sizeof(TItem));
}
}
{ /// pointer
@@ -172,7 +172,7 @@ public:
UNIT_ASSERT_EQUAL(value, a + i);
UNIT_ASSERT_EQUAL(reader.At(i), a + i);
}
- UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) + N * sizeof(int*));
+ UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) + N * sizeof(int*));
}
}
{ /// std::pair<int, int>
@@ -194,7 +194,7 @@ public:
reader.Get(i, value);
UNIT_ASSERT_EQUAL(value, TItem(i, i));
}
- UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) + N * sizeof(TItem));
+ UNIT_ASSERT_EQUAL(reader.RealSize(), sizeof(ui64) + N * sizeof(TItem));
}
}
}
@@ -262,7 +262,7 @@ public:
UNIT_ASSERT_STRINGS_EQUAL(reader.GetBlockName(1), "");
UNIT_ASSERT_STRINGS_EQUAL(reader.GetBlockName(2), "omega");
- UNIT_ASSERT_EQUAL(reader.GetBlockLenByName("alpha"), 6); // padding not included
+ UNIT_ASSERT_EQUAL(reader.GetBlockLenByName("alpha"), 6); // padding not included
UNIT_ASSERT_EQUAL(reader.GetBlockLenByName("omega"), 17);
UNIT_ASSERT(memcmp(reader.GetBlockByName("alpha"), "123456", 6) == 0);
@@ -277,8 +277,8 @@ UNIT_TEST_SUITE_REGISTRATION(TChunkedHelpersTest);
class TChunkedDataTest: public TTestBase {
private:
UNIT_TEST_SUITE(TChunkedDataTest);
- UNIT_TEST(Test)
- UNIT_TEST(TestEmpty)
+ UNIT_TEST(Test)
+ UNIT_TEST(TestEmpty)
UNIT_TEST_SUITE_END();
void Test() {
diff --git a/library/cpp/on_disk/chunks/reader.h b/library/cpp/on_disk/chunks/reader.h
index c5fe783319..aba81a355f 100644
--- a/library/cpp/on_disk/chunks/reader.h
+++ b/library/cpp/on_disk/chunks/reader.h
@@ -7,51 +7,51 @@
class TBlob;
class TChunkedDataReader {
-public:
- TChunkedDataReader(const TBlob& blob);
+public:
+ TChunkedDataReader(const TBlob& blob);
- inline const void* GetBlock(size_t index) const {
- CheckIndex(index);
- return Offsets[index];
- }
+ inline const void* GetBlock(size_t index) const {
+ CheckIndex(index);
+ return Offsets[index];
+ }
- inline size_t GetBlockLen(size_t index) const {
- CheckIndex(index);
+ inline size_t GetBlockLen(size_t index) const {
+ CheckIndex(index);
- if (Version == 0) {
- if (index + 1 < Offsets.size()) {
- return Offsets[index + 1] - Offsets[index];
+ if (Version == 0) {
+ if (index + 1 < Offsets.size()) {
+ return Offsets[index + 1] - Offsets[index];
}
- return Size - (Offsets.back() - Offsets.front());
+ return Size - (Offsets.back() - Offsets.front());
}
- return Lengths[index];
- }
+ return Lengths[index];
+ }
- TBlob GetBlob(size_t index) const;
+ TBlob GetBlob(size_t index) const;
- template <typename T>
+ template <typename T>
TArrayRef<const T> GetRegion(size_t index) const {
- size_t len = GetBlockLen(index);
- Y_ENSURE(len % sizeof(T) == 0, "wrong data padding");
+ size_t len = GetBlockLen(index);
+ Y_ENSURE(len % sizeof(T) == 0, "wrong data padding");
return TArrayRef<const T>(reinterpret_cast<const T*>(GetBlock(index)), len / sizeof(T));
- }
+ }
- inline size_t GetBlocksCount() const {
- return Offsets.size();
- }
+ inline size_t GetBlocksCount() const {
+ return Offsets.size();
+ }
-private:
- inline void CheckIndex(size_t index) const {
- if (index >= GetBlocksCount()) {
- ythrow yexception() << "requested block " << index << " of " << GetBlocksCount() << " blocks";
+private:
+ inline void CheckIndex(size_t index) const {
+ if (index >= GetBlocksCount()) {
+ ythrow yexception() << "requested block " << index << " of " << GetBlocksCount() << " blocks";
}
- }
+ }
-private:
- ui64 Version = 0;
- TVector<const char*> Offsets;
- TVector<size_t> Lengths;
- size_t Size = 0;
+private:
+ ui64 Version = 0;
+ TVector<const char*> Offsets;
+ TVector<size_t> Lengths;
+ size_t Size = 0;
};
diff --git a/library/cpp/on_disk/chunks/writer.h b/library/cpp/on_disk/chunks/writer.h
index ab14522bdd..fbd02eef4b 100644
--- a/library/cpp/on_disk/chunks/writer.h
+++ b/library/cpp/on_disk/chunks/writer.h
@@ -9,49 +9,49 @@ inline void WriteBin(IOutputStream* out, typename TTypeTraits<T>::TFuncParam t)
}
class TChunkedDataWriter: public IOutputStream {
-public:
- TChunkedDataWriter(IOutputStream& slave);
- ~TChunkedDataWriter() override;
+public:
+ TChunkedDataWriter(IOutputStream& slave);
+ ~TChunkedDataWriter() override;
- void NewBlock();
+ void NewBlock();
- template <typename T>
- inline void WriteBinary(typename TTypeTraits<T>::TFuncParam t) {
- this->Write(&t, sizeof(T));
- }
+ template <typename T>
+ inline void WriteBinary(typename TTypeTraits<T>::TFuncParam t) {
+ this->Write(&t, sizeof(T));
+ }
- void WriteFooter();
+ void WriteFooter();
- size_t GetCurrentBlockOffset() const;
- size_t GetBlockCount() const;
+ size_t GetCurrentBlockOffset() const;
+ size_t GetBlockCount() const;
-protected:
- void DoWrite(const void* buf, size_t len) override {
- Slave.Write(buf, len);
- Offset += len;
- }
+protected:
+ void DoWrite(const void* buf, size_t len) override {
+ Slave.Write(buf, len);
+ Offset += len;
+ }
-private:
- static inline size_t PaddingSize(size_t size, size_t boundary) noexcept {
- const size_t boundaryViolation = size % boundary;
+private:
+ static inline size_t PaddingSize(size_t size, size_t boundary) noexcept {
+ const size_t boundaryViolation = size % boundary;
- return boundaryViolation == 0 ? 0 : boundary - boundaryViolation;
- }
+ return boundaryViolation == 0 ? 0 : boundary - boundaryViolation;
+ }
- inline void Pad(size_t boundary) {
- const size_t newOffset = Offset + PaddingSize(Offset, boundary);
+ inline void Pad(size_t boundary) {
+ const size_t newOffset = Offset + PaddingSize(Offset, boundary);
- while (Offset < newOffset) {
- Write('\0');
+ while (Offset < newOffset) {
+ Write('\0');
}
- }
+ }
-private:
- static const ui64 Version = 1;
+private:
+ static const ui64 Version = 1;
- IOutputStream& Slave;
+ IOutputStream& Slave;
- size_t Offset;
- TVector<ui64> Offsets;
- TVector<ui64> Lengths;
+ size_t Offset;
+ TVector<ui64> Offsets;
+ TVector<ui64> Lengths;
};
diff --git a/library/cpp/on_disk/chunks/ya.make b/library/cpp/on_disk/chunks/ya.make
index acb52df5b0..93197cb1ce 100644
--- a/library/cpp/on_disk/chunks/ya.make
+++ b/library/cpp/on_disk/chunks/ya.make
@@ -1,7 +1,7 @@
LIBRARY()
OWNER(g:util)
-
+
SRCS(
chunked_helpers.cpp
reader.cpp