diff options
author | myltsev <myltsev@yandex-team.ru> | 2022-02-10 16:46:03 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:46:03 +0300 |
commit | 9166d66c30c23c9e85a7c88185a068987148d23f (patch) | |
tree | 421bdcec5755d9e441c485560aab5ab8d74c7475 /library/cpp/packers | |
parent | 8d3a5ed3a188a34167eaee54f1691ce5c9edf2f3 (diff) | |
download | ydb-9166d66c30c23c9e85a7c88185a068987148d23f.tar.gz |
Restoring authorship annotation for <myltsev@yandex-team.ru>. Commit 1 of 2.
Diffstat (limited to 'library/cpp/packers')
-rw-r--r-- | library/cpp/packers/region_packer.h | 14 | ||||
-rw-r--r-- | library/cpp/packers/ut/region_packer_ut.cpp | 60 |
2 files changed, 37 insertions, 37 deletions
diff --git a/library/cpp/packers/region_packer.h b/library/cpp/packers/region_packer.h index 2c661cb5bc..0e82475531 100644 --- a/library/cpp/packers/region_packer.h +++ b/library/cpp/packers/region_packer.h @@ -1,18 +1,18 @@ #pragma once - + #include "packers.h" #include <util/generic/array_ref.h> - -// Stores an array of PODs in the trie (copying them with memcpy). -// Byte order and alignment are your problem. - + +// Stores an array of PODs in the trie (copying them with memcpy). +// Byte order and alignment are your problem. + template <class TRecord> class TRegionPacker { public: typedef TArrayRef<TRecord> TRecords; - void UnpackLeaf(const char* p, TRecords& result) const { + void UnpackLeaf(const char* p, TRecords& result) const { size_t len; NPackers::TIntegralPacker<size_t>().UnpackLeaf(p, len); size_t start = NPackers::TIntegralPacker<size_t>().SkipLeaf(p); @@ -32,7 +32,7 @@ public: return NPackers::TIntegralPacker<size_t>().MeasureLeaf(len) + len * sizeof(TRecord); } - size_t SkipLeaf(const char* p) const { + size_t SkipLeaf(const char* p) const { size_t result = NPackers::TIntegralPacker<size_t>().SkipLeaf(p); size_t len; NPackers::TIntegralPacker<size_t>().UnpackLeaf(p, len); diff --git a/library/cpp/packers/ut/region_packer_ut.cpp b/library/cpp/packers/ut/region_packer_ut.cpp index 0cb08ccf65..0da6a8b773 100644 --- a/library/cpp/packers/ut/region_packer_ut.cpp +++ b/library/cpp/packers/ut/region_packer_ut.cpp @@ -1,40 +1,40 @@ -#include "region_packer.h" +#include "region_packer.h" #include <library/cpp/testing/unittest/registar.h> - -template <typename TValue> -void TestPacker() { - TValue values[] = {1, 2, 3, 42}; + +template <typename TValue> +void TestPacker() { + TValue values[] = {1, 2, 3, 42}; TString buffer; - - TRegionPacker<TValue> p; - + + TRegionPacker<TValue> p; + using TValues = TArrayRef<TValue>; TValues valueRegion = TValues(values, Y_ARRAY_SIZE(values)); - size_t sz = p.MeasureLeaf(valueRegion); - UNIT_ASSERT_VALUES_EQUAL(sz, 1 + sizeof(values)); - - buffer.resize(sz); - p.PackLeaf(buffer.begin(), valueRegion, sz); - UNIT_ASSERT_VALUES_EQUAL(buffer[0], 4); - + size_t sz = p.MeasureLeaf(valueRegion); + UNIT_ASSERT_VALUES_EQUAL(sz, 1 + sizeof(values)); + + buffer.resize(sz); + p.PackLeaf(buffer.begin(), valueRegion, sz); + UNIT_ASSERT_VALUES_EQUAL(buffer[0], 4); + p.UnpackLeaf(buffer.data(), valueRegion); UNIT_ASSERT_EQUAL(valueRegion.data(), (const TValue*)(buffer.begin() + 1)); UNIT_ASSERT_EQUAL(valueRegion.size(), Y_ARRAY_SIZE(values)); UNIT_ASSERT_EQUAL(0, memcmp(values, valueRegion.data(), sizeof(values))); -} - +} + Y_UNIT_TEST_SUITE(RegionPacker) { Y_UNIT_TEST(Test0) { - TestPacker<char>(); - TestPacker<signed char>(); - TestPacker<unsigned char>(); - TestPacker<i8>(); - TestPacker<ui8>(); - TestPacker<i16>(); - TestPacker<ui16>(); - TestPacker<i32>(); - TestPacker<ui32>(); - TestPacker<i64>(); - TestPacker<ui64>(); - } -} + TestPacker<char>(); + TestPacker<signed char>(); + TestPacker<unsigned char>(); + TestPacker<i8>(); + TestPacker<ui8>(); + TestPacker<i16>(); + TestPacker<ui16>(); + TestPacker<i32>(); + TestPacker<ui32>(); + TestPacker<i64>(); + TestPacker<ui64>(); + } +} |