be/src/storage/segment/plain_page.h
Line | Count | Source |
1 | | // Licensed to the Apache Software Foundation (ASF) under one |
2 | | // or more contributor license agreements. See the NOTICE file |
3 | | // distributed with this work for additional information |
4 | | // regarding copyright ownership. The ASF licenses this file |
5 | | // to you under the Apache License, Version 2.0 (the |
6 | | // "License"); you may not use this file except in compliance |
7 | | // with the License. You may obtain a copy of the License at |
8 | | // |
9 | | // http://www.apache.org/licenses/LICENSE-2.0 |
10 | | // |
11 | | // Unless required by applicable law or agreed to in writing, |
12 | | // software distributed under the License is distributed on an |
13 | | // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
14 | | // KIND, either express or implied. See the License for the |
15 | | // specific language governing permissions and limitations |
16 | | // under the License. |
17 | | |
18 | | #pragma once |
19 | | |
20 | | #include "common/cast_set.h" |
21 | | #include "storage/olap_common.h" |
22 | | #include "storage/segment/options.h" |
23 | | #include "storage/segment/page_builder.h" |
24 | | #include "storage/segment/page_decoder.h" |
25 | | #include "storage/types.h" |
26 | | #include "util/coding.h" |
27 | | #include "util/faststring.h" |
28 | | #include "util/unaligned.h" |
29 | | |
30 | | namespace doris { |
31 | | #include "common/compile_check_begin.h" |
32 | | namespace segment_v2 { |
33 | | |
34 | | static const size_t PLAIN_PAGE_HEADER_SIZE = sizeof(uint32_t); |
35 | | |
36 | | template <FieldType Type> |
37 | | class PlainPageBuilder : public PageBuilderHelper<PlainPageBuilder<Type>> { |
38 | | public: |
39 | | using Self = PlainPageBuilder<Type>; |
40 | | friend class PageBuilderHelper<Self>; |
41 | | |
42 | 131k | Status init() override { |
43 | | // Reserve enough space for the page, plus a bit of slop since |
44 | | // we often overrun the page by a few values. |
45 | 131k | return reset(); |
46 | 131k | } _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE4initEv Line | Count | Source | 42 | 39.6k | Status init() override { | 43 | | // Reserve enough space for the page, plus a bit of slop since | 44 | | // we often overrun the page by a few values. | 45 | 39.6k | return reset(); | 46 | 39.6k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE4initEv Line | Count | Source | 42 | 8.98k | Status init() override { | 43 | | // Reserve enough space for the page, plus a bit of slop since | 44 | | // we often overrun the page by a few values. | 45 | 8.98k | return reset(); | 46 | 8.98k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE4initEv Line | Count | Source | 42 | 43.2k | Status init() override { | 43 | | // Reserve enough space for the page, plus a bit of slop since | 44 | | // we often overrun the page by a few values. | 45 | 43.2k | return reset(); | 46 | 43.2k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE4initEv Line | Count | Source | 42 | 27.0k | Status init() override { | 43 | | // Reserve enough space for the page, plus a bit of slop since | 44 | | // we often overrun the page by a few values. | 45 | 27.0k | return reset(); | 46 | 27.0k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE4initEv Line | Count | Source | 42 | 12.0k | Status init() override { | 43 | | // Reserve enough space for the page, plus a bit of slop since | 44 | | // we often overrun the page by a few values. | 45 | 12.0k | return reset(); | 46 | 12.0k | } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE4initEv |
47 | | |
48 | 376k | bool is_page_full() override { return _remain_element_capacity == 0; }_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE12is_page_fullEv Line | Count | Source | 48 | 79.8k | bool is_page_full() override { return _remain_element_capacity == 0; } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE12is_page_fullEv Line | Count | Source | 48 | 28.9k | bool is_page_full() override { return _remain_element_capacity == 0; } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE12is_page_fullEv Line | Count | Source | 48 | 146k | bool is_page_full() override { return _remain_element_capacity == 0; } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE12is_page_fullEv Line | Count | Source | 48 | 86.6k | bool is_page_full() override { return _remain_element_capacity == 0; } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE12is_page_fullEv Line | Count | Source | 48 | 34.6k | bool is_page_full() override { return _remain_element_capacity == 0; } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE12is_page_fullEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE12is_page_fullEv |
49 | | |
50 | 188k | Status add(const uint8_t* vals, size_t* count) override { |
51 | 188k | if (is_page_full() || *count == 0) { |
52 | 0 | *count = 0; |
53 | 0 | return Status::OK(); |
54 | 0 | } |
55 | 188k | size_t old_size = _buffer.size(); |
56 | 188k | size_t to_add = std::min(_remain_element_capacity, *count); |
57 | | // This may need a large memory, should return error if could not allocated |
58 | | // successfully, to avoid BE OOM. |
59 | 188k | RETURN_IF_CATCH_EXCEPTION(_buffer.resize(old_size + to_add * SIZE_OF_TYPE)); |
60 | 188k | memcpy(&_buffer[old_size], vals, to_add * SIZE_OF_TYPE); |
61 | 188k | _count += to_add; |
62 | 188k | _raw_data_size += to_add * SIZE_OF_TYPE; |
63 | | |
64 | 188k | *count = to_add; |
65 | 188k | _remain_element_capacity -= to_add; |
66 | 188k | return Status::OK(); |
67 | 188k | } _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE3addEPKhPm Line | Count | Source | 50 | 39.9k | Status add(const uint8_t* vals, size_t* count) override { | 51 | 39.9k | if (is_page_full() || *count == 0) { | 52 | 0 | *count = 0; | 53 | 0 | return Status::OK(); | 54 | 0 | } | 55 | 39.9k | size_t old_size = _buffer.size(); | 56 | 39.9k | size_t to_add = std::min(_remain_element_capacity, *count); | 57 | | // This may need a large memory, should return error if could not allocated | 58 | | // successfully, to avoid BE OOM. | 59 | 39.9k | RETURN_IF_CATCH_EXCEPTION(_buffer.resize(old_size + to_add * SIZE_OF_TYPE)); | 60 | 39.9k | memcpy(&_buffer[old_size], vals, to_add * SIZE_OF_TYPE); | 61 | 39.9k | _count += to_add; | 62 | 39.9k | _raw_data_size += to_add * SIZE_OF_TYPE; | 63 | | | 64 | 39.9k | *count = to_add; | 65 | 39.9k | _remain_element_capacity -= to_add; | 66 | 39.9k | return Status::OK(); | 67 | 39.9k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE3addEPKhPm Line | Count | Source | 50 | 14.4k | Status add(const uint8_t* vals, size_t* count) override { | 51 | 14.4k | if (is_page_full() || *count == 0) { | 52 | 0 | *count = 0; | 53 | 0 | return Status::OK(); | 54 | 0 | } | 55 | 14.4k | size_t old_size = _buffer.size(); | 56 | 14.4k | size_t to_add = std::min(_remain_element_capacity, *count); | 57 | | // This may need a large memory, should return error if could not allocated | 58 | | // successfully, to avoid BE OOM. | 59 | 14.4k | RETURN_IF_CATCH_EXCEPTION(_buffer.resize(old_size + to_add * SIZE_OF_TYPE)); | 60 | 14.4k | memcpy(&_buffer[old_size], vals, to_add * SIZE_OF_TYPE); | 61 | 14.4k | _count += to_add; | 62 | 14.4k | _raw_data_size += to_add * SIZE_OF_TYPE; | 63 | | | 64 | 14.4k | *count = to_add; | 65 | 14.4k | _remain_element_capacity -= to_add; | 66 | 14.4k | return Status::OK(); | 67 | 14.4k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE3addEPKhPm Line | Count | Source | 50 | 73.0k | Status add(const uint8_t* vals, size_t* count) override { | 51 | 73.0k | if (is_page_full() || *count == 0) { | 52 | 0 | *count = 0; | 53 | 0 | return Status::OK(); | 54 | 0 | } | 55 | 73.0k | size_t old_size = _buffer.size(); | 56 | 73.0k | size_t to_add = std::min(_remain_element_capacity, *count); | 57 | | // This may need a large memory, should return error if could not allocated | 58 | | // successfully, to avoid BE OOM. | 59 | 73.0k | RETURN_IF_CATCH_EXCEPTION(_buffer.resize(old_size + to_add * SIZE_OF_TYPE)); | 60 | 73.0k | memcpy(&_buffer[old_size], vals, to_add * SIZE_OF_TYPE); | 61 | 73.0k | _count += to_add; | 62 | 73.0k | _raw_data_size += to_add * SIZE_OF_TYPE; | 63 | | | 64 | 73.0k | *count = to_add; | 65 | 73.0k | _remain_element_capacity -= to_add; | 66 | 73.0k | return Status::OK(); | 67 | 73.0k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE3addEPKhPm Line | Count | Source | 50 | 43.3k | Status add(const uint8_t* vals, size_t* count) override { | 51 | 43.3k | if (is_page_full() || *count == 0) { | 52 | 0 | *count = 0; | 53 | 0 | return Status::OK(); | 54 | 0 | } | 55 | 43.3k | size_t old_size = _buffer.size(); | 56 | 43.3k | size_t to_add = std::min(_remain_element_capacity, *count); | 57 | | // This may need a large memory, should return error if could not allocated | 58 | | // successfully, to avoid BE OOM. | 59 | 43.3k | RETURN_IF_CATCH_EXCEPTION(_buffer.resize(old_size + to_add * SIZE_OF_TYPE)); | 60 | 43.3k | memcpy(&_buffer[old_size], vals, to_add * SIZE_OF_TYPE); | 61 | 43.3k | _count += to_add; | 62 | 43.3k | _raw_data_size += to_add * SIZE_OF_TYPE; | 63 | | | 64 | 43.3k | *count = to_add; | 65 | 43.3k | _remain_element_capacity -= to_add; | 66 | 43.3k | return Status::OK(); | 67 | 43.3k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE3addEPKhPm Line | Count | Source | 50 | 17.3k | Status add(const uint8_t* vals, size_t* count) override { | 51 | 17.3k | if (is_page_full() || *count == 0) { | 52 | 0 | *count = 0; | 53 | 0 | return Status::OK(); | 54 | 0 | } | 55 | 17.3k | size_t old_size = _buffer.size(); | 56 | 17.3k | size_t to_add = std::min(_remain_element_capacity, *count); | 57 | | // This may need a large memory, should return error if could not allocated | 58 | | // successfully, to avoid BE OOM. | 59 | 17.3k | RETURN_IF_CATCH_EXCEPTION(_buffer.resize(old_size + to_add * SIZE_OF_TYPE)); | 60 | 17.3k | memcpy(&_buffer[old_size], vals, to_add * SIZE_OF_TYPE); | 61 | 17.3k | _count += to_add; | 62 | 17.3k | _raw_data_size += to_add * SIZE_OF_TYPE; | 63 | | | 64 | 17.3k | *count = to_add; | 65 | 17.3k | _remain_element_capacity -= to_add; | 66 | 17.3k | return Status::OK(); | 67 | 17.3k | } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE3addEPKhPm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE3addEPKhPm |
68 | | |
69 | 133k | Status finish(OwnedSlice* slice) override { |
70 | 133k | encode_fixed32_le((uint8_t*)&_buffer[0], cast_set<uint32_t>(_count)); |
71 | 133k | RETURN_IF_CATCH_EXCEPTION({ |
72 | 133k | if (_count > 0) { |
73 | 133k | _first_value.assign_copy(&_buffer[PLAIN_PAGE_HEADER_SIZE], SIZE_OF_TYPE); |
74 | 133k | _last_value.assign_copy( |
75 | 133k | &_buffer[PLAIN_PAGE_HEADER_SIZE + (_count - 1) * SIZE_OF_TYPE], |
76 | 133k | SIZE_OF_TYPE); |
77 | 133k | } |
78 | 133k | *slice = _buffer.build(); |
79 | 133k | }); |
80 | 133k | return Status::OK(); |
81 | 133k | } _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE6finishEPNS_10OwnedSliceE Line | Count | Source | 69 | 39.0k | Status finish(OwnedSlice* slice) override { | 70 | 39.0k | encode_fixed32_le((uint8_t*)&_buffer[0], cast_set<uint32_t>(_count)); | 71 | 39.0k | RETURN_IF_CATCH_EXCEPTION({ | 72 | 39.0k | if (_count > 0) { | 73 | 39.0k | _first_value.assign_copy(&_buffer[PLAIN_PAGE_HEADER_SIZE], SIZE_OF_TYPE); | 74 | 39.0k | _last_value.assign_copy( | 75 | 39.0k | &_buffer[PLAIN_PAGE_HEADER_SIZE + (_count - 1) * SIZE_OF_TYPE], | 76 | 39.0k | SIZE_OF_TYPE); | 77 | 39.0k | } | 78 | 39.0k | *slice = _buffer.build(); | 79 | 39.0k | }); | 80 | 39.0k | return Status::OK(); | 81 | 39.0k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE6finishEPNS_10OwnedSliceE Line | Count | Source | 69 | 8.54k | Status finish(OwnedSlice* slice) override { | 70 | 8.54k | encode_fixed32_le((uint8_t*)&_buffer[0], cast_set<uint32_t>(_count)); | 71 | 8.54k | RETURN_IF_CATCH_EXCEPTION({ | 72 | 8.54k | if (_count > 0) { | 73 | 8.54k | _first_value.assign_copy(&_buffer[PLAIN_PAGE_HEADER_SIZE], SIZE_OF_TYPE); | 74 | 8.54k | _last_value.assign_copy( | 75 | 8.54k | &_buffer[PLAIN_PAGE_HEADER_SIZE + (_count - 1) * SIZE_OF_TYPE], | 76 | 8.54k | SIZE_OF_TYPE); | 77 | 8.54k | } | 78 | 8.54k | *slice = _buffer.build(); | 79 | 8.54k | }); | 80 | 8.54k | return Status::OK(); | 81 | 8.54k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE6finishEPNS_10OwnedSliceE Line | Count | Source | 69 | 43.8k | Status finish(OwnedSlice* slice) override { | 70 | 43.8k | encode_fixed32_le((uint8_t*)&_buffer[0], cast_set<uint32_t>(_count)); | 71 | 43.8k | RETURN_IF_CATCH_EXCEPTION({ | 72 | 43.8k | if (_count > 0) { | 73 | 43.8k | _first_value.assign_copy(&_buffer[PLAIN_PAGE_HEADER_SIZE], SIZE_OF_TYPE); | 74 | 43.8k | _last_value.assign_copy( | 75 | 43.8k | &_buffer[PLAIN_PAGE_HEADER_SIZE + (_count - 1) * SIZE_OF_TYPE], | 76 | 43.8k | SIZE_OF_TYPE); | 77 | 43.8k | } | 78 | 43.8k | *slice = _buffer.build(); | 79 | 43.8k | }); | 80 | 43.8k | return Status::OK(); | 81 | 43.8k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE6finishEPNS_10OwnedSliceE Line | Count | Source | 69 | 30.2k | Status finish(OwnedSlice* slice) override { | 70 | 30.2k | encode_fixed32_le((uint8_t*)&_buffer[0], cast_set<uint32_t>(_count)); | 71 | 30.2k | RETURN_IF_CATCH_EXCEPTION({ | 72 | 30.2k | if (_count > 0) { | 73 | 30.2k | _first_value.assign_copy(&_buffer[PLAIN_PAGE_HEADER_SIZE], SIZE_OF_TYPE); | 74 | 30.2k | _last_value.assign_copy( | 75 | 30.2k | &_buffer[PLAIN_PAGE_HEADER_SIZE + (_count - 1) * SIZE_OF_TYPE], | 76 | 30.2k | SIZE_OF_TYPE); | 77 | 30.2k | } | 78 | 30.2k | *slice = _buffer.build(); | 79 | 30.2k | }); | 80 | 30.2k | return Status::OK(); | 81 | 30.2k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE6finishEPNS_10OwnedSliceE Line | Count | Source | 69 | 12.0k | Status finish(OwnedSlice* slice) override { | 70 | 12.0k | encode_fixed32_le((uint8_t*)&_buffer[0], cast_set<uint32_t>(_count)); | 71 | 12.0k | RETURN_IF_CATCH_EXCEPTION({ | 72 | 12.0k | if (_count > 0) { | 73 | 12.0k | _first_value.assign_copy(&_buffer[PLAIN_PAGE_HEADER_SIZE], SIZE_OF_TYPE); | 74 | 12.0k | _last_value.assign_copy( | 75 | 12.0k | &_buffer[PLAIN_PAGE_HEADER_SIZE + (_count - 1) * SIZE_OF_TYPE], | 76 | 12.0k | SIZE_OF_TYPE); | 77 | 12.0k | } | 78 | 12.0k | *slice = _buffer.build(); | 79 | 12.0k | }); | 80 | 12.0k | return Status::OK(); | 81 | 12.0k | } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE6finishEPNS_10OwnedSliceE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE6finishEPNS_10OwnedSliceE |
82 | | |
83 | 264k | Status reset() override { |
84 | 264k | RETURN_IF_CATCH_EXCEPTION({ |
85 | 264k | _buffer.reserve(_options.data_page_size); |
86 | 264k | _count = 0; |
87 | 264k | _raw_data_size = 0; |
88 | 264k | _buffer.clear(); |
89 | 264k | _buffer.resize(PLAIN_PAGE_HEADER_SIZE); |
90 | 264k | _remain_element_capacity = _options.data_page_size / SIZE_OF_TYPE; |
91 | 264k | }); |
92 | 265k | return Status::OK(); |
93 | 264k | } _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE5resetEv Line | Count | Source | 83 | 78.7k | Status reset() override { | 84 | 78.7k | RETURN_IF_CATCH_EXCEPTION({ | 85 | 78.7k | _buffer.reserve(_options.data_page_size); | 86 | 78.7k | _count = 0; | 87 | 78.7k | _raw_data_size = 0; | 88 | 78.7k | _buffer.clear(); | 89 | 78.7k | _buffer.resize(PLAIN_PAGE_HEADER_SIZE); | 90 | 78.7k | _remain_element_capacity = _options.data_page_size / SIZE_OF_TYPE; | 91 | 78.7k | }); | 92 | 78.7k | return Status::OK(); | 93 | 78.7k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE5resetEv Line | Count | Source | 83 | 17.5k | Status reset() override { | 84 | 17.5k | RETURN_IF_CATCH_EXCEPTION({ | 85 | 17.5k | _buffer.reserve(_options.data_page_size); | 86 | 17.5k | _count = 0; | 87 | 17.5k | _raw_data_size = 0; | 88 | 17.5k | _buffer.clear(); | 89 | 17.5k | _buffer.resize(PLAIN_PAGE_HEADER_SIZE); | 90 | 17.5k | _remain_element_capacity = _options.data_page_size / SIZE_OF_TYPE; | 91 | 17.5k | }); | 92 | 17.5k | return Status::OK(); | 93 | 17.5k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE5resetEv Line | Count | Source | 83 | 87.0k | Status reset() override { | 84 | 87.0k | RETURN_IF_CATCH_EXCEPTION({ | 85 | 87.0k | _buffer.reserve(_options.data_page_size); | 86 | 87.0k | _count = 0; | 87 | 87.0k | _raw_data_size = 0; | 88 | 87.0k | _buffer.clear(); | 89 | 87.0k | _buffer.resize(PLAIN_PAGE_HEADER_SIZE); | 90 | 87.0k | _remain_element_capacity = _options.data_page_size / SIZE_OF_TYPE; | 91 | 87.0k | }); | 92 | 87.2k | return Status::OK(); | 93 | 87.0k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE5resetEv Line | Count | Source | 83 | 57.2k | Status reset() override { | 84 | 57.2k | RETURN_IF_CATCH_EXCEPTION({ | 85 | 57.2k | _buffer.reserve(_options.data_page_size); | 86 | 57.2k | _count = 0; | 87 | 57.2k | _raw_data_size = 0; | 88 | 57.2k | _buffer.clear(); | 89 | 57.2k | _buffer.resize(PLAIN_PAGE_HEADER_SIZE); | 90 | 57.2k | _remain_element_capacity = _options.data_page_size / SIZE_OF_TYPE; | 91 | 57.2k | }); | 92 | 57.3k | return Status::OK(); | 93 | 57.2k | } |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE5resetEv Line | Count | Source | 83 | 24.1k | Status reset() override { | 84 | 24.1k | RETURN_IF_CATCH_EXCEPTION({ | 85 | 24.1k | _buffer.reserve(_options.data_page_size); | 86 | 24.1k | _count = 0; | 87 | 24.1k | _raw_data_size = 0; | 88 | 24.1k | _buffer.clear(); | 89 | 24.1k | _buffer.resize(PLAIN_PAGE_HEADER_SIZE); | 90 | 24.1k | _remain_element_capacity = _options.data_page_size / SIZE_OF_TYPE; | 91 | 24.1k | }); | 92 | 24.2k | return Status::OK(); | 93 | 24.1k | } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE5resetEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE5resetEv |
94 | | |
95 | 0 | size_t count() const override { return _count; }Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE5countEv |
96 | | |
97 | 9.55k | uint64_t size() const override { return _buffer.size(); }_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE4sizeEv Line | Count | Source | 97 | 1.48k | uint64_t size() const override { return _buffer.size(); } |
_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE4sizeEv Line | Count | Source | 97 | 847 | uint64_t size() const override { return _buffer.size(); } |
_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE4sizeEv Line | Count | Source | 97 | 3.58k | uint64_t size() const override { return _buffer.size(); } |
_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE4sizeEv Line | Count | Source | 97 | 2.29k | uint64_t size() const override { return _buffer.size(); } |
_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE4sizeEv Line | Count | Source | 97 | 1.33k | uint64_t size() const override { return _buffer.size(); } |
Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE4sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE4sizeEv |
98 | | |
99 | 133k | uint64_t get_raw_data_size() const override { return _raw_data_size; }_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE17get_raw_data_sizeEv Line | Count | Source | 99 | 39.0k | uint64_t get_raw_data_size() const override { return _raw_data_size; } |
_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE17get_raw_data_sizeEv Line | Count | Source | 99 | 8.54k | uint64_t get_raw_data_size() const override { return _raw_data_size; } |
_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE17get_raw_data_sizeEv Line | Count | Source | 99 | 43.8k | uint64_t get_raw_data_size() const override { return _raw_data_size; } |
_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE17get_raw_data_sizeEv Line | Count | Source | 99 | 30.2k | uint64_t get_raw_data_size() const override { return _raw_data_size; } |
_ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE17get_raw_data_sizeEv Line | Count | Source | 99 | 12.0k | uint64_t get_raw_data_size() const override { return _raw_data_size; } |
Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE17get_raw_data_sizeEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE17get_raw_data_sizeEv |
100 | | |
101 | 0 | Status get_first_value(void* value) const override { |
102 | 0 | if (_count == 0) { |
103 | 0 | return Status::Error<ErrorCode::ENTRY_NOT_FOUND>("page is empty"); |
104 | 0 | } |
105 | 0 | memcpy(value, _first_value.data(), SIZE_OF_TYPE); |
106 | 0 | return Status::OK(); |
107 | 0 | } Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE15get_first_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE15get_first_valueEPv |
108 | | |
109 | 0 | Status get_last_value(void* value) const override { |
110 | 0 | if (_count == 0) { |
111 | 0 | return Status::Error<ErrorCode::ENTRY_NOT_FOUND>("page is empty"); |
112 | 0 | } |
113 | 0 | memcpy(value, _last_value.data(), SIZE_OF_TYPE); |
114 | 0 | return Status::OK(); |
115 | 0 | } Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EE14get_last_valueEPv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EE14get_last_valueEPv |
116 | | |
117 | | private: |
118 | 131k | PlainPageBuilder(const PageBuilderOptions& options) : _options(options) {}_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE1EEC2ERKNS0_18PageBuilderOptionsE Line | Count | Source | 118 | 39.6k | PlainPageBuilder(const PageBuilderOptions& options) : _options(options) {} |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE3EEC2ERKNS0_18PageBuilderOptionsE Line | Count | Source | 118 | 8.99k | PlainPageBuilder(const PageBuilderOptions& options) : _options(options) {} |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE5EEC2ERKNS0_18PageBuilderOptionsE Line | Count | Source | 118 | 43.2k | PlainPageBuilder(const PageBuilderOptions& options) : _options(options) {} |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE7EEC2ERKNS0_18PageBuilderOptionsE Line | Count | Source | 118 | 27.0k | PlainPageBuilder(const PageBuilderOptions& options) : _options(options) {} |
_ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE9EEC2ERKNS0_18PageBuilderOptionsE Line | Count | Source | 118 | 12.0k | PlainPageBuilder(const PageBuilderOptions& options) : _options(options) {} |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE10EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE11EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE24EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE14EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE28EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE29EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE15EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE40EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE16EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE31EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE32EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE33EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE37EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE38EEC2ERKNS0_18PageBuilderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageBuilderILNS_9FieldTypeE39EEC2ERKNS0_18PageBuilderOptionsE |
119 | | |
120 | | faststring _buffer; |
121 | | PageBuilderOptions _options; |
122 | | size_t _count; |
123 | | size_t _remain_element_capacity {0}; |
124 | | uint64_t _raw_data_size = 0; |
125 | | typedef typename TypeTraits<Type>::CppType CppType; |
126 | | enum { SIZE_OF_TYPE = TypeTraits<Type>::size }; |
127 | | faststring _first_value; |
128 | | faststring _last_value; |
129 | | }; |
130 | | |
131 | | template <FieldType Type> |
132 | | class PlainPageDecoder : public PageDecoder { |
133 | | public: |
134 | | PlainPageDecoder(Slice data, const PageDecoderOptions& options) |
135 | 437k | : _data(data), _options(options), _parsed(false), _num_elems(0), _cur_idx(0) {}_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE1EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Line | Count | Source | 135 | 79.0k | : _data(data), _options(options), _parsed(false), _num_elems(0), _cur_idx(0) {} |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE3EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Line | Count | Source | 135 | 12.5k | : _data(data), _options(options), _parsed(false), _num_elems(0), _cur_idx(0) {} |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE5EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Line | Count | Source | 135 | 139k | : _data(data), _options(options), _parsed(false), _num_elems(0), _cur_idx(0) {} |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE7EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Line | Count | Source | 135 | 187k | : _data(data), _options(options), _parsed(false), _num_elems(0), _cur_idx(0) {} |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE9EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Line | Count | Source | 135 | 19.1k | : _data(data), _options(options), _parsed(false), _num_elems(0), _cur_idx(0) {} |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE10EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE11EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE24EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE14EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE28EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE29EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE15EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE40EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE16EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE31EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE32EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE33EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE37EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE38EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE39EEC2ENS_5SliceERKNS0_18PageDecoderOptionsE |
136 | | |
137 | 437k | Status init() override { |
138 | 437k | CHECK(!_parsed); |
139 | | |
140 | 437k | if (_data.size < PLAIN_PAGE_HEADER_SIZE) { |
141 | 0 | return Status::InternalError( |
142 | 0 | "file corruption: not enough bytes for header in PlainPageDecoder ." |
143 | 0 | "invalid data size:{}, header size:{}", |
144 | 0 | _data.size, PLAIN_PAGE_HEADER_SIZE); |
145 | 0 | } |
146 | | |
147 | 437k | _num_elems = decode_fixed32_le((const uint8_t*)&_data[0]); |
148 | | |
149 | 437k | if (_data.size != PLAIN_PAGE_HEADER_SIZE + _num_elems * SIZE_OF_TYPE) { |
150 | 0 | return Status::InternalError("file corruption: unexpected data size."); |
151 | 0 | } |
152 | | |
153 | 437k | _parsed = true; |
154 | | |
155 | 437k | RETURN_IF_ERROR(seek_to_position_in_page(0)); |
156 | 437k | return Status::OK(); |
157 | 437k | } _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE1EE4initEv Line | Count | Source | 137 | 79.0k | Status init() override { | 138 | 79.0k | CHECK(!_parsed); | 139 | | | 140 | 79.0k | if (_data.size < PLAIN_PAGE_HEADER_SIZE) { | 141 | 0 | return Status::InternalError( | 142 | 0 | "file corruption: not enough bytes for header in PlainPageDecoder ." | 143 | 0 | "invalid data size:{}, header size:{}", | 144 | 0 | _data.size, PLAIN_PAGE_HEADER_SIZE); | 145 | 0 | } | 146 | | | 147 | 79.0k | _num_elems = decode_fixed32_le((const uint8_t*)&_data[0]); | 148 | | | 149 | 79.0k | if (_data.size != PLAIN_PAGE_HEADER_SIZE + _num_elems * SIZE_OF_TYPE) { | 150 | 0 | return Status::InternalError("file corruption: unexpected data size."); | 151 | 0 | } | 152 | | | 153 | 79.0k | _parsed = true; | 154 | | | 155 | 79.0k | RETURN_IF_ERROR(seek_to_position_in_page(0)); | 156 | 79.0k | return Status::OK(); | 157 | 79.0k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE3EE4initEv Line | Count | Source | 137 | 12.5k | Status init() override { | 138 | 12.5k | CHECK(!_parsed); | 139 | | | 140 | 12.5k | if (_data.size < PLAIN_PAGE_HEADER_SIZE) { | 141 | 0 | return Status::InternalError( | 142 | 0 | "file corruption: not enough bytes for header in PlainPageDecoder ." | 143 | 0 | "invalid data size:{}, header size:{}", | 144 | 0 | _data.size, PLAIN_PAGE_HEADER_SIZE); | 145 | 0 | } | 146 | | | 147 | 12.5k | _num_elems = decode_fixed32_le((const uint8_t*)&_data[0]); | 148 | | | 149 | 12.5k | if (_data.size != PLAIN_PAGE_HEADER_SIZE + _num_elems * SIZE_OF_TYPE) { | 150 | 0 | return Status::InternalError("file corruption: unexpected data size."); | 151 | 0 | } | 152 | | | 153 | 12.5k | _parsed = true; | 154 | | | 155 | 12.5k | RETURN_IF_ERROR(seek_to_position_in_page(0)); | 156 | 12.5k | return Status::OK(); | 157 | 12.5k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE5EE4initEv Line | Count | Source | 137 | 139k | Status init() override { | 138 | 139k | CHECK(!_parsed); | 139 | | | 140 | 139k | if (_data.size < PLAIN_PAGE_HEADER_SIZE) { | 141 | 0 | return Status::InternalError( | 142 | 0 | "file corruption: not enough bytes for header in PlainPageDecoder ." | 143 | 0 | "invalid data size:{}, header size:{}", | 144 | 0 | _data.size, PLAIN_PAGE_HEADER_SIZE); | 145 | 0 | } | 146 | | | 147 | 139k | _num_elems = decode_fixed32_le((const uint8_t*)&_data[0]); | 148 | | | 149 | 139k | if (_data.size != PLAIN_PAGE_HEADER_SIZE + _num_elems * SIZE_OF_TYPE) { | 150 | 0 | return Status::InternalError("file corruption: unexpected data size."); | 151 | 0 | } | 152 | | | 153 | 139k | _parsed = true; | 154 | | | 155 | 139k | RETURN_IF_ERROR(seek_to_position_in_page(0)); | 156 | 139k | return Status::OK(); | 157 | 139k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE7EE4initEv Line | Count | Source | 137 | 187k | Status init() override { | 138 | 187k | CHECK(!_parsed); | 139 | | | 140 | 187k | if (_data.size < PLAIN_PAGE_HEADER_SIZE) { | 141 | 0 | return Status::InternalError( | 142 | 0 | "file corruption: not enough bytes for header in PlainPageDecoder ." | 143 | 0 | "invalid data size:{}, header size:{}", | 144 | 0 | _data.size, PLAIN_PAGE_HEADER_SIZE); | 145 | 0 | } | 146 | | | 147 | 187k | _num_elems = decode_fixed32_le((const uint8_t*)&_data[0]); | 148 | | | 149 | 187k | if (_data.size != PLAIN_PAGE_HEADER_SIZE + _num_elems * SIZE_OF_TYPE) { | 150 | 0 | return Status::InternalError("file corruption: unexpected data size."); | 151 | 0 | } | 152 | | | 153 | 187k | _parsed = true; | 154 | | | 155 | 187k | RETURN_IF_ERROR(seek_to_position_in_page(0)); | 156 | 187k | return Status::OK(); | 157 | 187k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE9EE4initEv Line | Count | Source | 137 | 19.1k | Status init() override { | 138 | 19.1k | CHECK(!_parsed); | 139 | | | 140 | 19.1k | if (_data.size < PLAIN_PAGE_HEADER_SIZE) { | 141 | 0 | return Status::InternalError( | 142 | 0 | "file corruption: not enough bytes for header in PlainPageDecoder ." | 143 | 0 | "invalid data size:{}, header size:{}", | 144 | 0 | _data.size, PLAIN_PAGE_HEADER_SIZE); | 145 | 0 | } | 146 | | | 147 | 19.1k | _num_elems = decode_fixed32_le((const uint8_t*)&_data[0]); | 148 | | | 149 | 19.1k | if (_data.size != PLAIN_PAGE_HEADER_SIZE + _num_elems * SIZE_OF_TYPE) { | 150 | 0 | return Status::InternalError("file corruption: unexpected data size."); | 151 | 0 | } | 152 | | | 153 | 19.1k | _parsed = true; | 154 | | | 155 | 19.1k | RETURN_IF_ERROR(seek_to_position_in_page(0)); | 156 | 19.1k | return Status::OK(); | 157 | 19.1k | } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE10EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE11EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE24EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE14EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE28EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE29EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE15EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE40EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE16EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE31EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE32EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE33EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE37EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE38EE4initEv Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE39EE4initEv |
158 | | |
159 | 1.13M | Status seek_to_position_in_page(size_t pos) override { |
160 | 1.13M | CHECK(_parsed) << "Must call init()"; |
161 | 1.13M | if (_num_elems == 0) [[unlikely]] { |
162 | 5.28k | if (pos != 0) { |
163 | 0 | return Status::Error<ErrorCode::INTERNAL_ERROR, false>( |
164 | 0 | "seek pos {} is larger than total elements {}", pos, _num_elems); |
165 | 0 | } |
166 | 5.28k | } |
167 | | |
168 | 1.13M | DCHECK_LE(pos, _num_elems); |
169 | | |
170 | 1.13M | _cur_idx = cast_set<uint32_t>(pos); |
171 | 1.13M | return Status::OK(); |
172 | 1.13M | } _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE1EE24seek_to_position_in_pageEm Line | Count | Source | 159 | 125k | Status seek_to_position_in_page(size_t pos) override { | 160 | 18.4E | CHECK(_parsed) << "Must call init()"; | 161 | 125k | if (_num_elems == 0) [[unlikely]] { | 162 | 476 | if (pos != 0) { | 163 | 0 | return Status::Error<ErrorCode::INTERNAL_ERROR, false>( | 164 | 0 | "seek pos {} is larger than total elements {}", pos, _num_elems); | 165 | 0 | } | 166 | 476 | } | 167 | | | 168 | 125k | DCHECK_LE(pos, _num_elems); | 169 | | | 170 | 125k | _cur_idx = cast_set<uint32_t>(pos); | 171 | 125k | return Status::OK(); | 172 | 125k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE3EE24seek_to_position_in_pageEm Line | Count | Source | 159 | 31.1k | Status seek_to_position_in_page(size_t pos) override { | 160 | 18.4E | CHECK(_parsed) << "Must call init()"; | 161 | 31.1k | if (_num_elems == 0) [[unlikely]] { | 162 | 104 | if (pos != 0) { | 163 | 0 | return Status::Error<ErrorCode::INTERNAL_ERROR, false>( | 164 | 0 | "seek pos {} is larger than total elements {}", pos, _num_elems); | 165 | 0 | } | 166 | 104 | } | 167 | | | 168 | 31.1k | DCHECK_LE(pos, _num_elems); | 169 | | | 170 | 31.1k | _cur_idx = cast_set<uint32_t>(pos); | 171 | 31.1k | return Status::OK(); | 172 | 31.1k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE5EE24seek_to_position_in_pageEm Line | Count | Source | 159 | 542k | Status seek_to_position_in_page(size_t pos) override { | 160 | 542k | CHECK(_parsed) << "Must call init()"; | 161 | 542k | if (_num_elems == 0) [[unlikely]] { | 162 | 2.16k | if (pos != 0) { | 163 | 0 | return Status::Error<ErrorCode::INTERNAL_ERROR, false>( | 164 | 0 | "seek pos {} is larger than total elements {}", pos, _num_elems); | 165 | 0 | } | 166 | 2.16k | } | 167 | | | 168 | 542k | DCHECK_LE(pos, _num_elems); | 169 | | | 170 | 542k | _cur_idx = cast_set<uint32_t>(pos); | 171 | 542k | return Status::OK(); | 172 | 542k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE7EE24seek_to_position_in_pageEm Line | Count | Source | 159 | 405k | Status seek_to_position_in_page(size_t pos) override { | 160 | 18.4E | CHECK(_parsed) << "Must call init()"; | 161 | 405k | if (_num_elems == 0) [[unlikely]] { | 162 | 2.15k | if (pos != 0) { | 163 | 0 | return Status::Error<ErrorCode::INTERNAL_ERROR, false>( | 164 | 0 | "seek pos {} is larger than total elements {}", pos, _num_elems); | 165 | 0 | } | 166 | 2.15k | } | 167 | | | 168 | 405k | DCHECK_LE(pos, _num_elems); | 169 | | | 170 | 405k | _cur_idx = cast_set<uint32_t>(pos); | 171 | 405k | return Status::OK(); | 172 | 405k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE9EE24seek_to_position_in_pageEm Line | Count | Source | 159 | 28.5k | Status seek_to_position_in_page(size_t pos) override { | 160 | 18.4E | CHECK(_parsed) << "Must call init()"; | 161 | 28.5k | if (_num_elems == 0) [[unlikely]] { | 162 | 384 | if (pos != 0) { | 163 | 0 | return Status::Error<ErrorCode::INTERNAL_ERROR, false>( | 164 | 0 | "seek pos {} is larger than total elements {}", pos, _num_elems); | 165 | 0 | } | 166 | 384 | } | 167 | | | 168 | 28.5k | DCHECK_LE(pos, _num_elems); | 169 | | | 170 | 28.5k | _cur_idx = cast_set<uint32_t>(pos); | 171 | 28.5k | return Status::OK(); | 172 | 28.5k | } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE10EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE11EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE24EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE14EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE28EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE29EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE15EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE40EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE16EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE31EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE32EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE33EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE37EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE38EE24seek_to_position_in_pageEm Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE39EE24seek_to_position_in_pageEm |
173 | | |
174 | 0 | Status seek_at_or_after_value(const void* value, bool* exact_match) override { |
175 | 0 | DCHECK(_parsed) << "Must call init() firstly"; |
176 | |
|
177 | 0 | if (_num_elems == 0) { |
178 | 0 | return Status::Error<ErrorCode::ENTRY_NOT_FOUND>("page is empty"); |
179 | 0 | } |
180 | | |
181 | 0 | uint32_t left = 0; |
182 | 0 | uint32_t right = _num_elems; |
183 | |
|
184 | 0 | const void* mid_value = nullptr; |
185 | | |
186 | | // find the first value >= target. after loop, |
187 | | // - left == index of first value >= target when found |
188 | | // - left == _num_elems when not found (all values < target) |
189 | 0 | while (left < right) { |
190 | 0 | uint32_t mid = left + (right - left) / 2; |
191 | 0 | mid_value = &_data[PLAIN_PAGE_HEADER_SIZE + mid * SIZE_OF_TYPE]; |
192 | 0 | if (TypeTraits<Type>::cmp(mid_value, value) < 0) { |
193 | 0 | left = mid + 1; |
194 | 0 | } else { |
195 | 0 | right = mid; |
196 | 0 | } |
197 | 0 | } |
198 | 0 | if (left >= _num_elems) { |
199 | 0 | return Status::Error<ErrorCode::ENTRY_NOT_FOUND>("all value small than the value"); |
200 | 0 | } |
201 | 0 | const void* find_value = &_data[PLAIN_PAGE_HEADER_SIZE + left * SIZE_OF_TYPE]; |
202 | 0 | if (TypeTraits<Type>::cmp(find_value, value) == 0) { |
203 | 0 | *exact_match = true; |
204 | 0 | } else { |
205 | 0 | *exact_match = false; |
206 | 0 | } |
207 | |
|
208 | 0 | _cur_idx = left; |
209 | 0 | return Status::OK(); |
210 | 0 | } Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE1EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE3EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE5EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE7EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE9EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE10EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE11EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE24EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE14EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE28EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE29EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE15EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE40EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE16EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE31EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE32EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE33EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE37EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE38EE22seek_at_or_after_valueEPKvPb Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE39EE22seek_at_or_after_valueEPKvPb |
211 | | |
212 | 979k | Status next_batch(size_t* n, MutableColumnPtr& dst) override { |
213 | 979k | DCHECK(_parsed); |
214 | 979k | if (*n == 0 || _cur_idx >= _num_elems) [[unlikely]] { |
215 | 0 | return Status::OK(); |
216 | 0 | } |
217 | | |
218 | 979k | size_t max_fetch = std::min(*n, static_cast<size_t>(_num_elems - _cur_idx)); |
219 | 979k | const void* src_data = &_data[PLAIN_PAGE_HEADER_SIZE + _cur_idx * SIZE_OF_TYPE]; |
220 | | |
221 | 979k | dst->insert_many_fix_len_data((const char*)src_data, max_fetch); |
222 | | |
223 | 979k | *n = max_fetch; |
224 | 979k | _cur_idx += max_fetch; |
225 | | |
226 | 979k | return Status::OK(); |
227 | 979k | } _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE1EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Line | Count | Source | 212 | 417k | Status next_batch(size_t* n, MutableColumnPtr& dst) override { | 213 | 417k | DCHECK(_parsed); | 214 | 417k | if (*n == 0 || _cur_idx >= _num_elems) [[unlikely]] { | 215 | 0 | return Status::OK(); | 216 | 0 | } | 217 | | | 218 | 417k | size_t max_fetch = std::min(*n, static_cast<size_t>(_num_elems - _cur_idx)); | 219 | 417k | const void* src_data = &_data[PLAIN_PAGE_HEADER_SIZE + _cur_idx * SIZE_OF_TYPE]; | 220 | | | 221 | 417k | dst->insert_many_fix_len_data((const char*)src_data, max_fetch); | 222 | | | 223 | 417k | *n = max_fetch; | 224 | 417k | _cur_idx += max_fetch; | 225 | | | 226 | 417k | return Status::OK(); | 227 | 417k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE3EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Line | Count | Source | 212 | 15.6k | Status next_batch(size_t* n, MutableColumnPtr& dst) override { | 213 | 15.6k | DCHECK(_parsed); | 214 | 15.6k | if (*n == 0 || _cur_idx >= _num_elems) [[unlikely]] { | 215 | 0 | return Status::OK(); | 216 | 0 | } | 217 | | | 218 | 15.6k | size_t max_fetch = std::min(*n, static_cast<size_t>(_num_elems - _cur_idx)); | 219 | 15.6k | const void* src_data = &_data[PLAIN_PAGE_HEADER_SIZE + _cur_idx * SIZE_OF_TYPE]; | 220 | | | 221 | 15.6k | dst->insert_many_fix_len_data((const char*)src_data, max_fetch); | 222 | | | 223 | 15.6k | *n = max_fetch; | 224 | 15.6k | _cur_idx += max_fetch; | 225 | | | 226 | 15.6k | return Status::OK(); | 227 | 15.6k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE5EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Line | Count | Source | 212 | 455k | Status next_batch(size_t* n, MutableColumnPtr& dst) override { | 213 | 455k | DCHECK(_parsed); | 214 | 455k | if (*n == 0 || _cur_idx >= _num_elems) [[unlikely]] { | 215 | 0 | return Status::OK(); | 216 | 0 | } | 217 | | | 218 | 455k | size_t max_fetch = std::min(*n, static_cast<size_t>(_num_elems - _cur_idx)); | 219 | 455k | const void* src_data = &_data[PLAIN_PAGE_HEADER_SIZE + _cur_idx * SIZE_OF_TYPE]; | 220 | | | 221 | 455k | dst->insert_many_fix_len_data((const char*)src_data, max_fetch); | 222 | | | 223 | 455k | *n = max_fetch; | 224 | 455k | _cur_idx += max_fetch; | 225 | | | 226 | 455k | return Status::OK(); | 227 | 455k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE7EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Line | Count | Source | 212 | 67.2k | Status next_batch(size_t* n, MutableColumnPtr& dst) override { | 213 | 67.2k | DCHECK(_parsed); | 214 | 67.2k | if (*n == 0 || _cur_idx >= _num_elems) [[unlikely]] { | 215 | 0 | return Status::OK(); | 216 | 0 | } | 217 | | | 218 | 67.2k | size_t max_fetch = std::min(*n, static_cast<size_t>(_num_elems - _cur_idx)); | 219 | 67.2k | const void* src_data = &_data[PLAIN_PAGE_HEADER_SIZE + _cur_idx * SIZE_OF_TYPE]; | 220 | | | 221 | 67.2k | dst->insert_many_fix_len_data((const char*)src_data, max_fetch); | 222 | | | 223 | 67.2k | *n = max_fetch; | 224 | 67.2k | _cur_idx += max_fetch; | 225 | | | 226 | 67.2k | return Status::OK(); | 227 | 67.2k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE9EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Line | Count | Source | 212 | 23.0k | Status next_batch(size_t* n, MutableColumnPtr& dst) override { | 213 | 23.0k | DCHECK(_parsed); | 214 | 23.0k | if (*n == 0 || _cur_idx >= _num_elems) [[unlikely]] { | 215 | 0 | return Status::OK(); | 216 | 0 | } | 217 | | | 218 | 23.0k | size_t max_fetch = std::min(*n, static_cast<size_t>(_num_elems - _cur_idx)); | 219 | 23.0k | const void* src_data = &_data[PLAIN_PAGE_HEADER_SIZE + _cur_idx * SIZE_OF_TYPE]; | 220 | | | 221 | 23.0k | dst->insert_many_fix_len_data((const char*)src_data, max_fetch); | 222 | | | 223 | 23.0k | *n = max_fetch; | 224 | 23.0k | _cur_idx += max_fetch; | 225 | | | 226 | 23.0k | return Status::OK(); | 227 | 23.0k | } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE10EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE11EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE24EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE14EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE28EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE29EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE15EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE40EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE16EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE31EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE32EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE33EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE37EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE38EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE39EE10next_batchEPmRNS_3COWINS_7IColumnEE11mutable_ptrIS6_EE |
228 | | |
229 | | Status read_by_rowids(const rowid_t* rowids, ordinal_t page_first_ordinal, size_t* n, |
230 | 134k | MutableColumnPtr& dst) override { |
231 | 134k | DCHECK(_parsed); |
232 | 134k | if (*n == 0) [[unlikely]] { |
233 | 0 | return Status::OK(); |
234 | 0 | } |
235 | | |
236 | 134k | auto total = *n; |
237 | 134k | auto read_count = 0; |
238 | 134k | _buffer.resize(total); |
239 | 70.8M | for (size_t i = 0; i < total; ++i) { |
240 | 70.6M | ordinal_t ord = rowids[i] - page_first_ordinal; |
241 | 70.6M | if (UNLIKELY(ord >= _num_elems)) { |
242 | 3.76k | break; |
243 | 3.76k | } |
244 | | |
245 | 70.6M | _buffer[read_count++] = |
246 | 70.6M | unaligned_load<CppType>(&_data[PLAIN_PAGE_HEADER_SIZE + ord * SIZE_OF_TYPE]); |
247 | 70.6M | } |
248 | | |
249 | 134k | if (LIKELY(read_count > 0)) { |
250 | 134k | dst->insert_many_fix_len_data((char*)_buffer.data(), read_count); |
251 | 134k | } |
252 | | |
253 | 134k | *n = read_count; |
254 | 134k | return Status::OK(); |
255 | 134k | } _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE1EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Line | Count | Source | 230 | 17.2k | MutableColumnPtr& dst) override { | 231 | 17.2k | DCHECK(_parsed); | 232 | 17.2k | if (*n == 0) [[unlikely]] { | 233 | 0 | return Status::OK(); | 234 | 0 | } | 235 | | | 236 | 17.2k | auto total = *n; | 237 | 17.2k | auto read_count = 0; | 238 | 17.2k | _buffer.resize(total); | 239 | 3.28M | for (size_t i = 0; i < total; ++i) { | 240 | 3.26M | ordinal_t ord = rowids[i] - page_first_ordinal; | 241 | 3.26M | if (UNLIKELY(ord >= _num_elems)) { | 242 | 65 | break; | 243 | 65 | } | 244 | | | 245 | 3.26M | _buffer[read_count++] = | 246 | 3.26M | unaligned_load<CppType>(&_data[PLAIN_PAGE_HEADER_SIZE + ord * SIZE_OF_TYPE]); | 247 | 3.26M | } | 248 | | | 249 | 17.2k | if (LIKELY(read_count > 0)) { | 250 | 17.2k | dst->insert_many_fix_len_data((char*)_buffer.data(), read_count); | 251 | 17.2k | } | 252 | | | 253 | 17.2k | *n = read_count; | 254 | 17.2k | return Status::OK(); | 255 | 17.2k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE3EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Line | Count | Source | 230 | 5.54k | MutableColumnPtr& dst) override { | 231 | 5.54k | DCHECK(_parsed); | 232 | 5.54k | if (*n == 0) [[unlikely]] { | 233 | 0 | return Status::OK(); | 234 | 0 | } | 235 | | | 236 | 5.54k | auto total = *n; | 237 | 5.54k | auto read_count = 0; | 238 | 5.54k | _buffer.resize(total); | 239 | 830k | for (size_t i = 0; i < total; ++i) { | 240 | 824k | ordinal_t ord = rowids[i] - page_first_ordinal; | 241 | 824k | if (UNLIKELY(ord >= _num_elems)) { | 242 | 12 | break; | 243 | 12 | } | 244 | | | 245 | 824k | _buffer[read_count++] = | 246 | 824k | unaligned_load<CppType>(&_data[PLAIN_PAGE_HEADER_SIZE + ord * SIZE_OF_TYPE]); | 247 | 824k | } | 248 | | | 249 | 5.54k | if (LIKELY(read_count > 0)) { | 250 | 5.54k | dst->insert_many_fix_len_data((char*)_buffer.data(), read_count); | 251 | 5.54k | } | 252 | | | 253 | 5.54k | *n = read_count; | 254 | 5.54k | return Status::OK(); | 255 | 5.54k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE5EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Line | Count | Source | 230 | 67.8k | MutableColumnPtr& dst) override { | 231 | 67.8k | DCHECK(_parsed); | 232 | 67.8k | if (*n == 0) [[unlikely]] { | 233 | 0 | return Status::OK(); | 234 | 0 | } | 235 | | | 236 | 67.8k | auto total = *n; | 237 | 67.8k | auto read_count = 0; | 238 | 67.8k | _buffer.resize(total); | 239 | 33.5M | for (size_t i = 0; i < total; ++i) { | 240 | 33.4M | ordinal_t ord = rowids[i] - page_first_ordinal; | 241 | 33.4M | if (UNLIKELY(ord >= _num_elems)) { | 242 | 1.81k | break; | 243 | 1.81k | } | 244 | | | 245 | 33.4M | _buffer[read_count++] = | 246 | 33.4M | unaligned_load<CppType>(&_data[PLAIN_PAGE_HEADER_SIZE + ord * SIZE_OF_TYPE]); | 247 | 33.4M | } | 248 | | | 249 | 67.8k | if (LIKELY(read_count > 0)) { | 250 | 67.8k | dst->insert_many_fix_len_data((char*)_buffer.data(), read_count); | 251 | 67.8k | } | 252 | | | 253 | 67.8k | *n = read_count; | 254 | 67.8k | return Status::OK(); | 255 | 67.8k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE7EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Line | Count | Source | 230 | 34.8k | MutableColumnPtr& dst) override { | 231 | 34.8k | DCHECK(_parsed); | 232 | 34.8k | if (*n == 0) [[unlikely]] { | 233 | 0 | return Status::OK(); | 234 | 0 | } | 235 | | | 236 | 34.8k | auto total = *n; | 237 | 34.8k | auto read_count = 0; | 238 | 34.8k | _buffer.resize(total); | 239 | 31.1M | for (size_t i = 0; i < total; ++i) { | 240 | 31.1M | ordinal_t ord = rowids[i] - page_first_ordinal; | 241 | 31.1M | if (UNLIKELY(ord >= _num_elems)) { | 242 | 1.60k | break; | 243 | 1.60k | } | 244 | | | 245 | 31.1M | _buffer[read_count++] = | 246 | 31.1M | unaligned_load<CppType>(&_data[PLAIN_PAGE_HEADER_SIZE + ord * SIZE_OF_TYPE]); | 247 | 31.1M | } | 248 | | | 249 | 34.8k | if (LIKELY(read_count > 0)) { | 250 | 34.8k | dst->insert_many_fix_len_data((char*)_buffer.data(), read_count); | 251 | 34.8k | } | 252 | | | 253 | 34.8k | *n = read_count; | 254 | 34.8k | return Status::OK(); | 255 | 34.8k | } |
_ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE9EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Line | Count | Source | 230 | 8.81k | MutableColumnPtr& dst) override { | 231 | 8.81k | DCHECK(_parsed); | 232 | 8.81k | if (*n == 0) [[unlikely]] { | 233 | 0 | return Status::OK(); | 234 | 0 | } | 235 | | | 236 | 8.81k | auto total = *n; | 237 | 8.81k | auto read_count = 0; | 238 | 8.81k | _buffer.resize(total); | 239 | 1.99M | for (size_t i = 0; i < total; ++i) { | 240 | 1.98M | ordinal_t ord = rowids[i] - page_first_ordinal; | 241 | 1.98M | if (UNLIKELY(ord >= _num_elems)) { | 242 | 265 | break; | 243 | 265 | } | 244 | | | 245 | 1.98M | _buffer[read_count++] = | 246 | 1.98M | unaligned_load<CppType>(&_data[PLAIN_PAGE_HEADER_SIZE + ord * SIZE_OF_TYPE]); | 247 | 1.98M | } | 248 | | | 249 | 8.81k | if (LIKELY(read_count > 0)) { | 250 | 8.81k | dst->insert_many_fix_len_data((char*)_buffer.data(), read_count); | 251 | 8.81k | } | 252 | | | 253 | 8.81k | *n = read_count; | 254 | 8.81k | return Status::OK(); | 255 | 8.81k | } |
Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE10EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE11EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE24EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE14EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE28EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE29EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE15EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE40EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE16EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE31EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE32EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE33EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE37EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE38EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE Unexecuted instantiation: _ZN5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE39EE14read_by_rowidsEPKjmPmRNS_3COWINS_7IColumnEE11mutable_ptrIS8_EE |
256 | | |
257 | 0 | size_t count() const override { |
258 | 0 | DCHECK(_parsed); |
259 | 0 | return _num_elems; |
260 | 0 | } Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE1EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE3EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE5EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE7EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE9EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE10EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE11EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE24EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE14EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE28EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE29EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE15EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE40EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE16EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE31EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE32EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE33EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE37EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE38EE5countEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE39EE5countEv |
261 | | |
262 | 227k | size_t current_index() const override { |
263 | | DCHECK(_parsed); |
264 | 227k | return _cur_idx; |
265 | 227k | } _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE1EE13current_indexEv Line | Count | Source | 262 | 15.4k | size_t current_index() const override { | 263 | | DCHECK(_parsed); | 264 | 15.4k | return _cur_idx; | 265 | 15.4k | } |
_ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE3EE13current_indexEv Line | Count | Source | 262 | 14.3k | size_t current_index() const override { | 263 | | DCHECK(_parsed); | 264 | 14.3k | return _cur_idx; | 265 | 14.3k | } |
_ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE5EE13current_indexEv Line | Count | Source | 262 | 22.3k | size_t current_index() const override { | 263 | | DCHECK(_parsed); | 264 | 22.3k | return _cur_idx; | 265 | 22.3k | } |
_ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE7EE13current_indexEv Line | Count | Source | 262 | 172k | size_t current_index() const override { | 263 | | DCHECK(_parsed); | 264 | 172k | return _cur_idx; | 265 | 172k | } |
_ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE9EE13current_indexEv Line | Count | Source | 262 | 3.54k | size_t current_index() const override { | 263 | | DCHECK(_parsed); | 264 | 3.54k | return _cur_idx; | 265 | 3.54k | } |
Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE10EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE11EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE24EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE14EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE28EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE29EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE15EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE40EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE16EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE31EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE32EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE33EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE37EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE38EE13current_indexEv Unexecuted instantiation: _ZNK5doris10segment_v216PlainPageDecoderILNS_9FieldTypeE39EE13current_indexEv |
266 | | |
267 | | private: |
268 | | Slice _data; |
269 | | PageDecoderOptions _options; |
270 | | bool _parsed; |
271 | | uint32_t _num_elems; |
272 | | uint32_t _cur_idx; |
273 | | typedef typename TypeTraits<Type>::CppType CppType; |
274 | | enum { SIZE_OF_TYPE = TypeTraits<Type>::size }; |
275 | | |
276 | | std::vector<std::conditional_t<std::is_same_v<CppType, bool>, uint8_t, CppType>> _buffer; |
277 | | }; |
278 | | |
279 | | } // namespace segment_v2 |
280 | | #include "common/compile_check_end.h" |
281 | | } // namespace doris |