aboutsummaryrefslogtreecommitdiffstats
path: root/yt/yt/library/column_converters/column_converter.h
blob: 12d9e2a04c1ece98a2fdc60de38a6dac450155a6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#pragma once

#include <yt/yt/client/table_client/row_batch.h>

#include <yt/yt/core/misc/bitmap.h>

#include <library/cpp/yt/memory/ref.h>

namespace NYT::NColumnConverters {

////////////////////////////////////////////////////////////////////////////////

using TBatchColumn = NTableClient::IUnversionedColumnarRowBatch::TColumn;
using TBatchColumnPtr = std::shared_ptr<TBatchColumn>;
using TUnversionedRowValues = std::vector<const NTableClient::TUnversionedValue*>;

////////////////////////////////////////////////////////////////////////////////

struct TOwningColumn
{
    TBatchColumnPtr Column;
    TSharedRef NullBitmap;
    TSharedRef ValueBuffer;
    TSharedRef StringBuffer;
};

struct TConvertedColumn
{
    std::vector<TOwningColumn> Columns;
    TBatchColumn* RootColumn;
};

using TConvertedColumnRange = std::vector<TConvertedColumn>;

////////////////////////////////////////////////////////////////////////////////

struct IColumnConverter
    : private TNonCopyable
{
    virtual ~IColumnConverter() = default;
    virtual TConvertedColumn Convert(TRange<TUnversionedRowValues> rowsValues) = 0;
};

using IColumnConverterPtr = std::unique_ptr<IColumnConverter>;

////////////////////////////////////////////////////////////////////////////////

class TColumnConverters
{
public:
    TConvertedColumnRange ConvertRowsToColumns(
        TRange<NTableClient::TUnversionedRow> rows,
        const THashMap<int, NTableClient::TColumnSchema>& columnSchema);
private:
    THashMap<int, int> IdsToIndexes_;
    std::vector<int> ColumnIds_;
    bool IsFirstBatch_ = true;
};

////////////////////////////////////////////////////////////////////////////////

} // namespace NYT::NColumnConverters