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 | | // This file is copied from |
18 | | // https://github.com/ClickHouse/ClickHouse/blob/master/src/Core/Field.h |
19 | | // and modified by Doris |
20 | | |
21 | | #pragma once |
22 | | |
23 | | #include <fmt/format.h> |
24 | | #include <glog/logging.h> |
25 | | |
26 | | #include <algorithm> |
27 | | #include <cassert> |
28 | | #include <cstring> |
29 | | #include <map> |
30 | | #include <string> |
31 | | #include <string_view> |
32 | | #include <type_traits> |
33 | | #include <utility> |
34 | | #include <vector> |
35 | | |
36 | | #include "common/compiler_util.h" // IWYU pragma: keep |
37 | | #include "common/exception.h" |
38 | | #include "core/data_type/primitive_type.h" |
39 | | #include "core/string_view.h" |
40 | | #include "core/types.h" |
41 | | #include "core/uint128.h" |
42 | | #include "core/value/bitmap_value.h" |
43 | | #include "core/value/hll.h" |
44 | | #include "core/value/quantile_state.h" |
45 | | #include "util/json/path_in_data.h" |
46 | | |
47 | | namespace doris { |
48 | | template <PrimitiveType type> |
49 | | struct PrimitiveTypeTraits; |
50 | | template <typename T> |
51 | | struct TypeName; |
52 | | struct PackedInt128; |
53 | | } // namespace doris |
54 | | |
55 | | namespace doris { |
56 | | |
57 | | class Field; |
58 | | |
59 | | using FieldVector = std::vector<Field>; |
60 | | |
61 | | /// Array and Tuple use the same storage type -- FieldVector, but we declare |
62 | | /// distinct types for them, so that the caller can choose whether it wants to |
63 | | /// construct a Field of Array or a Tuple type. An alternative approach would be |
64 | | /// to construct both of these types from FieldVector, and have the caller |
65 | | /// specify the desired Field type explicitly. |
66 | | struct Array : public FieldVector { |
67 | | using FieldVector::FieldVector; |
68 | | }; |
69 | | |
70 | | struct Tuple : public FieldVector { |
71 | | using FieldVector::FieldVector; |
72 | | }; |
73 | | |
74 | | struct Map : public FieldVector { |
75 | | using FieldVector::FieldVector; |
76 | | }; |
77 | | |
78 | | struct FieldWithDataType; |
79 | | |
80 | | using VariantMap = std::map<PathInData, FieldWithDataType>; |
81 | | |
82 | | //TODO: rethink if we really need this? it only save one pointer from std::string |
83 | | // not POD type so could only use read/write_json_binary instead of read/write_binary |
84 | | class JsonbField { |
85 | | public: |
86 | 206k | JsonbField() = default; |
87 | 12.2M | ~JsonbField() = default; // unique_ptr will handle cleanup automatically |
88 | | |
89 | 2.40M | JsonbField(const char* ptr, size_t len) : size(len) { |
90 | 2.40M | data = std::make_unique<char[]>(size); |
91 | 2.40M | if (!data) { |
92 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", size)); |
93 | 0 | } |
94 | 2.40M | if (size > 0) { |
95 | 2.39M | memcpy(data.get(), ptr, size); |
96 | 2.39M | } |
97 | 2.40M | } |
98 | | |
99 | 2.70M | JsonbField(const JsonbField& x) : size(x.size) { |
100 | 2.70M | data = std::make_unique<char[]>(size); |
101 | 2.70M | if (!data) { |
102 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", size)); |
103 | 0 | } |
104 | 2.70M | if (size > 0) { |
105 | 2.68M | memcpy(data.get(), x.data.get(), size); |
106 | 2.68M | } |
107 | 2.70M | } |
108 | | |
109 | 6.93M | JsonbField(JsonbField&& x) noexcept : data(std::move(x.data)), size(x.size) { x.size = 0; } |
110 | | |
111 | | // dispatch for all type of storage. so need this. but not really used now. |
112 | 23 | JsonbField& operator=(const JsonbField& x) { |
113 | 23 | if (this != &x) { |
114 | 23 | data = std::make_unique<char[]>(x.size); |
115 | 23 | if (!data) { |
116 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", x.size)); |
117 | 0 | } |
118 | 23 | if (x.size > 0) { |
119 | 22 | memcpy(data.get(), x.data.get(), x.size); |
120 | 22 | } |
121 | 23 | size = x.size; |
122 | 23 | } |
123 | 23 | return *this; |
124 | 23 | } |
125 | | |
126 | 204k | JsonbField& operator=(JsonbField&& x) noexcept { |
127 | 204k | if (this != &x) { |
128 | 204k | data = std::move(x.data); |
129 | 204k | size = x.size; |
130 | 204k | x.size = 0; |
131 | 204k | } |
132 | 204k | return *this; |
133 | 204k | } |
134 | | |
135 | 1.98M | const char* get_value() const { return data.get(); } |
136 | 2.02M | size_t get_size() const { return size; } |
137 | | |
138 | 0 | bool operator<(const JsonbField& r) const { |
139 | 0 | throw Exception(Status::FatalError("comparing between JsonbField is not supported")); |
140 | 0 | } |
141 | 0 | bool operator<=(const JsonbField& r) const { |
142 | 0 | throw Exception(Status::FatalError("comparing between JsonbField is not supported")); |
143 | 0 | } |
144 | 0 | bool operator==(const JsonbField& r) const { |
145 | 0 | throw Exception(Status::FatalError("comparing between JsonbField is not supported")); |
146 | 0 | } |
147 | 0 | bool operator>(const JsonbField& r) const { |
148 | 0 | throw Exception(Status::FatalError("comparing between JsonbField is not supported")); |
149 | 0 | } |
150 | 0 | bool operator>=(const JsonbField& r) const { |
151 | 0 | throw Exception(Status::FatalError("comparing between JsonbField is not supported")); |
152 | 0 | } |
153 | 0 | bool operator!=(const JsonbField& r) const { |
154 | 0 | throw Exception(Status::FatalError("comparing between JsonbField is not supported")); |
155 | 0 | } |
156 | | |
157 | 0 | const JsonbField& operator+=(const JsonbField& r) { |
158 | 0 | throw Exception(Status::FatalError("Not support plus opration on JsonbField")); |
159 | 0 | } |
160 | | |
161 | 0 | const JsonbField& operator-=(const JsonbField& r) { |
162 | 0 | throw Exception(Status::FatalError("Not support minus opration on JsonbField")); |
163 | 0 | } |
164 | | |
165 | | private: |
166 | | std::unique_ptr<char[]> data = nullptr; |
167 | | size_t size = 0; |
168 | | }; |
169 | | |
170 | | template <typename T> |
171 | | bool decimal_equal(T x, T y, UInt32 x_scale, UInt32 y_scale); |
172 | | template <typename T> |
173 | | bool decimal_less(T x, T y, UInt32 x_scale, UInt32 y_scale); |
174 | | template <typename T> |
175 | | bool decimal_less_or_equal(T x, T y, UInt32 x_scale, UInt32 y_scale); |
176 | | |
177 | | /** 32 is enough. Round number is used for alignment and for better arithmetic inside std::vector. |
178 | | * NOTE: Actually, sizeof(std::string) is 32 when using libc++, so Field is 40 bytes. |
179 | | */ |
180 | | constexpr size_t DBMS_MIN_FIELD_SIZE = 32; |
181 | | |
182 | | /** Discriminated union of several types. |
183 | | * Made for replacement of `boost::variant` |
184 | | * is not generalized, |
185 | | * but somewhat more efficient, and simpler. |
186 | | * |
187 | | * Used to represent a single value of one of several types in memory. |
188 | | * Warning! Prefer to use chunks of columns instead of single values. See Column.h |
189 | | */ |
190 | | class Field { |
191 | | public: |
192 | | static const int MIN_NON_POD = 16; |
193 | 89.3M | Field() : type(PrimitiveType::TYPE_NULL) {} |
194 | | // set Types::Null explictly and avoid other types |
195 | 140M | Field(PrimitiveType w) : type(w) {} |
196 | | template <PrimitiveType T> |
197 | 23.5M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { |
198 | 23.5M | auto f = Field(T); |
199 | 23.5M | f.template create_concrete<T>(data); |
200 | 23.5M | return f; |
201 | 23.5M | } _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE23EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 1.19M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 1.19M | auto f = Field(T); | 199 | 1.19M | f.template create_concrete<T>(data); | 200 | 1.19M | return f; | 201 | 1.19M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE37EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 27.5k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 27.5k | auto f = Field(T); | 199 | 27.5k | f.template create_concrete<T>(data); | 200 | 27.5k | return f; | 201 | 27.5k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE41EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 6 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 6 | auto f = Field(T); | 199 | 6 | f.template create_concrete<T>(data); | 200 | 6 | return f; | 201 | 6 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE5EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 19.1M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 19.1M | auto f = Field(T); | 199 | 19.1M | f.template create_concrete<T>(data); | 200 | 19.1M | return f; | 201 | 19.1M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE15EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 135 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 135 | auto f = Field(T); | 199 | 135 | f.template create_concrete<T>(data); | 200 | 135 | return f; | 201 | 135 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE2EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 93.0k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 93.0k | auto f = Field(T); | 199 | 93.0k | f.template create_concrete<T>(data); | 200 | 93.0k | return f; | 201 | 93.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE3EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 125k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 125k | auto f = Field(T); | 199 | 125k | f.template create_concrete<T>(data); | 200 | 125k | return f; | 201 | 125k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE4EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 42.1k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 42.1k | auto f = Field(T); | 199 | 42.1k | f.template create_concrete<T>(data); | 200 | 42.1k | return f; | 201 | 42.1k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE6EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 1.43M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 1.43M | auto f = Field(T); | 199 | 1.43M | f.template create_concrete<T>(data); | 200 | 1.43M | return f; | 201 | 1.43M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE7EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 32.0k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 32.0k | auto f = Field(T); | 199 | 32.0k | f.template create_concrete<T>(data); | 200 | 32.0k | return f; | 201 | 32.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE8EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 38.2k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 38.2k | auto f = Field(T); | 199 | 38.2k | f.template create_concrete<T>(data); | 200 | 38.2k | return f; | 201 | 38.2k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE9EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 324k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 324k | auto f = Field(T); | 199 | 324k | f.template create_concrete<T>(data); | 200 | 324k | return f; | 201 | 324k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE36EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 37.3k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 37.3k | auto f = Field(T); | 199 | 37.3k | f.template create_concrete<T>(data); | 200 | 37.3k | return f; | 201 | 37.3k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE11EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 9.61k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 9.61k | auto f = Field(T); | 199 | 9.61k | f.template create_concrete<T>(data); | 200 | 9.61k | return f; | 201 | 9.61k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE25EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 65.0k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 65.0k | auto f = Field(T); | 199 | 65.0k | f.template create_concrete<T>(data); | 200 | 65.0k | return f; | 201 | 65.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE12EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 14.5k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 14.5k | auto f = Field(T); | 199 | 14.5k | f.template create_concrete<T>(data); | 200 | 14.5k | return f; | 201 | 14.5k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE26EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 82.7k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 82.7k | auto f = Field(T); | 199 | 82.7k | f.template create_concrete<T>(data); | 200 | 82.7k | return f; | 201 | 82.7k | } |
Unexecuted instantiation: _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE21EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE27EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 127 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 127 | auto f = Field(T); | 199 | 127 | f.template create_concrete<T>(data); | 200 | 127 | return f; | 201 | 127 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE42EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 12.2k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 12.2k | auto f = Field(T); | 199 | 12.2k | f.template create_concrete<T>(data); | 200 | 12.2k | return f; | 201 | 12.2k | } |
Unexecuted instantiation: _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE38EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Unexecuted instantiation: _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE39EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE17EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 766k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 766k | auto f = Field(T); | 199 | 766k | f.template create_concrete<T>(data); | 200 | 766k | return f; | 201 | 766k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE28EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 22.1k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 22.1k | auto f = Field(T); | 199 | 22.1k | f.template create_concrete<T>(data); | 200 | 22.1k | return f; | 201 | 22.1k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE29EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 28.4k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 28.4k | auto f = Field(T); | 199 | 28.4k | f.template create_concrete<T>(data); | 200 | 28.4k | return f; | 201 | 28.4k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE20EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 8.72k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 8.72k | auto f = Field(T); | 199 | 8.72k | f.template create_concrete<T>(data); | 200 | 8.72k | return f; | 201 | 8.72k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE30EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 28.4k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 28.4k | auto f = Field(T); | 199 | 28.4k | f.template create_concrete<T>(data); | 200 | 28.4k | return f; | 201 | 28.4k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE35EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 39.7k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 39.7k | auto f = Field(T); | 199 | 39.7k | f.template create_concrete<T>(data); | 200 | 39.7k | return f; | 201 | 39.7k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE24EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 22.3k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 22.3k | auto f = Field(T); | 199 | 22.3k | f.template create_concrete<T>(data); | 200 | 22.3k | return f; | 201 | 22.3k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE22EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 2.42k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 2.42k | auto f = Field(T); | 199 | 2.42k | f.template create_concrete<T>(data); | 200 | 2.42k | return f; | 201 | 2.42k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE19EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 403 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 403 | auto f = Field(T); | 199 | 403 | f.template create_concrete<T>(data); | 200 | 403 | return f; | 201 | 403 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE18EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 825 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 825 | auto f = Field(T); | 199 | 825 | f.template create_concrete<T>(data); | 200 | 825 | return f; | 201 | 825 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE16EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 31 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 31 | auto f = Field(T); | 199 | 31 | f.template create_concrete<T>(data); | 200 | 31 | return f; | 201 | 31 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE31EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 4 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 4 | auto f = Field(T); | 199 | 4 | f.template create_concrete<T>(data); | 200 | 4 | return f; | 201 | 4 | } |
|
202 | | template <PrimitiveType T> |
203 | 94.2M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { |
204 | 94.2M | auto f = Field(T); |
205 | 94.2M | f.template create_concrete<T>(std::move(data)); |
206 | 94.2M | return f; |
207 | 94.2M | } _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE23EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 15.8M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 15.8M | auto f = Field(T); | 205 | 15.8M | f.template create_concrete<T>(std::move(data)); | 206 | 15.8M | return f; | 207 | 15.8M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE25EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 221k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 221k | auto f = Field(T); | 205 | 221k | f.template create_concrete<T>(std::move(data)); | 206 | 221k | return f; | 207 | 221k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE26EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 268k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 268k | auto f = Field(T); | 205 | 268k | f.template create_concrete<T>(std::move(data)); | 206 | 268k | return f; | 207 | 268k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE22EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 54 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 54 | auto f = Field(T); | 205 | 54 | f.template create_concrete<T>(std::move(data)); | 206 | 54 | return f; | 207 | 54 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE11EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 3.90k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 3.90k | auto f = Field(T); | 205 | 3.90k | f.template create_concrete<T>(std::move(data)); | 206 | 3.90k | return f; | 207 | 3.90k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE12EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 3.01k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 3.01k | auto f = Field(T); | 205 | 3.01k | f.template create_concrete<T>(std::move(data)); | 206 | 3.01k | return f; | 207 | 3.01k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE19EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 18 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 18 | auto f = Field(T); | 205 | 18 | f.template create_concrete<T>(std::move(data)); | 206 | 18 | return f; | 207 | 18 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE32EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 447k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 447k | auto f = Field(T); | 205 | 447k | f.template create_concrete<T>(std::move(data)); | 206 | 447k | return f; | 207 | 447k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE15EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 54.3k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 54.3k | auto f = Field(T); | 205 | 54.3k | f.template create_concrete<T>(std::move(data)); | 206 | 54.3k | return f; | 207 | 54.3k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE28EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 39.1k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 39.1k | auto f = Field(T); | 205 | 39.1k | f.template create_concrete<T>(std::move(data)); | 206 | 39.1k | return f; | 207 | 39.1k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE29EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 13.5M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 13.5M | auto f = Field(T); | 205 | 13.5M | f.template create_concrete<T>(std::move(data)); | 206 | 13.5M | return f; | 207 | 13.5M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE20EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 10.3k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 10.3k | auto f = Field(T); | 205 | 10.3k | f.template create_concrete<T>(std::move(data)); | 206 | 10.3k | return f; | 207 | 10.3k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE35EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 9.59k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 9.59k | auto f = Field(T); | 205 | 9.59k | f.template create_concrete<T>(std::move(data)); | 206 | 9.59k | return f; | 207 | 9.59k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE30EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 73.3k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 73.3k | auto f = Field(T); | 205 | 73.3k | f.template create_concrete<T>(std::move(data)); | 206 | 73.3k | return f; | 207 | 73.3k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE1EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 54.0k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 54.0k | auto f = Field(T); | 205 | 54.0k | f.template create_concrete<T>(std::move(data)); | 206 | 54.0k | return f; | 207 | 54.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE31EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.61M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.61M | auto f = Field(T); | 205 | 2.61M | f.template create_concrete<T>(std::move(data)); | 206 | 2.61M | return f; | 207 | 2.61M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE2EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 28.7M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 28.7M | auto f = Field(T); | 205 | 28.7M | f.template create_concrete<T>(std::move(data)); | 206 | 28.7M | return f; | 207 | 28.7M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE3EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 5.87M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 5.87M | auto f = Field(T); | 205 | 5.87M | f.template create_concrete<T>(std::move(data)); | 206 | 5.87M | return f; | 207 | 5.87M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE4EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 91.4k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 91.4k | auto f = Field(T); | 205 | 91.4k | f.template create_concrete<T>(std::move(data)); | 206 | 91.4k | return f; | 207 | 91.4k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE5EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 970k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 970k | auto f = Field(T); | 205 | 970k | f.template create_concrete<T>(std::move(data)); | 206 | 970k | return f; | 207 | 970k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE6EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 20.5M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 20.5M | auto f = Field(T); | 205 | 20.5M | f.template create_concrete<T>(std::move(data)); | 206 | 20.5M | return f; | 207 | 20.5M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE7EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 119k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 119k | auto f = Field(T); | 205 | 119k | f.template create_concrete<T>(std::move(data)); | 206 | 119k | return f; | 207 | 119k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE8EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 42.8k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 42.8k | auto f = Field(T); | 205 | 42.8k | f.template create_concrete<T>(std::move(data)); | 206 | 42.8k | return f; | 207 | 42.8k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE9EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.97M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.97M | auto f = Field(T); | 205 | 2.97M | f.template create_concrete<T>(std::move(data)); | 206 | 2.97M | return f; | 207 | 2.97M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE36EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 5.03k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 5.03k | auto f = Field(T); | 205 | 5.03k | f.template create_concrete<T>(std::move(data)); | 206 | 5.03k | return f; | 207 | 5.03k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE37EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.61k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.61k | auto f = Field(T); | 205 | 2.61k | f.template create_concrete<T>(std::move(data)); | 206 | 2.61k | return f; | 207 | 2.61k | } |
Unexecuted instantiation: _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE21EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE27EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 5 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 5 | auto f = Field(T); | 205 | 5 | f.template create_concrete<T>(std::move(data)); | 206 | 5 | return f; | 207 | 5 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE42EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 21.1k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 21.1k | auto f = Field(T); | 205 | 21.1k | f.template create_concrete<T>(std::move(data)); | 206 | 21.1k | return f; | 207 | 21.1k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE17EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 963k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 963k | auto f = Field(T); | 205 | 963k | f.template create_concrete<T>(std::move(data)); | 206 | 963k | return f; | 207 | 963k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE24EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 18 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 18 | auto f = Field(T); | 205 | 18 | f.template create_concrete<T>(std::move(data)); | 206 | 18 | return f; | 207 | 18 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE41EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 19 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 19 | auto f = Field(T); | 205 | 19 | f.template create_concrete<T>(std::move(data)); | 206 | 19 | return f; | 207 | 19 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE18EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 25.1k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 25.1k | auto f = Field(T); | 205 | 25.1k | f.template create_concrete<T>(std::move(data)); | 206 | 25.1k | return f; | 207 | 25.1k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE16EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 5.80k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 5.80k | auto f = Field(T); | 205 | 5.80k | f.template create_concrete<T>(std::move(data)); | 206 | 5.80k | return f; | 207 | 5.80k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE10EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 688k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 688k | auto f = Field(T); | 205 | 688k | f.template create_concrete<T>(std::move(data)); | 206 | 688k | return f; | 207 | 688k | } |
|
208 | | |
209 | | template <PrimitiveType PType, typename ValType = std::conditional_t< |
210 | | doris::is_string_type(PType), StringRef, |
211 | | typename PrimitiveTypeTraits<PType>::StorageFieldType>> |
212 | 8.41M | static Field create_field_from_olap_value(const ValType& data) { |
213 | 8.41M | auto f = Field(PType); |
214 | 8.41M | typename PrimitiveTypeTraits<PType>::CppType cpp_value; |
215 | 8.41M | if constexpr (is_string_type(PType)) { |
216 | 4.66M | auto min_size = |
217 | 4.66M | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; |
218 | 4.66M | cpp_value = String(data.data, min_size); |
219 | 4.66M | } else if constexpr (is_date_or_datetime(PType)) { |
220 | 1.07k | if constexpr (PType == TYPE_DATE) { |
221 | 392 | cpp_value.from_olap_date(data); |
222 | 681 | } else { |
223 | 681 | cpp_value.from_olap_datetime(data); |
224 | 681 | } |
225 | 1.07k | } else if constexpr (is_decimalv2(PType)) { |
226 | 144 | cpp_value = DecimalV2Value(data.integer, data.fraction); |
227 | 3.75M | } else { |
228 | 3.75M | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); |
229 | 3.75M | } |
230 | 8.41M | f.template create_concrete<PType>(std::move(cpp_value)); |
231 | 8.41M | return f; |
232 | 8.41M | } _ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE3EaEES0_RKT0_ Line | Count | Source | 212 | 104k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 104k | auto f = Field(PType); | 214 | 104k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 104k | } else { | 228 | 104k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 104k | } | 230 | 104k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 104k | return f; | 232 | 104k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE4EsEES0_RKT0_ Line | Count | Source | 212 | 23.8k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 23.8k | auto f = Field(PType); | 214 | 23.8k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 23.8k | } else { | 228 | 23.8k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 23.8k | } | 230 | 23.8k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 23.8k | return f; | 232 | 23.8k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE5EiEES0_RKT0_ Line | Count | Source | 212 | 1.60M | static Field create_field_from_olap_value(const ValType& data) { | 213 | 1.60M | auto f = Field(PType); | 214 | 1.60M | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 1.60M | } else { | 228 | 1.60M | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 1.60M | } | 230 | 1.60M | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 1.60M | return f; | 232 | 1.60M | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE6ElEES0_RKT0_ Line | Count | Source | 212 | 1.24M | static Field create_field_from_olap_value(const ValType& data) { | 213 | 1.24M | auto f = Field(PType); | 214 | 1.24M | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 1.24M | } else { | 228 | 1.24M | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 1.24M | } | 230 | 1.24M | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 1.24M | return f; | 232 | 1.24M | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE7EnEES0_RKT0_ Line | Count | Source | 212 | 42.6k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 42.6k | auto f = Field(PType); | 214 | 42.6k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 42.6k | } else { | 228 | 42.6k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 42.6k | } | 230 | 42.6k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 42.6k | return f; | 232 | 42.6k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE8EfEES0_RKT0_ Line | Count | Source | 212 | 14.5k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 14.5k | auto f = Field(PType); | 214 | 14.5k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 14.5k | } else { | 228 | 14.5k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 14.5k | } | 230 | 14.5k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 14.5k | return f; | 232 | 14.5k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE9EdEES0_RKT0_ Line | Count | Source | 212 | 23.6k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 23.6k | auto f = Field(PType); | 214 | 23.6k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 23.6k | } else { | 228 | 23.6k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 23.6k | } | 230 | 23.6k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 23.6k | return f; | 232 | 23.6k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE15ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 69.3k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 69.3k | auto f = Field(PType); | 214 | 69.3k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 69.3k | if constexpr (is_string_type(PType)) { | 216 | 69.3k | auto min_size = | 217 | 69.3k | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | 69.3k | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | | } else { | 228 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | | } | 230 | 69.3k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 69.3k | return f; | 232 | 69.3k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE11ENS_8uint24_tEEES0_RKT0_ Line | Count | Source | 212 | 392 | static Field create_field_from_olap_value(const ValType& data) { | 213 | 392 | auto f = Field(PType); | 214 | 392 | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | 392 | } else if constexpr (is_date_or_datetime(PType)) { | 220 | 392 | if constexpr (PType == TYPE_DATE) { | 221 | 392 | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | | } else { | 228 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | | } | 230 | 392 | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 392 | return f; | 232 | 392 | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE12EmEES0_RKT0_ Line | Count | Source | 212 | 681 | static Field create_field_from_olap_value(const ValType& data) { | 213 | 681 | auto f = Field(PType); | 214 | 681 | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | 681 | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | 681 | } else { | 223 | 681 | cpp_value.from_olap_datetime(data); | 224 | 681 | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | | } else { | 228 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | | } | 230 | 681 | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 681 | return f; | 232 | 681 | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE25EjEES0_RKT0_ Line | Count | Source | 212 | 142k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 142k | auto f = Field(PType); | 214 | 142k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 142k | } else { | 228 | 142k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 142k | } | 230 | 142k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 142k | return f; | 232 | 142k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE26EmEES0_RKT0_ Line | Count | Source | 212 | 75.7k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 75.7k | auto f = Field(PType); | 214 | 75.7k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 75.7k | } else { | 228 | 75.7k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 75.7k | } | 230 | 75.7k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 75.7k | return f; | 232 | 75.7k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE42EmEES0_RKT0_ Line | Count | Source | 212 | 6.51k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 6.51k | auto f = Field(PType); | 214 | 6.51k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 6.51k | } else { | 228 | 6.51k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 6.51k | } | 230 | 6.51k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 6.51k | return f; | 232 | 6.51k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE36EjEES0_RKT0_ Line | Count | Source | 212 | 1.26k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 1.26k | auto f = Field(PType); | 214 | 1.26k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 1.26k | } else { | 228 | 1.26k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 1.26k | } | 230 | 1.26k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 1.26k | return f; | 232 | 1.26k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE37EoEES0_RKT0_ Line | Count | Source | 212 | 6.07k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 6.07k | auto f = Field(PType); | 214 | 6.07k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 6.07k | } else { | 228 | 6.07k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 6.07k | } | 230 | 6.07k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 6.07k | return f; | 232 | 6.07k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE10ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 436k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 436k | auto f = Field(PType); | 214 | 436k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 436k | if constexpr (is_string_type(PType)) { | 216 | 436k | auto min_size = | 217 | 436k | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | 436k | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | | } else { | 228 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | | } | 230 | 436k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 436k | return f; | 232 | 436k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE23ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 4.15M | static Field create_field_from_olap_value(const ValType& data) { | 213 | 4.15M | auto f = Field(PType); | 214 | 4.15M | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 4.15M | if constexpr (is_string_type(PType)) { | 216 | 4.15M | auto min_size = | 217 | 4.15M | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | 4.15M | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | | } else { | 228 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | | } | 230 | 4.15M | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 4.15M | return f; | 232 | 4.15M | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE28EiEES0_RKT0_ Line | Count | Source | 212 | 7.00k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 7.00k | auto f = Field(PType); | 214 | 7.00k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 7.00k | } else { | 228 | 7.00k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 7.00k | } | 230 | 7.00k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 7.00k | return f; | 232 | 7.00k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE29ElEES0_RKT0_ Line | Count | Source | 212 | 66.2k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 66.2k | auto f = Field(PType); | 214 | 66.2k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 66.2k | } else { | 228 | 66.2k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 66.2k | } | 230 | 66.2k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 66.2k | return f; | 232 | 66.2k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE30EnEES0_RKT0_ Line | Count | Source | 212 | 21.5k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 21.5k | auto f = Field(PType); | 214 | 21.5k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 21.5k | } else { | 228 | 21.5k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 21.5k | } | 230 | 21.5k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 21.5k | return f; | 232 | 21.5k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE35EN4wide7integerILm256EiEEEES0_RKT0_ Line | Count | Source | 212 | 1.14k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 1.14k | auto f = Field(PType); | 214 | 1.14k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 1.14k | } else { | 228 | 1.14k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 1.14k | } | 230 | 1.14k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 1.14k | return f; | 232 | 1.14k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE20ENS_11decimal12_tEEES0_RKT0_ Line | Count | Source | 212 | 144 | static Field create_field_from_olap_value(const ValType& data) { | 213 | 144 | auto f = Field(PType); | 214 | 144 | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | 144 | } else if constexpr (is_decimalv2(PType)) { | 226 | 144 | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | | } else { | 228 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | | } | 230 | 144 | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 144 | return f; | 232 | 144 | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE2EhEES0_RKT0_ Line | Count | Source | 212 | 363k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 363k | auto f = Field(PType); | 214 | 363k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | auto min_size = | 217 | | MAX_ZONE_MAP_INDEX_SIZE >= data.size ? data.size : MAX_ZONE_MAP_INDEX_SIZE; | 218 | | cpp_value = String(data.data, min_size); | 219 | | } else if constexpr (is_date_or_datetime(PType)) { | 220 | | if constexpr (PType == TYPE_DATE) { | 221 | | cpp_value.from_olap_date(data); | 222 | | } else { | 223 | | cpp_value.from_olap_datetime(data); | 224 | | } | 225 | | } else if constexpr (is_decimalv2(PType)) { | 226 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 227 | 363k | } else { | 228 | 363k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 229 | 363k | } | 230 | 363k | f.template create_concrete<PType>(std::move(cpp_value)); | 231 | 363k | return f; | 232 | 363k | } |
|
233 | | |
234 | | /** Despite the presence of a template constructor, this constructor is still needed, |
235 | | * since, in its absence, the compiler will still generate the default constructor. |
236 | | */ |
237 | | Field(const Field& rhs); |
238 | | |
239 | | Field(Field&& rhs); |
240 | | |
241 | | Field& operator=(const Field& rhs); |
242 | | |
243 | 20.9M | bool is_complex_field() const { |
244 | 20.9M | return type == PrimitiveType::TYPE_ARRAY || type == PrimitiveType::TYPE_MAP || |
245 | 20.9M | type == PrimitiveType::TYPE_STRUCT || type == PrimitiveType::TYPE_VARIANT; |
246 | 20.9M | } |
247 | | |
248 | 67.1M | Field& operator=(Field&& rhs) { |
249 | 67.1M | if (this != &rhs) { |
250 | 67.1M | if (type != rhs.type) { |
251 | 39.2M | destroy(); |
252 | 39.2M | create(std::move(rhs)); |
253 | 39.2M | } else { |
254 | 27.8M | assign(std::move(rhs)); |
255 | 27.8M | } |
256 | 67.1M | } |
257 | 67.1M | return *this; |
258 | 67.1M | } |
259 | | |
260 | 492M | ~Field() { destroy(); } |
261 | | |
262 | 132M | PrimitiveType get_type() const { return type; } |
263 | | std::string get_type_name() const; |
264 | | |
265 | 134M | bool is_null() const { return type == PrimitiveType::TYPE_NULL; } |
266 | | |
267 | | // The template parameter T needs to be consistent with `which`. |
268 | | // If not, use NearestFieldType<> externally. |
269 | | // Maybe modify this in the future, reference: https://github.com/ClickHouse/ClickHouse/pull/22003 |
270 | | template <PrimitiveType T> |
271 | | typename PrimitiveTypeTraits<T>::CppType& get(); |
272 | | |
273 | | template <PrimitiveType T> |
274 | | const typename PrimitiveTypeTraits<T>::CppType& get() const; |
275 | | |
276 | 14.0M | bool operator==(const Field& rhs) const { |
277 | 14.0M | return operator<=>(rhs) == std::strong_ordering::equal; |
278 | 14.0M | } |
279 | | |
280 | | std::strong_ordering operator<=>(const Field& rhs) const; |
281 | | |
282 | | std::string_view as_string_view() const; |
283 | | |
284 | | private: |
285 | | std::aligned_union_t<DBMS_MIN_FIELD_SIZE - sizeof(PrimitiveType), Null, UInt64, UInt128, Int64, |
286 | | Int128, IPv6, Float64, String, JsonbField, StringView, Array, Tuple, Map, |
287 | | VariantMap, Decimal32, Decimal64, DecimalV2Value, Decimal128V3, Decimal256, |
288 | | BitmapValue, HyperLogLog, QuantileState> |
289 | | storage; |
290 | | |
291 | | PrimitiveType type; |
292 | | |
293 | | /// Assuming there was no allocated state or it was deallocated (see destroy). |
294 | | template <PrimitiveType Type> |
295 | | void create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x); |
296 | | template <PrimitiveType Type> |
297 | | void create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x); |
298 | | /// Assuming same types. |
299 | | template <PrimitiveType Type> |
300 | | void assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x); |
301 | | template <PrimitiveType Type> |
302 | | void assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x); |
303 | | |
304 | | void create(const Field& field); |
305 | | void create(Field&& field); |
306 | | |
307 | | void assign(const Field& x); |
308 | | void assign(Field&& x); |
309 | | |
310 | | void destroy(); |
311 | | |
312 | | template <PrimitiveType T> |
313 | | void destroy(); |
314 | | }; |
315 | | |
316 | | struct FieldWithDataType { |
317 | | Field field; |
318 | | // used for nested type of array |
319 | | PrimitiveType base_scalar_type_id = PrimitiveType::INVALID_TYPE; |
320 | | uint8_t num_dimensions = 0; |
321 | | int precision = -1; |
322 | | int scale = -1; |
323 | | }; |
324 | | |
325 | | } // namespace doris |
326 | | |
327 | | template <> |
328 | | struct std::hash<doris::Field> { |
329 | 1.45k | size_t operator()(const doris::Field& field) const { |
330 | 1.45k | if (field.is_null()) { |
331 | 158 | return 0; |
332 | 158 | } |
333 | 1.29k | std::hash<std::string_view> hasher; |
334 | 1.29k | return hasher(field.as_string_view()); |
335 | 1.45k | } |
336 | | }; |