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 | 209k | JsonbField() = default; |
87 | 10.4M | ~JsonbField() = default; // unique_ptr will handle cleanup automatically |
88 | | |
89 | 2.34M | JsonbField(const char* ptr, size_t len) : size(len) { |
90 | 2.34M | data = std::make_unique<char[]>(size); |
91 | 2.34M | if (!data) { |
92 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", size)); |
93 | 0 | } |
94 | 2.34M | if (size > 0) { |
95 | 2.33M | memcpy(data.get(), ptr, size); |
96 | 2.33M | } |
97 | 2.34M | } |
98 | | |
99 | 2.50M | JsonbField(const JsonbField& x) : size(x.size) { |
100 | 2.50M | data = std::make_unique<char[]>(size); |
101 | 2.50M | if (!data) { |
102 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", size)); |
103 | 0 | } |
104 | 2.50M | if (size > 0) { |
105 | 2.48M | memcpy(data.get(), x.data.get(), size); |
106 | 2.48M | } |
107 | 2.50M | } |
108 | | |
109 | 5.41M | 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 | 18 | JsonbField& operator=(const JsonbField& x) { |
113 | 18 | if (this != &x) { |
114 | 18 | data = std::make_unique<char[]>(x.size); |
115 | 18 | if (!data) { |
116 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", x.size)); |
117 | 0 | } |
118 | 18 | if (x.size > 0) { |
119 | 17 | memcpy(data.get(), x.data.get(), x.size); |
120 | 17 | } |
121 | 18 | size = x.size; |
122 | 18 | } |
123 | 18 | return *this; |
124 | 18 | } |
125 | | |
126 | 207k | JsonbField& operator=(JsonbField&& x) noexcept { |
127 | 207k | if (this != &x) { |
128 | 207k | data = std::move(x.data); |
129 | 207k | size = x.size; |
130 | 207k | x.size = 0; |
131 | 207k | } |
132 | 207k | return *this; |
133 | 207k | } |
134 | | |
135 | 1.93M | const char* get_value() const { return data.get(); } |
136 | 1.93M | 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 | 119M | Field() : type(PrimitiveType::TYPE_NULL) {} |
194 | | // set Types::Null explictly and avoid other types |
195 | 135M | Field(PrimitiveType w) : type(w) {} |
196 | | template <PrimitiveType T> |
197 | 27.2M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { |
198 | 27.2M | auto f = Field(T); |
199 | 27.2M | f.template create_concrete<T>(data); |
200 | 27.2M | return f; |
201 | 27.2M | } _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE23EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 1.30M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 1.30M | auto f = Field(T); | 199 | 1.30M | f.template create_concrete<T>(data); | 200 | 1.30M | return f; | 201 | 1.30M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE37EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 28.0k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 28.0k | auto f = Field(T); | 199 | 28.0k | f.template create_concrete<T>(data); | 200 | 28.0k | return f; | 201 | 28.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE41EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 7 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 7 | auto f = Field(T); | 199 | 7 | f.template create_concrete<T>(data); | 200 | 7 | return f; | 201 | 7 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE5EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 19.9M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 19.9M | auto f = Field(T); | 199 | 19.9M | f.template create_concrete<T>(data); | 200 | 19.9M | return f; | 201 | 19.9M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE15EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 201 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 201 | auto f = Field(T); | 199 | 201 | f.template create_concrete<T>(data); | 200 | 201 | return f; | 201 | 201 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE2EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 139k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 139k | auto f = Field(T); | 199 | 139k | f.template create_concrete<T>(data); | 200 | 139k | return f; | 201 | 139k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE3EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 489k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 489k | auto f = Field(T); | 199 | 489k | f.template create_concrete<T>(data); | 200 | 489k | return f; | 201 | 489k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE4EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 74.9k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 74.9k | auto f = Field(T); | 199 | 74.9k | f.template create_concrete<T>(data); | 200 | 74.9k | return f; | 201 | 74.9k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE6EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 3.12M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 3.12M | auto f = Field(T); | 199 | 3.12M | f.template create_concrete<T>(data); | 200 | 3.12M | return f; | 201 | 3.12M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE7EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 42.4k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 42.4k | auto f = Field(T); | 199 | 42.4k | f.template create_concrete<T>(data); | 200 | 42.4k | return f; | 201 | 42.4k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE8EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 49.7k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 49.7k | auto f = Field(T); | 199 | 49.7k | f.template create_concrete<T>(data); | 200 | 49.7k | return f; | 201 | 49.7k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE9EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 149k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 149k | auto f = Field(T); | 199 | 149k | f.template create_concrete<T>(data); | 200 | 149k | return f; | 201 | 149k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE36EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 37.9k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 37.9k | auto f = Field(T); | 199 | 37.9k | f.template create_concrete<T>(data); | 200 | 37.9k | return f; | 201 | 37.9k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE11EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 27.2k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 27.2k | auto f = Field(T); | 199 | 27.2k | f.template create_concrete<T>(data); | 200 | 27.2k | return f; | 201 | 27.2k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE25EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 628k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 628k | auto f = Field(T); | 199 | 628k | f.template create_concrete<T>(data); | 200 | 628k | return f; | 201 | 628k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE12EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 14.8k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 14.8k | auto f = Field(T); | 199 | 14.8k | f.template create_concrete<T>(data); | 200 | 14.8k | return f; | 201 | 14.8k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE26EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 116k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 116k | auto f = Field(T); | 199 | 116k | f.template create_concrete<T>(data); | 200 | 116k | return f; | 201 | 116k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE27EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 128 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 128 | auto f = Field(T); | 199 | 128 | f.template create_concrete<T>(data); | 200 | 128 | return f; | 201 | 128 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE42EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 16.6k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 16.6k | auto f = Field(T); | 199 | 16.6k | f.template create_concrete<T>(data); | 200 | 16.6k | return f; | 201 | 16.6k | } |
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 | 115k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 115k | auto f = Field(T); | 199 | 115k | f.template create_concrete<T>(data); | 200 | 115k | return f; | 201 | 115k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE28EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 25.3k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 25.3k | auto f = Field(T); | 199 | 25.3k | f.template create_concrete<T>(data); | 200 | 25.3k | return f; | 201 | 25.3k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE29EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 181k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 181k | auto f = Field(T); | 199 | 181k | f.template create_concrete<T>(data); | 200 | 181k | return f; | 201 | 181k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE20EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 8.83k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 8.83k | auto f = Field(T); | 199 | 8.83k | f.template create_concrete<T>(data); | 200 | 8.83k | return f; | 201 | 8.83k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE30EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 33.8k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 33.8k | auto f = Field(T); | 199 | 33.8k | f.template create_concrete<T>(data); | 200 | 33.8k | return f; | 201 | 33.8k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE35EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 40.9k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 40.9k | auto f = Field(T); | 199 | 40.9k | f.template create_concrete<T>(data); | 200 | 40.9k | return f; | 201 | 40.9k | } |
_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 | 404 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 404 | auto f = Field(T); | 199 | 404 | f.template create_concrete<T>(data); | 200 | 404 | return f; | 201 | 404 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE10EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 598k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 598k | auto f = Field(T); | 199 | 598k | f.template create_concrete<T>(data); | 200 | 598k | return f; | 201 | 598k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE31EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 1.44k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 1.44k | auto f = Field(T); | 199 | 1.44k | f.template create_concrete<T>(data); | 200 | 1.44k | return f; | 201 | 1.44k | } |
|
202 | | template <PrimitiveType T> |
203 | 97.2M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { |
204 | 97.2M | auto f = Field(T); |
205 | 97.2M | f.template create_concrete<T>(std::move(data)); |
206 | 97.2M | return f; |
207 | 97.2M | } _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE23EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 15.6M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 15.6M | auto f = Field(T); | 205 | 15.6M | f.template create_concrete<T>(std::move(data)); | 206 | 15.6M | return f; | 207 | 15.6M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE15EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 56.7k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 56.7k | auto f = Field(T); | 205 | 56.7k | f.template create_concrete<T>(std::move(data)); | 206 | 56.7k | return f; | 207 | 56.7k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE28EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 45.5k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 45.5k | auto f = Field(T); | 205 | 45.5k | f.template create_concrete<T>(std::move(data)); | 206 | 45.5k | return f; | 207 | 45.5k | } |
_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.4k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 10.4k | auto f = Field(T); | 205 | 10.4k | f.template create_concrete<T>(std::move(data)); | 206 | 10.4k | return f; | 207 | 10.4k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE35EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 10.8k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 10.8k | auto f = Field(T); | 205 | 10.8k | f.template create_concrete<T>(std::move(data)); | 206 | 10.8k | return f; | 207 | 10.8k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE30EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 152k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 152k | auto f = Field(T); | 205 | 152k | f.template create_concrete<T>(std::move(data)); | 206 | 152k | return f; | 207 | 152k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE1EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 61.3k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 61.3k | auto f = Field(T); | 205 | 61.3k | f.template create_concrete<T>(std::move(data)); | 206 | 61.3k | return f; | 207 | 61.3k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE31EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.55M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.55M | auto f = Field(T); | 205 | 2.55M | f.template create_concrete<T>(std::move(data)); | 206 | 2.55M | return f; | 207 | 2.55M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE2EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 28.6M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 28.6M | auto f = Field(T); | 205 | 28.6M | f.template create_concrete<T>(std::move(data)); | 206 | 28.6M | return f; | 207 | 28.6M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE3EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 7.05M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 7.05M | auto f = Field(T); | 205 | 7.05M | f.template create_concrete<T>(std::move(data)); | 206 | 7.05M | return f; | 207 | 7.05M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE4EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 94.5k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 94.5k | auto f = Field(T); | 205 | 94.5k | f.template create_concrete<T>(std::move(data)); | 206 | 94.5k | return f; | 207 | 94.5k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE5EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 1.75M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 1.75M | auto f = Field(T); | 205 | 1.75M | f.template create_concrete<T>(std::move(data)); | 206 | 1.75M | return f; | 207 | 1.75M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE6EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 20.4M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 20.4M | auto f = Field(T); | 205 | 20.4M | f.template create_concrete<T>(std::move(data)); | 206 | 20.4M | return f; | 207 | 20.4M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE7EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 125k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 125k | auto f = Field(T); | 205 | 125k | f.template create_concrete<T>(std::move(data)); | 206 | 125k | return f; | 207 | 125k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE8EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 50.5k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 50.5k | auto f = Field(T); | 205 | 50.5k | f.template create_concrete<T>(std::move(data)); | 206 | 50.5k | return f; | 207 | 50.5k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE9EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.94M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.94M | auto f = Field(T); | 205 | 2.94M | f.template create_concrete<T>(std::move(data)); | 206 | 2.94M | return f; | 207 | 2.94M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE11EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 4.30k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 4.30k | auto f = Field(T); | 205 | 4.30k | f.template create_concrete<T>(std::move(data)); | 206 | 4.30k | return f; | 207 | 4.30k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE25EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 217k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 217k | auto f = Field(T); | 205 | 217k | f.template create_concrete<T>(std::move(data)); | 206 | 217k | return f; | 207 | 217k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE12EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 3.70k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 3.70k | auto f = Field(T); | 205 | 3.70k | f.template create_concrete<T>(std::move(data)); | 206 | 3.70k | return f; | 207 | 3.70k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE26EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 258k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 258k | auto f = Field(T); | 205 | 258k | f.template create_concrete<T>(std::move(data)); | 206 | 258k | return f; | 207 | 258k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE36EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 5.06k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 5.06k | auto f = Field(T); | 205 | 5.06k | f.template create_concrete<T>(std::move(data)); | 206 | 5.06k | return f; | 207 | 5.06k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE37EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.65k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.65k | auto f = Field(T); | 205 | 2.65k | f.template create_concrete<T>(std::move(data)); | 206 | 2.65k | return f; | 207 | 2.65k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE27EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 3 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 3 | auto f = Field(T); | 205 | 3 | f.template create_concrete<T>(std::move(data)); | 206 | 3 | return f; | 207 | 3 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE42EEES0_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_13PrimitiveTypeE17EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.39M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.39M | auto f = Field(T); | 205 | 2.39M | f.template create_concrete<T>(std::move(data)); | 206 | 2.39M | return f; | 207 | 2.39M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE41EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 50 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 50 | auto f = Field(T); | 205 | 50 | f.template create_concrete<T>(std::move(data)); | 206 | 50 | return f; | 207 | 50 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE22EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 62 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 62 | auto f = Field(T); | 205 | 62 | f.template create_concrete<T>(std::move(data)); | 206 | 62 | return f; | 207 | 62 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE24EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 10 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 10 | auto f = Field(T); | 205 | 10 | f.template create_concrete<T>(std::move(data)); | 206 | 10 | return f; | 207 | 10 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE19EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 10 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 10 | auto f = Field(T); | 205 | 10 | f.template create_concrete<T>(std::move(data)); | 206 | 10 | return f; | 207 | 10 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE18EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 20.2k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 20.2k | auto f = Field(T); | 205 | 20.2k | f.template create_concrete<T>(std::move(data)); | 206 | 20.2k | return f; | 207 | 20.2k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE16EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 5.95k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 5.95k | auto f = Field(T); | 205 | 5.95k | f.template create_concrete<T>(std::move(data)); | 206 | 5.95k | return f; | 207 | 5.95k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE32EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 127k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 127k | auto f = Field(T); | 205 | 127k | f.template create_concrete<T>(std::move(data)); | 206 | 127k | return f; | 207 | 127k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE10EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 861k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 861k | auto f = Field(T); | 205 | 861k | f.template create_concrete<T>(std::move(data)); | 206 | 861k | return f; | 207 | 861k | } |
|
208 | | |
209 | | template <PrimitiveType PType, typename ValType = std::conditional_t< |
210 | | doris::is_string_type(PType), StringRef, |
211 | | typename PrimitiveTypeTraits<PType>::StorageFieldType>> |
212 | 1.49M | static Field create_field_from_olap_value(const ValType& data) { |
213 | 1.49M | auto f = Field(PType); |
214 | 1.49M | typename PrimitiveTypeTraits<PType>::CppType cpp_value; |
215 | 1.49M | if constexpr (is_string_type(PType)) { |
216 | 492k | cpp_value = String(data.data, data.size); |
217 | 492k | } else if constexpr (is_date_or_datetime(PType)) { |
218 | 1.07k | if constexpr (PType == TYPE_DATE) { |
219 | 391 | cpp_value.from_olap_date(data); |
220 | 681 | } else { |
221 | 681 | cpp_value.from_olap_datetime(data); |
222 | 681 | } |
223 | 1.07k | } else if constexpr (is_decimalv2(PType)) { |
224 | 150 | cpp_value = DecimalV2Value(data.integer, data.fraction); |
225 | 1.00M | } else { |
226 | 1.00M | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); |
227 | 1.00M | } |
228 | 1.49M | f.template create_concrete<PType>(std::move(cpp_value)); |
229 | 1.49M | return f; |
230 | 1.49M | } _ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE3EaEES0_RKT0_ Line | Count | Source | 212 | 82.0k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 82.0k | auto f = Field(PType); | 214 | 82.0k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 82.0k | } else { | 226 | 82.0k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 82.0k | } | 228 | 82.0k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 82.0k | return f; | 230 | 82.0k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE4EsEES0_RKT0_ Line | Count | Source | 212 | 23.5k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 23.5k | auto f = Field(PType); | 214 | 23.5k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 23.5k | } else { | 226 | 23.5k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 23.5k | } | 228 | 23.5k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 23.5k | return f; | 230 | 23.5k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE5EiEES0_RKT0_ Line | Count | Source | 212 | 192k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 192k | auto f = Field(PType); | 214 | 192k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 192k | } else { | 226 | 192k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 192k | } | 228 | 192k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 192k | return f; | 230 | 192k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE6ElEES0_RKT0_ Line | Count | Source | 212 | 426k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 426k | auto f = Field(PType); | 214 | 426k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 426k | } else { | 226 | 426k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 426k | } | 228 | 426k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 426k | return f; | 230 | 426k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE7EnEES0_RKT0_ Line | Count | Source | 212 | 32.7k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 32.7k | auto f = Field(PType); | 214 | 32.7k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 32.7k | } else { | 226 | 32.7k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 32.7k | } | 228 | 32.7k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 32.7k | return f; | 230 | 32.7k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE8EfEES0_RKT0_ Line | Count | Source | 212 | 14.1k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 14.1k | auto f = Field(PType); | 214 | 14.1k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 14.1k | } else { | 226 | 14.1k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 14.1k | } | 228 | 14.1k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 14.1k | return f; | 230 | 14.1k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE9EdEES0_RKT0_ Line | Count | Source | 212 | 20.0k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 20.0k | auto f = Field(PType); | 214 | 20.0k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 20.0k | } else { | 226 | 20.0k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 20.0k | } | 228 | 20.0k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 20.0k | return f; | 230 | 20.0k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE15ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 34.6k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 34.6k | auto f = Field(PType); | 214 | 34.6k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 34.6k | if constexpr (is_string_type(PType)) { | 216 | 34.6k | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | | } else { | 226 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | | } | 228 | 34.6k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 34.6k | return f; | 230 | 34.6k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE11ENS_8uint24_tEEES0_RKT0_ Line | Count | Source | 212 | 391 | static Field create_field_from_olap_value(const ValType& data) { | 213 | 391 | auto f = Field(PType); | 214 | 391 | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | 391 | } else if constexpr (is_date_or_datetime(PType)) { | 218 | 391 | if constexpr (PType == TYPE_DATE) { | 219 | 391 | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | | } else { | 226 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | | } | 228 | 391 | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 391 | return f; | 230 | 391 | } |
_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 | | cpp_value = String(data.data, data.size); | 217 | 681 | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | 681 | } else { | 221 | 681 | cpp_value.from_olap_datetime(data); | 222 | 681 | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | | } else { | 226 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | | } | 228 | 681 | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 681 | return f; | 230 | 681 | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE25EjEES0_RKT0_ Line | Count | Source | 212 | 60.6k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 60.6k | auto f = Field(PType); | 214 | 60.6k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 60.6k | } else { | 226 | 60.6k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 60.6k | } | 228 | 60.6k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 60.6k | return f; | 230 | 60.6k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE26EmEES0_RKT0_ Line | Count | Source | 212 | 68.6k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 68.6k | auto f = Field(PType); | 214 | 68.6k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 68.6k | } else { | 226 | 68.6k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 68.6k | } | 228 | 68.6k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 68.6k | return f; | 230 | 68.6k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE42EmEES0_RKT0_ Line | Count | Source | 212 | 6.48k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 6.48k | auto f = Field(PType); | 214 | 6.48k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 6.48k | } else { | 226 | 6.48k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 6.48k | } | 228 | 6.48k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 6.48k | return f; | 230 | 6.48k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE36EjEES0_RKT0_ Line | Count | Source | 212 | 1.16k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 1.16k | auto f = Field(PType); | 214 | 1.16k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 1.16k | } else { | 226 | 1.16k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 1.16k | } | 228 | 1.16k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 1.16k | return f; | 230 | 1.16k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE37EoEES0_RKT0_ Line | Count | Source | 212 | 1.01k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 1.01k | auto f = Field(PType); | 214 | 1.01k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 1.01k | } else { | 226 | 1.01k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 1.01k | } | 228 | 1.01k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 1.01k | return f; | 230 | 1.01k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE10ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 309k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 309k | auto f = Field(PType); | 214 | 309k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 309k | if constexpr (is_string_type(PType)) { | 216 | 309k | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | | } else { | 226 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | | } | 228 | 309k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 309k | return f; | 230 | 309k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE23ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 148k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 148k | auto f = Field(PType); | 214 | 148k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 148k | if constexpr (is_string_type(PType)) { | 216 | 148k | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | | } else { | 226 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | | } | 228 | 148k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 148k | return f; | 230 | 148k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE28EiEES0_RKT0_ Line | Count | Source | 212 | 6.85k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 6.85k | auto f = Field(PType); | 214 | 6.85k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 6.85k | } else { | 226 | 6.85k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 6.85k | } | 228 | 6.85k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 6.85k | return f; | 230 | 6.85k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE29ElEES0_RKT0_ Line | Count | Source | 212 | 31.8k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 31.8k | auto f = Field(PType); | 214 | 31.8k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 31.8k | } else { | 226 | 31.8k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 31.8k | } | 228 | 31.8k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 31.8k | return f; | 230 | 31.8k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE30EnEES0_RKT0_ Line | Count | Source | 212 | 20.8k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 20.8k | auto f = Field(PType); | 214 | 20.8k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 20.8k | } else { | 226 | 20.8k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 20.8k | } | 228 | 20.8k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 20.8k | return f; | 230 | 20.8k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE35EN4wide7integerILm256EiEEEES0_RKT0_ Line | Count | Source | 212 | 1.05k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 1.05k | auto f = Field(PType); | 214 | 1.05k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 1.05k | } else { | 226 | 1.05k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 1.05k | } | 228 | 1.05k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 1.05k | return f; | 230 | 1.05k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE20ENS_11decimal12_tEEES0_RKT0_ Line | Count | Source | 212 | 150 | static Field create_field_from_olap_value(const ValType& data) { | 213 | 150 | auto f = Field(PType); | 214 | 150 | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | 150 | } else if constexpr (is_decimalv2(PType)) { | 224 | 150 | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | | } else { | 226 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | | } | 228 | 150 | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 150 | return f; | 230 | 150 | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE2EhEES0_RKT0_ Line | Count | Source | 212 | 16.0k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 16.0k | auto f = Field(PType); | 214 | 16.0k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | | } else { | 221 | | cpp_value.from_olap_datetime(data); | 222 | | } | 223 | | } else if constexpr (is_decimalv2(PType)) { | 224 | | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | 16.0k | } else { | 226 | 16.0k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 16.0k | } | 228 | 16.0k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 16.0k | return f; | 230 | 16.0k | } |
|
231 | | |
232 | | /** Despite the presence of a template constructor, this constructor is still needed, |
233 | | * since, in its absence, the compiler will still generate the default constructor. |
234 | | */ |
235 | | Field(const Field& rhs); |
236 | | |
237 | | Field(Field&& rhs); |
238 | | |
239 | | Field& operator=(const Field& rhs); |
240 | | |
241 | 22.5M | bool is_complex_field() const { |
242 | 22.5M | return type == PrimitiveType::TYPE_ARRAY || type == PrimitiveType::TYPE_MAP || |
243 | 22.5M | type == PrimitiveType::TYPE_STRUCT || type == PrimitiveType::TYPE_VARIANT; |
244 | 22.5M | } |
245 | | |
246 | 81.6M | Field& operator=(Field&& rhs) { |
247 | 81.6M | if (this != &rhs) { |
248 | 81.5M | if (type != rhs.type) { |
249 | 44.9M | destroy(); |
250 | 44.9M | create(std::move(rhs)); |
251 | 44.9M | } else { |
252 | 36.6M | assign(std::move(rhs)); |
253 | 36.6M | } |
254 | 81.5M | } |
255 | 81.6M | return *this; |
256 | 81.6M | } |
257 | | |
258 | 521M | ~Field() { destroy(); } |
259 | | |
260 | 145M | PrimitiveType get_type() const { return type; } |
261 | | std::string get_type_name() const; |
262 | | |
263 | 186M | bool is_null() const { return type == PrimitiveType::TYPE_NULL; } |
264 | | |
265 | | // The template parameter T needs to be consistent with `which`. |
266 | | // If not, use NearestFieldType<> externally. |
267 | | // Maybe modify this in the future, reference: https://github.com/ClickHouse/ClickHouse/pull/22003 |
268 | | template <PrimitiveType T> |
269 | | typename PrimitiveTypeTraits<T>::CppType& get(); |
270 | | |
271 | | template <PrimitiveType T> |
272 | | const typename PrimitiveTypeTraits<T>::CppType& get() const; |
273 | | |
274 | 9.89M | bool operator==(const Field& rhs) const { |
275 | 9.89M | return operator<=>(rhs) == std::strong_ordering::equal; |
276 | 9.89M | } |
277 | | |
278 | | std::strong_ordering operator<=>(const Field& rhs) const; |
279 | | |
280 | | std::string_view as_string_view() const; |
281 | | |
282 | | // Return a human-readable representation of the stored value for debugging. |
283 | | // Unlike get_type_name() which returns the type, this prints the actual value. |
284 | | // For decimal types, caller can provide scale for accurate formatting. |
285 | | std::string to_debug_string(int scale) const; |
286 | | |
287 | | private: |
288 | | std::aligned_union_t<DBMS_MIN_FIELD_SIZE - sizeof(PrimitiveType), Null, UInt64, UInt128, Int64, |
289 | | Int128, IPv6, Float64, String, JsonbField, StringView, Array, Tuple, Map, |
290 | | VariantMap, Decimal32, Decimal64, DecimalV2Value, Decimal128V3, Decimal256, |
291 | | BitmapValue, HyperLogLog, QuantileState> |
292 | | storage; |
293 | | |
294 | | PrimitiveType type; |
295 | | |
296 | | /// Assuming there was no allocated state or it was deallocated (see destroy). |
297 | | template <PrimitiveType Type> |
298 | | void create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x); |
299 | | template <PrimitiveType Type> |
300 | | void create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x); |
301 | | /// Assuming same types. |
302 | | template <PrimitiveType Type> |
303 | | void assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x); |
304 | | template <PrimitiveType Type> |
305 | | void assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x); |
306 | | |
307 | | void create(const Field& field); |
308 | | void create(Field&& field); |
309 | | |
310 | | void assign(const Field& x); |
311 | | void assign(Field&& x); |
312 | | |
313 | | void destroy(); |
314 | | |
315 | | template <PrimitiveType T> |
316 | | void destroy(); |
317 | | }; |
318 | | |
319 | | struct FieldWithDataType { |
320 | | Field field; |
321 | | // used for nested type of array |
322 | | PrimitiveType base_scalar_type_id = PrimitiveType::INVALID_TYPE; |
323 | | uint8_t num_dimensions = 0; |
324 | | int precision = -1; |
325 | | int scale = -1; |
326 | | }; |
327 | | |
328 | | } // namespace doris |
329 | | |
330 | | template <> |
331 | | struct std::hash<doris::Field> { |
332 | 1.50k | size_t operator()(const doris::Field& field) const { |
333 | 1.50k | if (field.is_null()) { |
334 | 158 | return 0; |
335 | 158 | } |
336 | 1.34k | std::hash<std::string_view> hasher; |
337 | 1.34k | return hasher(field.as_string_view()); |
338 | 1.50k | } |
339 | | }; |