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 Struct 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 Struct 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 Struct : 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.5M | ~JsonbField() = default; // unique_ptr will handle cleanup automatically |
88 | | |
89 | 2.20M | JsonbField(const char* ptr, size_t len) : size(len) { |
90 | 2.20M | data = std::make_unique<char[]>(size); |
91 | 2.20M | if (!data) { |
92 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", size)); |
93 | 0 | } |
94 | 2.20M | if (size > 0) { |
95 | 2.18M | memcpy(data.get(), ptr, size); |
96 | 2.18M | } |
97 | 2.20M | } |
98 | | |
99 | 2.28M | JsonbField(const JsonbField& x) : size(x.size) { |
100 | 2.28M | data = std::make_unique<char[]>(size); |
101 | 2.28M | if (!data) { |
102 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", size)); |
103 | 0 | } |
104 | 2.28M | if (size > 0) { |
105 | 2.27M | memcpy(data.get(), x.data.get(), size); |
106 | 2.27M | } |
107 | 2.28M | } |
108 | | |
109 | 5.89M | 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 | 25 | JsonbField& operator=(const JsonbField& x) { |
113 | 25 | if (this != &x) { |
114 | 25 | data = std::make_unique<char[]>(x.size); |
115 | 25 | if (!data) { |
116 | 0 | throw Exception(Status::FatalError("new data buffer failed, size: {}", x.size)); |
117 | 0 | } |
118 | 25 | if (x.size > 0) { |
119 | 24 | memcpy(data.get(), x.data.get(), x.size); |
120 | 24 | } |
121 | 25 | size = x.size; |
122 | 25 | } |
123 | 25 | return *this; |
124 | 25 | } |
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.72M | const char* get_value() const { return data.get(); } |
136 | 1.76M | 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 | 123M | Field() : type(PrimitiveType::TYPE_NULL) {} |
194 | | // set Types::Null explictly and avoid other types |
195 | 165M | Field(PrimitiveType w) : type(w) {} |
196 | | template <PrimitiveType T> |
197 | 46.1M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { |
198 | 46.1M | auto f = Field(T); |
199 | 46.1M | f.template create_concrete<T>(data); |
200 | 46.1M | return f; |
201 | 46.1M | } _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE23EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 19.8M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 19.8M | auto f = Field(T); | 199 | 19.8M | f.template create_concrete<T>(data); | 200 | 19.8M | return f; | 201 | 19.8M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE37EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 28.1k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 28.1k | auto f = Field(T); | 199 | 28.1k | f.template create_concrete<T>(data); | 200 | 28.1k | return f; | 201 | 28.1k | } |
_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 | 20.1M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 20.1M | auto f = Field(T); | 199 | 20.1M | f.template create_concrete<T>(data); | 200 | 20.1M | return f; | 201 | 20.1M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE15EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 216 | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 216 | auto f = Field(T); | 199 | 216 | f.template create_concrete<T>(data); | 200 | 216 | return f; | 201 | 216 | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE2EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 90.7k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 90.7k | auto f = Field(T); | 199 | 90.7k | f.template create_concrete<T>(data); | 200 | 90.7k | return f; | 201 | 90.7k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE3EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 481k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 481k | auto f = Field(T); | 199 | 481k | f.template create_concrete<T>(data); | 200 | 481k | return f; | 201 | 481k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE4EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 72.7k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 72.7k | auto f = Field(T); | 199 | 72.7k | f.template create_concrete<T>(data); | 200 | 72.7k | return f; | 201 | 72.7k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE6EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 2.73M | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 2.73M | auto f = Field(T); | 199 | 2.73M | f.template create_concrete<T>(data); | 200 | 2.73M | return f; | 201 | 2.73M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE7EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 42.3k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 42.3k | auto f = Field(T); | 199 | 42.3k | f.template create_concrete<T>(data); | 200 | 42.3k | return f; | 201 | 42.3k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE8EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 49.6k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 49.6k | auto f = Field(T); | 199 | 49.6k | f.template create_concrete<T>(data); | 200 | 49.6k | return f; | 201 | 49.6k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE9EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 418k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 418k | auto f = Field(T); | 199 | 418k | f.template create_concrete<T>(data); | 200 | 418k | return f; | 201 | 418k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE36EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 38.0k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 38.0k | auto f = Field(T); | 199 | 38.0k | f.template create_concrete<T>(data); | 200 | 38.0k | return f; | 201 | 38.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE11EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 19.0k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 19.0k | auto f = Field(T); | 199 | 19.0k | f.template create_concrete<T>(data); | 200 | 19.0k | return f; | 201 | 19.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE25EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 614k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 614k | auto f = Field(T); | 199 | 614k | f.template create_concrete<T>(data); | 200 | 614k | return f; | 201 | 614k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE12EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 15.0k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 15.0k | auto f = Field(T); | 199 | 15.0k | f.template create_concrete<T>(data); | 200 | 15.0k | return f; | 201 | 15.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE26EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 112k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 112k | auto f = Field(T); | 199 | 112k | f.template create_concrete<T>(data); | 200 | 112k | return f; | 201 | 112k | } |
_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 | 17.5k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 17.5k | auto f = Field(T); | 199 | 17.5k | f.template create_concrete<T>(data); | 200 | 17.5k | return f; | 201 | 17.5k | } |
Unexecuted instantiation: _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE38EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Unexecuted instantiation: _ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE39EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE _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 | 178k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 178k | auto f = Field(T); | 199 | 178k | f.template create_concrete<T>(data); | 200 | 178k | return f; | 201 | 178k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE20EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 8.86k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 8.86k | auto f = Field(T); | 199 | 8.86k | f.template create_concrete<T>(data); | 200 | 8.86k | return f; | 201 | 8.86k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE30EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 33.5k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 33.5k | auto f = Field(T); | 199 | 33.5k | f.template create_concrete<T>(data); | 200 | 33.5k | return f; | 201 | 33.5k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE35EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 41.0k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 41.0k | auto f = Field(T); | 199 | 41.0k | f.template create_concrete<T>(data); | 200 | 41.0k | return f; | 201 | 41.0k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE17EEES0_RKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 197 | 483k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 483k | auto f = Field(T); | 199 | 483k | f.template create_concrete<T>(data); | 200 | 483k | return f; | 201 | 483k | } |
_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 | 595k | static Field create_field(const typename PrimitiveTypeTraits<T>::CppType& data) { | 198 | 595k | auto f = Field(T); | 199 | 595k | f.template create_concrete<T>(data); | 200 | 595k | return f; | 201 | 595k | } |
_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 | 107M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { |
204 | 107M | auto f = Field(T); |
205 | 107M | f.template create_concrete<T>(std::move(data)); |
206 | 107M | return f; |
207 | 107M | } _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_13PrimitiveTypeE15EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 56.2k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 56.2k | auto f = Field(T); | 205 | 56.2k | f.template create_concrete<T>(std::move(data)); | 206 | 56.2k | return f; | 207 | 56.2k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE28EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 54.7k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 54.7k | auto f = Field(T); | 205 | 54.7k | f.template create_concrete<T>(std::move(data)); | 206 | 54.7k | return f; | 207 | 54.7k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE29EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 13.6M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 13.6M | auto f = Field(T); | 205 | 13.6M | f.template create_concrete<T>(std::move(data)); | 206 | 13.6M | return f; | 207 | 13.6M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE20EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 10.6k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 10.6k | auto f = Field(T); | 205 | 10.6k | f.template create_concrete<T>(std::move(data)); | 206 | 10.6k | return f; | 207 | 10.6k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE35EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 11.5k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 11.5k | auto f = Field(T); | 205 | 11.5k | f.template create_concrete<T>(std::move(data)); | 206 | 11.5k | return f; | 207 | 11.5k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE30EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 98.1k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 98.1k | auto f = Field(T); | 205 | 98.1k | f.template create_concrete<T>(std::move(data)); | 206 | 98.1k | return f; | 207 | 98.1k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE1EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 65.8k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 65.8k | auto f = Field(T); | 205 | 65.8k | f.template create_concrete<T>(std::move(data)); | 206 | 65.8k | return f; | 207 | 65.8k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE31EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.40M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.40M | auto f = Field(T); | 205 | 2.40M | f.template create_concrete<T>(std::move(data)); | 206 | 2.40M | return f; | 207 | 2.40M | } |
_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 | 7.12M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 7.12M | auto f = Field(T); | 205 | 7.12M | f.template create_concrete<T>(std::move(data)); | 206 | 7.12M | return f; | 207 | 7.12M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE4EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 104k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 104k | auto f = Field(T); | 205 | 104k | f.template create_concrete<T>(std::move(data)); | 206 | 104k | return f; | 207 | 104k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE5EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 1.84M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 1.84M | auto f = Field(T); | 205 | 1.84M | f.template create_concrete<T>(std::move(data)); | 206 | 1.84M | return f; | 207 | 1.84M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE6EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 29.1M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 29.1M | auto f = Field(T); | 205 | 29.1M | f.template create_concrete<T>(std::move(data)); | 206 | 29.1M | return f; | 207 | 29.1M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE7EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 139k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 139k | auto f = Field(T); | 205 | 139k | f.template create_concrete<T>(std::move(data)); | 206 | 139k | return f; | 207 | 139k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE8EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 60.0k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 60.0k | auto f = Field(T); | 205 | 60.0k | f.template create_concrete<T>(std::move(data)); | 206 | 60.0k | return f; | 207 | 60.0k | } |
_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_13PrimitiveTypeE11EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 12.5k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 12.5k | auto f = Field(T); | 205 | 12.5k | f.template create_concrete<T>(std::move(data)); | 206 | 12.5k | return f; | 207 | 12.5k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE25EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 250k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 250k | auto f = Field(T); | 205 | 250k | f.template create_concrete<T>(std::move(data)); | 206 | 250k | return f; | 207 | 250k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE12EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 13.7k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 13.7k | auto f = Field(T); | 205 | 13.7k | f.template create_concrete<T>(std::move(data)); | 206 | 13.7k | return f; | 207 | 13.7k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE26EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.44M | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.44M | auto f = Field(T); | 205 | 2.44M | f.template create_concrete<T>(std::move(data)); | 206 | 2.44M | return f; | 207 | 2.44M | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE36EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 5.28k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 5.28k | auto f = Field(T); | 205 | 5.28k | f.template create_concrete<T>(std::move(data)); | 206 | 5.28k | return f; | 207 | 5.28k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE37EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 2.86k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 2.86k | auto f = Field(T); | 205 | 2.86k | f.template create_concrete<T>(std::move(data)); | 206 | 2.86k | return f; | 207 | 2.86k | } |
_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 | 32.2k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 32.2k | auto f = Field(T); | 205 | 32.2k | f.template create_concrete<T>(std::move(data)); | 206 | 32.2k | return f; | 207 | 32.2k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE17EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 907k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 907k | auto f = Field(T); | 205 | 907k | f.template create_concrete<T>(std::move(data)); | 206 | 907k | return f; | 207 | 907k | } |
_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 | 60 | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 60 | auto f = Field(T); | 205 | 60 | f.template create_concrete<T>(std::move(data)); | 206 | 60 | return f; | 207 | 60 | } |
_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 | 24.2k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 24.2k | auto f = Field(T); | 205 | 24.2k | f.template create_concrete<T>(std::move(data)); | 206 | 24.2k | return f; | 207 | 24.2k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE16EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 5.93k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 5.93k | auto f = Field(T); | 205 | 5.93k | f.template create_concrete<T>(std::move(data)); | 206 | 5.93k | return f; | 207 | 5.93k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE32EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 397k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 397k | auto f = Field(T); | 205 | 397k | f.template create_concrete<T>(std::move(data)); | 206 | 397k | return f; | 207 | 397k | } |
_ZN5doris5Field12create_fieldILNS_13PrimitiveTypeE10EEES0_ONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE Line | Count | Source | 203 | 851k | static Field create_field(typename PrimitiveTypeTraits<T>::CppType&& data) { | 204 | 851k | auto f = Field(T); | 205 | 851k | f.template create_concrete<T>(std::move(data)); | 206 | 851k | return f; | 207 | 851k | } |
|
208 | | |
209 | | template <PrimitiveType PType, typename ValType = std::conditional_t< |
210 | | doris::is_string_type(PType), StringRef, |
211 | | typename PrimitiveTypeTraits<PType>::StorageFieldType>> |
212 | 1.47M | static Field create_field_from_olap_value(const ValType& data) { |
213 | 1.47M | auto f = Field(PType); |
214 | 1.47M | typename PrimitiveTypeTraits<PType>::CppType cpp_value; |
215 | 1.47M | if constexpr (is_string_type(PType)) { |
216 | 477k | cpp_value = String(data.data, data.size); |
217 | 477k | } else if constexpr (is_date_or_datetime(PType)) { |
218 | 1.09k | if constexpr (PType == TYPE_DATE) { |
219 | 405 | cpp_value.from_olap_date(data); |
220 | 691 | } else { |
221 | 691 | cpp_value.from_olap_datetime(data); |
222 | 691 | } |
223 | 1.09k | } else if constexpr (is_decimalv2(PType)) { |
224 | 155 | 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.47M | f.template create_concrete<PType>(std::move(cpp_value)); |
229 | 1.47M | return f; |
230 | 1.47M | } _ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE3EaEES0_RKT0_ Line | Count | Source | 212 | 81.4k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 81.4k | auto f = Field(PType); | 214 | 81.4k | 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 | 81.4k | } else { | 226 | 81.4k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 81.4k | } | 228 | 81.4k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 81.4k | return f; | 230 | 81.4k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE4EsEES0_RKT0_ Line | Count | Source | 212 | 23.4k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 23.4k | auto f = Field(PType); | 214 | 23.4k | 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.4k | } else { | 226 | 23.4k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 23.4k | } | 228 | 23.4k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 23.4k | return f; | 230 | 23.4k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE5EiEES0_RKT0_ Line | Count | Source | 212 | 193k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 193k | auto f = Field(PType); | 214 | 193k | 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 | 193k | } else { | 226 | 193k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 193k | } | 228 | 193k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 193k | return f; | 230 | 193k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE6ElEES0_RKT0_ Line | Count | Source | 212 | 422k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 422k | auto f = Field(PType); | 214 | 422k | 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 | 422k | } else { | 226 | 422k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 422k | } | 228 | 422k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 422k | return f; | 230 | 422k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE7EnEES0_RKT0_ Line | Count | Source | 212 | 32.4k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 32.4k | auto f = Field(PType); | 214 | 32.4k | 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.4k | } else { | 226 | 32.4k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 32.4k | } | 228 | 32.4k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 32.4k | return f; | 230 | 32.4k | } |
_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 | 19.5k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 19.5k | auto f = Field(PType); | 214 | 19.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 | 19.5k | } else { | 226 | 19.5k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 19.5k | } | 228 | 19.5k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 19.5k | return f; | 230 | 19.5k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE15ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 35.2k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 35.2k | auto f = Field(PType); | 214 | 35.2k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 35.2k | if constexpr (is_string_type(PType)) { | 216 | 35.2k | 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 | 35.2k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 35.2k | return f; | 230 | 35.2k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE11ENS_8uint24_tEEES0_RKT0_ Line | Count | Source | 212 | 405 | static Field create_field_from_olap_value(const ValType& data) { | 213 | 405 | auto f = Field(PType); | 214 | 405 | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | 405 | } else if constexpr (is_date_or_datetime(PType)) { | 218 | 405 | if constexpr (PType == TYPE_DATE) { | 219 | 405 | 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 | 405 | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 405 | return f; | 230 | 405 | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE12EmEES0_RKT0_ Line | Count | Source | 212 | 691 | static Field create_field_from_olap_value(const ValType& data) { | 213 | 691 | auto f = Field(PType); | 214 | 691 | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | | if constexpr (is_string_type(PType)) { | 216 | | cpp_value = String(data.data, data.size); | 217 | 691 | } else if constexpr (is_date_or_datetime(PType)) { | 218 | | if constexpr (PType == TYPE_DATE) { | 219 | | cpp_value.from_olap_date(data); | 220 | 691 | } else { | 221 | 691 | cpp_value.from_olap_datetime(data); | 222 | 691 | } | 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 | 691 | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 691 | return f; | 230 | 691 | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE25EjEES0_RKT0_ Line | Count | Source | 212 | 61.2k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 61.2k | auto f = Field(PType); | 214 | 61.2k | 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 | 61.2k | } else { | 226 | 61.2k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 61.2k | } | 228 | 61.2k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 61.2k | return f; | 230 | 61.2k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE26EmEES0_RKT0_ Line | Count | Source | 212 | 67.9k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 67.9k | auto f = Field(PType); | 214 | 67.9k | 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 | 67.9k | } else { | 226 | 67.9k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 67.9k | } | 228 | 67.9k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 67.9k | return f; | 230 | 67.9k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE42EmEES0_RKT0_ Line | Count | Source | 212 | 6.52k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 6.52k | auto f = Field(PType); | 214 | 6.52k | 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.52k | } else { | 226 | 6.52k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 6.52k | } | 228 | 6.52k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 6.52k | return f; | 230 | 6.52k | } |
_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.00k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 1.00k | auto f = Field(PType); | 214 | 1.00k | 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.00k | } else { | 226 | 1.00k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 1.00k | } | 228 | 1.00k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 1.00k | return f; | 230 | 1.00k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE10ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 306k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 306k | auto f = Field(PType); | 214 | 306k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 306k | if constexpr (is_string_type(PType)) { | 216 | 306k | 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 | 306k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 306k | return f; | 230 | 306k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE23ENS_9StringRefEEES0_RKT0_ Line | Count | Source | 212 | 135k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 135k | auto f = Field(PType); | 214 | 135k | typename PrimitiveTypeTraits<PType>::CppType cpp_value; | 215 | 135k | if constexpr (is_string_type(PType)) { | 216 | 135k | 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 | 135k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 135k | return f; | 230 | 135k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE28EiEES0_RKT0_ Line | Count | Source | 212 | 6.83k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 6.83k | auto f = Field(PType); | 214 | 6.83k | 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.83k | } else { | 226 | 6.83k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 6.83k | } | 228 | 6.83k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 6.83k | return f; | 230 | 6.83k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE29ElEES0_RKT0_ Line | Count | Source | 212 | 32.9k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 32.9k | auto f = Field(PType); | 214 | 32.9k | 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.9k | } else { | 226 | 32.9k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 32.9k | } | 228 | 32.9k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 32.9k | return f; | 230 | 32.9k | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE30EnEES0_RKT0_ Line | Count | Source | 212 | 20.6k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 20.6k | auto f = Field(PType); | 214 | 20.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 | 20.6k | } else { | 226 | 20.6k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 20.6k | } | 228 | 20.6k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 20.6k | return f; | 230 | 20.6k | } |
_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 | 155 | static Field create_field_from_olap_value(const ValType& data) { | 213 | 155 | auto f = Field(PType); | 214 | 155 | 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 | 155 | } else if constexpr (is_decimalv2(PType)) { | 224 | 155 | cpp_value = DecimalV2Value(data.integer, data.fraction); | 225 | | } else { | 226 | | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | | } | 228 | 155 | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 155 | return f; | 230 | 155 | } |
_ZN5doris5Field28create_field_from_olap_valueILNS_13PrimitiveTypeE2EhEES0_RKT0_ Line | Count | Source | 212 | 14.9k | static Field create_field_from_olap_value(const ValType& data) { | 213 | 14.9k | auto f = Field(PType); | 214 | 14.9k | 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.9k | } else { | 226 | 14.9k | cpp_value = typename PrimitiveTypeTraits<PType>::CppType(data); | 227 | 14.9k | } | 228 | 14.9k | f.template create_concrete<PType>(std::move(cpp_value)); | 229 | 14.9k | return f; | 230 | 14.9k | } |
|
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 | 21.0M | bool is_complex_field() const { |
242 | 21.0M | return type == PrimitiveType::TYPE_ARRAY || type == PrimitiveType::TYPE_MAP || |
243 | 21.0M | type == PrimitiveType::TYPE_STRUCT || type == PrimitiveType::TYPE_VARIANT; |
244 | 21.0M | } |
245 | | |
246 | 96.0M | Field& operator=(Field&& rhs) { |
247 | 96.0M | if (this != &rhs) { |
248 | 96.0M | if (type != rhs.type) { |
249 | 72.3M | destroy(); |
250 | 72.3M | create(std::move(rhs)); |
251 | 72.3M | } else { |
252 | 23.6M | assign(std::move(rhs)); |
253 | 23.6M | } |
254 | 96.0M | } |
255 | 96.0M | return *this; |
256 | 96.0M | } |
257 | | |
258 | 566M | ~Field() { destroy(); } |
259 | | |
260 | 126M | PrimitiveType get_type() const { return type; } |
261 | | std::string get_type_name() const; |
262 | | |
263 | 207M | 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 | 10.5M | bool operator==(const Field& rhs) const { |
275 | 10.5M | return operator<=>(rhs) == std::strong_ordering::equal; |
276 | 10.5M | } |
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, Struct, 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 | | }; |