Coverage Report

Created: 2026-03-27 23:51

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/core/field.cpp
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.cpp
19
// and modified by Doris
20
21
#include "core/field.h"
22
23
#include "common/compare.h"
24
#include "core/accurate_comparison.h"
25
#include "core/data_type/data_type_decimal.h"
26
#include "core/data_type/define_primitive_type.h"
27
#include "core/data_type/primitive_type.h"
28
#include "core/decimal_comparison.h"
29
#include "core/value/bitmap_value.h"
30
#include "core/value/jsonb_value.h"
31
#include "core/value/timestamptz_value.h"
32
#include "core/value/vdatetime_value.h"
33
#include "exprs/function/cast/cast_to_string.h"
34
#include "util/io_helper.h"
35
#include "util/var_int.h"
36
37
namespace doris {
38
class BufferReadable;
39
class BufferWritable;
40
41
template <PrimitiveType T>
42
bool dec_equal(typename PrimitiveTypeTraits<T>::CppType x,
43
0
               typename PrimitiveTypeTraits<T>::CppType y, UInt32 x_scale, UInt32 y_scale) {
44
0
    using Comparator = DecimalComparison<T, T, EqualsOp>;
45
0
    return Comparator::compare(x, y, x_scale, y_scale);
46
0
}
Unexecuted instantiation: _ZN5doris9dec_equalILNS_13PrimitiveTypeE28EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Unexecuted instantiation: _ZN5doris9dec_equalILNS_13PrimitiveTypeE29EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Unexecuted instantiation: _ZN5doris9dec_equalILNS_13PrimitiveTypeE20EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Unexecuted instantiation: _ZN5doris9dec_equalILNS_13PrimitiveTypeE35EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Unexecuted instantiation: _ZN5doris9dec_equalILNS_13PrimitiveTypeE30EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
47
48
template <PrimitiveType T>
49
bool dec_less(typename PrimitiveTypeTraits<T>::CppType x,
50
3.48k
              typename PrimitiveTypeTraits<T>::CppType y, UInt32 x_scale, UInt32 y_scale) {
51
3.48k
    using Comparator = DecimalComparison<T, T, LessOp>;
52
3.48k
    return Comparator::compare(x, y, x_scale, y_scale);
53
3.48k
}
_ZN5doris8dec_lessILNS_13PrimitiveTypeE28EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Line
Count
Source
50
10
              typename PrimitiveTypeTraits<T>::CppType y, UInt32 x_scale, UInt32 y_scale) {
51
10
    using Comparator = DecimalComparison<T, T, LessOp>;
52
10
    return Comparator::compare(x, y, x_scale, y_scale);
53
10
}
_ZN5doris8dec_lessILNS_13PrimitiveTypeE29EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Line
Count
Source
50
3
              typename PrimitiveTypeTraits<T>::CppType y, UInt32 x_scale, UInt32 y_scale) {
51
3
    using Comparator = DecimalComparison<T, T, LessOp>;
52
3
    return Comparator::compare(x, y, x_scale, y_scale);
53
3
}
Unexecuted instantiation: _ZN5doris8dec_lessILNS_13PrimitiveTypeE20EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
_ZN5doris8dec_lessILNS_13PrimitiveTypeE35EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Line
Count
Source
50
972
              typename PrimitiveTypeTraits<T>::CppType y, UInt32 x_scale, UInt32 y_scale) {
51
972
    using Comparator = DecimalComparison<T, T, LessOp>;
52
972
    return Comparator::compare(x, y, x_scale, y_scale);
53
972
}
_ZN5doris8dec_lessILNS_13PrimitiveTypeE30EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Line
Count
Source
50
2.50k
              typename PrimitiveTypeTraits<T>::CppType y, UInt32 x_scale, UInt32 y_scale) {
51
2.50k
    using Comparator = DecimalComparison<T, T, LessOp>;
52
2.50k
    return Comparator::compare(x, y, x_scale, y_scale);
53
2.50k
}
54
55
template <PrimitiveType T>
56
bool dec_less_or_equal(typename PrimitiveTypeTraits<T>::CppType x,
57
0
                       typename PrimitiveTypeTraits<T>::CppType y, UInt32 x_scale, UInt32 y_scale) {
58
0
    using Comparator = DecimalComparison<T, T, LessOrEqualsOp>;
59
0
    return Comparator::compare(x, y, x_scale, y_scale);
60
0
}
Unexecuted instantiation: _ZN5doris17dec_less_or_equalILNS_13PrimitiveTypeE28EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Unexecuted instantiation: _ZN5doris17dec_less_or_equalILNS_13PrimitiveTypeE29EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Unexecuted instantiation: _ZN5doris17dec_less_or_equalILNS_13PrimitiveTypeE20EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Unexecuted instantiation: _ZN5doris17dec_less_or_equalILNS_13PrimitiveTypeE35EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
Unexecuted instantiation: _ZN5doris17dec_less_or_equalILNS_13PrimitiveTypeE30EEEbNS_19PrimitiveTypeTraitsIXT_EE7CppTypeES4_jj
61
62
#define DECLARE_DECIMAL_COMPARISON(TYPE, PTYPE)                        \
63
    template <>                                                        \
64
0
    bool decimal_equal(TYPE x, TYPE y, UInt32 xs, UInt32 ys) {         \
65
0
        return dec_equal<PTYPE>(x, y, xs, ys);                         \
66
0
    }                                                                  \
Unexecuted instantiation: _ZN5doris13decimal_equalINS_7DecimalIiEEEEbT_S3_jj
Unexecuted instantiation: _ZN5doris13decimal_equalINS_7DecimalIlEEEEbT_S3_jj
Unexecuted instantiation: _ZN5doris13decimal_equalINS_14DecimalV2ValueEEEbT_S2_jj
Unexecuted instantiation: _ZN5doris13decimal_equalINS_7DecimalIN4wide7integerILm256EiEEEEEEbT_S6_jj
67
    template <>                                                        \
68
985
    bool decimal_less(TYPE x, TYPE y, UInt32 xs, UInt32 ys) {          \
69
985
        return dec_less<PTYPE>(x, y, xs, ys);                          \
70
985
    }                                                                  \
_ZN5doris12decimal_lessINS_7DecimalIiEEEEbT_S3_jj
Line
Count
Source
68
10
    bool decimal_less(TYPE x, TYPE y, UInt32 xs, UInt32 ys) {          \
69
10
        return dec_less<PTYPE>(x, y, xs, ys);                          \
70
10
    }                                                                  \
_ZN5doris12decimal_lessINS_7DecimalIlEEEEbT_S3_jj
Line
Count
Source
68
3
    bool decimal_less(TYPE x, TYPE y, UInt32 xs, UInt32 ys) {          \
69
3
        return dec_less<PTYPE>(x, y, xs, ys);                          \
70
3
    }                                                                  \
Unexecuted instantiation: _ZN5doris12decimal_lessINS_14DecimalV2ValueEEEbT_S2_jj
_ZN5doris12decimal_lessINS_7DecimalIN4wide7integerILm256EiEEEEEEbT_S6_jj
Line
Count
Source
68
972
    bool decimal_less(TYPE x, TYPE y, UInt32 xs, UInt32 ys) {          \
69
972
        return dec_less<PTYPE>(x, y, xs, ys);                          \
70
972
    }                                                                  \
71
    template <>                                                        \
72
0
    bool decimal_less_or_equal(TYPE x, TYPE y, UInt32 xs, UInt32 ys) { \
73
0
        return dec_less_or_equal<PTYPE>(x, y, xs, ys);                 \
74
0
    }
Unexecuted instantiation: _ZN5doris21decimal_less_or_equalINS_7DecimalIiEEEEbT_S3_jj
Unexecuted instantiation: _ZN5doris21decimal_less_or_equalINS_7DecimalIlEEEEbT_S3_jj
Unexecuted instantiation: _ZN5doris21decimal_less_or_equalINS_14DecimalV2ValueEEEbT_S2_jj
Unexecuted instantiation: _ZN5doris21decimal_less_or_equalINS_7DecimalIN4wide7integerILm256EiEEEEEEbT_S6_jj
75
76
DECLARE_DECIMAL_COMPARISON(Decimal32, TYPE_DECIMAL32)
77
DECLARE_DECIMAL_COMPARISON(Decimal64, TYPE_DECIMAL64)
78
DECLARE_DECIMAL_COMPARISON(DecimalV2Value, TYPE_DECIMALV2)
79
DECLARE_DECIMAL_COMPARISON(Decimal256, TYPE_DECIMAL256)
80
81
template <>
82
0
bool decimal_equal(Decimal128V3 x, Decimal128V3 y, UInt32 xs, UInt32 ys) {
83
0
    return dec_equal<TYPE_DECIMAL128I>(x, y, xs, ys);
84
0
}
85
template <>
86
2.50k
bool decimal_less(Decimal128V3 x, Decimal128V3 y, UInt32 xs, UInt32 ys) {
87
2.50k
    return dec_less<TYPE_DECIMAL128I>(x, y, xs, ys);
88
2.50k
}
89
template <>
90
0
bool decimal_less_or_equal(Decimal128V3 x, Decimal128V3 y, UInt32 xs, UInt32 ys) {
91
0
    return dec_less_or_equal<TYPE_DECIMAL128I>(x, y, xs, ys);
92
0
}
93
94
template <PrimitiveType Type>
95
255M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
255M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
255M
    new (&storage) StorageType(std::move(x));
103
255M
    type = Type;
104
255M
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
255M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE1EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
542k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
542k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
542k
    new (&storage) StorageType(std::move(x));
103
542k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
542k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE3EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
15.2M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
15.2M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
15.2M
    new (&storage) StorageType(std::move(x));
103
15.2M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
15.2M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE4EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
312k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
312k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
312k
    new (&storage) StorageType(std::move(x));
103
312k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
312k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE5EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
23.0M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
23.0M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
23.0M
    new (&storage) StorageType(std::move(x));
103
23.0M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
23.0M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE6EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
69.2M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
69.2M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
69.2M
    new (&storage) StorageType(std::move(x));
103
69.2M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
69.2M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE7EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
387k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
387k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
387k
    new (&storage) StorageType(std::move(x));
103
387k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
387k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE11EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
36.0k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
36.0k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
36.0k
    new (&storage) StorageType(std::move(x));
103
36.0k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
36.0k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE12EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
45.0k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
45.0k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
45.0k
    new (&storage) StorageType(std::move(x));
103
45.0k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
45.0k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE25EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
984k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
984k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
984k
    new (&storage) StorageType(std::move(x));
103
984k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
984k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE26EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
7.24M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
7.24M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
7.24M
    new (&storage) StorageType(std::move(x));
103
7.24M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
7.24M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE28EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
142k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
142k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
142k
    new (&storage) StorageType(std::move(x));
103
142k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
142k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE29EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
13.8M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
13.8M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
13.8M
    new (&storage) StorageType(std::move(x));
103
13.8M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
13.8M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE20EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
16.9k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
16.9k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
16.9k
    new (&storage) StorageType(std::move(x));
103
16.9k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
16.9k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE30EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
258k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
258k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
258k
    new (&storage) StorageType(std::move(x));
103
258k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
258k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE35EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
61.6k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
61.6k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
61.6k
    new (&storage) StorageType(std::move(x));
103
61.6k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
61.6k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE15EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
175k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
175k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
175k
    new (&storage) StorageType(std::move(x));
103
175k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
175k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE10EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
2.81M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
2.81M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
2.81M
    new (&storage) StorageType(std::move(x));
103
2.81M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
2.81M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE23EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
68.1M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
68.1M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
68.1M
    new (&storage) StorageType(std::move(x));
103
68.1M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
68.1M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE41EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
98
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
98
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
98
    new (&storage) StorageType(std::move(x));
103
98
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
98
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE19EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
27
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
27
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
27
    new (&storage) StorageType(std::move(x));
103
27
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
27
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE32EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
482k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
482k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
482k
    new (&storage) StorageType(std::move(x));
103
482k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
482k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE24EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
21
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
21
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
21
    new (&storage) StorageType(std::move(x));
103
21
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
21
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE17EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
8.16M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
8.16M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
8.16M
    new (&storage) StorageType(std::move(x));
103
8.16M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
8.16M
}
Unexecuted instantiation: _ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE21EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE42EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
75.4k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
75.4k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
75.4k
    new (&storage) StorageType(std::move(x));
103
75.4k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
75.4k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE36EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
50.5k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
50.5k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
50.5k
    new (&storage) StorageType(std::move(x));
103
50.5k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
50.5k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE37EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
40.9k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
40.9k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
40.9k
    new (&storage) StorageType(std::move(x));
103
40.9k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
40.9k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE2EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
30.2M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
30.2M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
30.2M
    new (&storage) StorageType(std::move(x));
103
30.2M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
30.2M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE8EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
189k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
189k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
189k
    new (&storage) StorageType(std::move(x));
103
189k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
189k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE9EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
6.72M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
6.72M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
6.72M
    new (&storage) StorageType(std::move(x));
103
6.72M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
6.72M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE31EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
6.60M
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
6.60M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
6.60M
    new (&storage) StorageType(std::move(x));
103
6.60M
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
6.60M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE16EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
11.1k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
11.1k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
11.1k
    new (&storage) StorageType(std::move(x));
103
11.1k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
11.1k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE18EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
29.9k
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
29.9k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
29.9k
    new (&storage) StorageType(std::move(x));
103
29.9k
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
29.9k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE22EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
131
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
131
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
131
    new (&storage) StorageType(std::move(x));
103
131
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
131
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE27EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
127
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
127
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
127
    new (&storage) StorageType(std::move(x));
103
127
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
127
}
Unexecuted instantiation: _ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE38EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE39EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
95
40
void Field::create_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
96
    // In both Field and PODArray, small types may be stored as wider types,
97
    // e.g. char is stored as UInt64. Field can return this extended value
98
    // with get<StorageType>(). To avoid uninitialized results from get(),
99
    // we must initialize the entire wide stored type, and not just the
100
    // nominal type.
101
40
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
102
40
    new (&storage) StorageType(std::move(x));
103
40
    type = Type;
104
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
105
40
}
106
107
template <PrimitiveType Type>
108
291M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
291M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
291M
    new (&storage) StorageType(x);
116
291M
    type = Type;
117
291M
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
291M
}
Unexecuted instantiation: _ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE21EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE1EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
39.7M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
39.7M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
39.7M
    new (&storage) StorageType(x);
116
39.7M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
39.7M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE3EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
5.53M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
5.53M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
5.53M
    new (&storage) StorageType(x);
116
5.53M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
5.53M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE4EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
4.07M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
4.07M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
4.07M
    new (&storage) StorageType(x);
116
4.07M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
4.07M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE5EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
20.9M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
20.9M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
20.9M
    new (&storage) StorageType(x);
116
20.9M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
20.9M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE6EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
13.8M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
13.8M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
13.8M
    new (&storage) StorageType(x);
116
13.8M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
13.8M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE7EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.27M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.27M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.27M
    new (&storage) StorageType(x);
116
3.27M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.27M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE11EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.40M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.40M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.40M
    new (&storage) StorageType(x);
116
3.40M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.40M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE12EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.33M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.33M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.33M
    new (&storage) StorageType(x);
116
3.33M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.33M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE25EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
5.61M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
5.61M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
5.61M
    new (&storage) StorageType(x);
116
5.61M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
5.61M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE26EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
4.18M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
4.18M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
4.18M
    new (&storage) StorageType(x);
116
4.18M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
4.18M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE42EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
47.3k
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
47.3k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
47.3k
    new (&storage) StorageType(x);
116
47.3k
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
47.3k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE28EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.61M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.61M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.61M
    new (&storage) StorageType(x);
116
3.61M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.61M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE29EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.64M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.64M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.64M
    new (&storage) StorageType(x);
116
3.64M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.64M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE20EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
9.97k
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
9.97k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
9.97k
    new (&storage) StorageType(x);
116
9.97k
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
9.97k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE30EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.53M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.53M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.53M
    new (&storage) StorageType(x);
116
3.53M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.53M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE35EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.71M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.71M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.71M
    new (&storage) StorageType(x);
116
3.71M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.71M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE15EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
4.55k
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
4.55k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
4.55k
    new (&storage) StorageType(x);
116
4.55k
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
4.55k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE10EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
13.0M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
13.0M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
13.0M
    new (&storage) StorageType(x);
116
13.0M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
13.0M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE23EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
35.0M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
35.0M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
35.0M
    new (&storage) StorageType(x);
116
35.0M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
35.0M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE41EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
6
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
6
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
6
    new (&storage) StorageType(x);
116
6
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
6
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE19EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
403
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
403
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
403
    new (&storage) StorageType(x);
116
403
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
403
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE32EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
75.5k
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
75.5k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
75.5k
    new (&storage) StorageType(x);
116
75.5k
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
75.5k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE24EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
22.3k
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
22.3k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
22.3k
    new (&storage) StorageType(x);
116
22.3k
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
22.3k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE17EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
93.5M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
93.5M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
93.5M
    new (&storage) StorageType(x);
116
93.5M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
93.5M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE36EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
68.8k
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
68.8k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
68.8k
    new (&storage) StorageType(x);
116
68.8k
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
68.8k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE37EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
48.3k
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
48.3k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
48.3k
    new (&storage) StorageType(x);
116
48.3k
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
48.3k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE2EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
4.10M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
4.10M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
4.10M
    new (&storage) StorageType(x);
116
4.10M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
4.10M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE8EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.54M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.54M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.54M
    new (&storage) StorageType(x);
116
3.54M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.54M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE9EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
4.25M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
4.25M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
4.25M
    new (&storage) StorageType(x);
116
4.25M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
4.25M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE31EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
2.89M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
2.89M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
2.89M
    new (&storage) StorageType(x);
116
2.89M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
2.89M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE16EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
3.04M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
3.04M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
3.04M
    new (&storage) StorageType(x);
116
3.04M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
3.04M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE18EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
13.2M
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
13.2M
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
13.2M
    new (&storage) StorageType(x);
116
13.2M
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
13.2M
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE22EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
2.42k
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
2.42k
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
2.42k
    new (&storage) StorageType(x);
116
2.42k
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
2.42k
}
_ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE27EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
108
135
void Field::create_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
109
    // In both Field and PODArray, small types may be stored as wider types,
110
    // e.g. char is stored as UInt64. Field can return this extended value
111
    // with get<StorageType>(). To avoid uninitialized results from get(),
112
    // we must initialize the entire wide stored type, and not just the
113
    // nominal type.
114
135
    using StorageType = typename PrimitiveTypeTraits<Type>::CppType;
115
135
    new (&storage) StorageType(x);
116
135
    type = Type;
117
    DCHECK_NE(type, PrimitiveType::INVALID_TYPE);
118
135
}
Unexecuted instantiation: _ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE38EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Unexecuted instantiation: _ZN5doris5Field15create_concreteILNS_13PrimitiveTypeE39EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
119
120
131M
void Field::create(Field&& field) {
121
131M
    switch (field.type) {
122
479k
    case PrimitiveType::TYPE_NULL:
123
479k
        create_concrete<TYPE_NULL>(std::move(field.template get<TYPE_NULL>()));
124
479k
        return;
125
3.62M
    case PrimitiveType::TYPE_DATETIMEV2:
126
3.62M
        create_concrete<TYPE_DATETIMEV2>(std::move(field.template get<TYPE_DATETIMEV2>()));
127
3.62M
        return;
128
589k
    case PrimitiveType::TYPE_DATEV2:
129
589k
        create_concrete<TYPE_DATEV2>(std::move(field.template get<TYPE_DATEV2>()));
130
589k
        return;
131
39.9k
    case PrimitiveType::TYPE_TIMESTAMPTZ:
132
39.9k
        create_concrete<TYPE_TIMESTAMPTZ>(std::move(field.template get<TYPE_TIMESTAMPTZ>()));
133
39.9k
        return;
134
29.6k
    case PrimitiveType::TYPE_DATETIME:
135
29.6k
        create_concrete<TYPE_DATETIME>(std::move(field.template get<TYPE_DATETIME>()));
136
29.6k
        return;
137
23.0k
    case PrimitiveType::TYPE_DATE:
138
23.0k
        create_concrete<TYPE_DATE>(std::move(field.template get<TYPE_DATE>()));
139
23.0k
        return;
140
1.19M
    case PrimitiveType::TYPE_BOOLEAN:
141
1.19M
        create_concrete<TYPE_BOOLEAN>(std::move(field.template get<TYPE_BOOLEAN>()));
142
1.19M
        return;
143
7.77M
    case PrimitiveType::TYPE_TINYINT:
144
7.77M
        create_concrete<TYPE_TINYINT>(std::move(field.template get<TYPE_TINYINT>()));
145
7.77M
        return;
146
176k
    case PrimitiveType::TYPE_SMALLINT:
147
176k
        create_concrete<TYPE_SMALLINT>(std::move(field.template get<TYPE_SMALLINT>()));
148
176k
        return;
149
19.5M
    case PrimitiveType::TYPE_INT:
150
19.5M
        create_concrete<TYPE_INT>(std::move(field.template get<TYPE_INT>()));
151
19.5M
        return;
152
34.7M
    case PrimitiveType::TYPE_BIGINT:
153
34.7M
        create_concrete<TYPE_BIGINT>(std::move(field.template get<TYPE_BIGINT>()));
154
34.7M
        return;
155
203k
    case PrimitiveType::TYPE_LARGEINT:
156
203k
        create_concrete<TYPE_LARGEINT>(std::move(field.template get<TYPE_LARGEINT>()));
157
203k
        return;
158
44.0k
    case PrimitiveType::TYPE_IPV4:
159
44.0k
        create_concrete<TYPE_IPV4>(std::move(field.template get<TYPE_IPV4>()));
160
44.0k
        return;
161
32.0k
    case PrimitiveType::TYPE_IPV6:
162
32.0k
        create_concrete<TYPE_IPV6>(std::move(field.template get<TYPE_IPV6>()));
163
32.0k
        return;
164
111k
    case PrimitiveType::TYPE_FLOAT:
165
111k
        create_concrete<TYPE_FLOAT>(std::move(field.template get<TYPE_FLOAT>()));
166
111k
        return;
167
122
    case PrimitiveType::TYPE_TIMEV2:
168
122
        create_concrete<TYPE_TIMEV2>(std::move(field.template get<TYPE_TIMEV2>()));
169
122
        return;
170
3.73M
    case PrimitiveType::TYPE_DOUBLE:
171
3.73M
        create_concrete<TYPE_DOUBLE>(std::move(field.template get<TYPE_DOUBLE>()));
172
3.73M
        return;
173
48.3M
    case PrimitiveType::TYPE_STRING:
174
48.3M
        create_concrete<TYPE_STRING>(std::move(field.template get<TYPE_STRING>()));
175
48.3M
        return;
176
55.1k
    case PrimitiveType::TYPE_CHAR:
177
55.1k
        create_concrete<TYPE_CHAR>(std::move(field.template get<TYPE_CHAR>()));
178
55.1k
        return;
179
1.44M
    case PrimitiveType::TYPE_VARCHAR:
180
1.44M
        create_concrete<TYPE_VARCHAR>(std::move(field.template get<TYPE_VARCHAR>()));
181
1.44M
        return;
182
3.81M
    case PrimitiveType::TYPE_JSONB:
183
3.81M
        create_concrete<TYPE_JSONB>(std::move(field.template get<TYPE_JSONB>()));
184
3.81M
        return;
185
5.88M
    case PrimitiveType::TYPE_ARRAY:
186
5.88M
        create_concrete<TYPE_ARRAY>(std::move(field.template get<TYPE_ARRAY>()));
187
5.88M
        return;
188
5.20k
    case PrimitiveType::TYPE_STRUCT:
189
5.20k
        create_concrete<TYPE_STRUCT>(std::move(field.template get<TYPE_STRUCT>()));
190
5.20k
        return;
191
5.77k
    case PrimitiveType::TYPE_MAP:
192
5.77k
        create_concrete<TYPE_MAP>(std::move(field.template get<TYPE_MAP>()));
193
5.77k
        return;
194
79.5k
    case PrimitiveType::TYPE_DECIMAL32:
195
79.5k
        create_concrete<TYPE_DECIMAL32>(std::move(field.template get<TYPE_DECIMAL32>()));
196
79.5k
        return;
197
129k
    case PrimitiveType::TYPE_DECIMAL64:
198
129k
        create_concrete<TYPE_DECIMAL64>(std::move(field.template get<TYPE_DECIMAL64>()));
199
129k
        return;
200
6.57k
    case PrimitiveType::TYPE_DECIMALV2:
201
6.57k
        create_concrete<TYPE_DECIMALV2>(std::move(field.template get<TYPE_DECIMALV2>()));
202
6.57k
        return;
203
131k
    case PrimitiveType::TYPE_DECIMAL128I:
204
131k
        create_concrete<TYPE_DECIMAL128I>(std::move(field.template get<TYPE_DECIMAL128I>()));
205
131k
        return;
206
49.6k
    case PrimitiveType::TYPE_DECIMAL256:
207
49.6k
        create_concrete<TYPE_DECIMAL256>(std::move(field.template get<TYPE_DECIMAL256>()));
208
49.6k
        return;
209
257k
    case PrimitiveType::TYPE_VARIANT:
210
257k
        create_concrete<TYPE_VARIANT>(std::move(field.template get<TYPE_VARIANT>()));
211
257k
        return;
212
39
    case PrimitiveType::TYPE_BITMAP:
213
39
        create_concrete<TYPE_BITMAP>(std::move(field.template get<TYPE_BITMAP>()));
214
39
        return;
215
3
    case PrimitiveType::TYPE_HLL:
216
3
        create_concrete<TYPE_HLL>(std::move(field.template get<TYPE_HLL>()));
217
3
        return;
218
1
    case PrimitiveType::TYPE_QUANTILE_STATE:
219
1
        create_concrete<TYPE_QUANTILE_STATE>(std::move(field.template get<TYPE_QUANTILE_STATE>()));
220
1
        return;
221
47
    case PrimitiveType::TYPE_VARBINARY:
222
47
        create_concrete<TYPE_VARBINARY>(std::move(field.template get<TYPE_VARBINARY>()));
223
47
        return;
224
0
    default:
225
0
        throw Exception(Status::FatalError("type not supported, type={}", field.get_type_name()));
226
131M
    }
227
131M
}
228
229
228M
Field::Field(const Field& rhs) {
230
228M
    create(rhs);
231
228M
}
232
233
42.8M
Field::Field(Field&& rhs) {
234
42.8M
    create(std::move(rhs));
235
42.8M
}
236
237
10.7M
Field& Field::operator=(const Field& rhs) {
238
10.7M
    if (this != &rhs) {
239
10.7M
        if (type != rhs.type) {
240
8.95M
            destroy();
241
8.95M
            create(rhs);
242
8.95M
        } else {
243
1.75M
            assign(rhs); /// This assigns string or vector without deallocation of existing buffer.
244
1.75M
        }
245
10.7M
    }
246
10.7M
    return *this;
247
10.7M
}
248
249
237M
void Field::create(const Field& field) {
250
237M
    switch (field.type) {
251
39.7M
    case PrimitiveType::TYPE_NULL:
252
39.7M
        create_concrete<TYPE_NULL>(field.template get<TYPE_NULL>());
253
39.7M
        return;
254
4.07M
    case PrimitiveType::TYPE_DATETIMEV2:
255
4.07M
        create_concrete<TYPE_DATETIMEV2>(field.template get<TYPE_DATETIMEV2>());
256
4.07M
        return;
257
4.85M
    case PrimitiveType::TYPE_DATEV2:
258
4.85M
        create_concrete<TYPE_DATEV2>(field.template get<TYPE_DATEV2>());
259
4.85M
        return;
260
31.0k
    case PrimitiveType::TYPE_TIMESTAMPTZ:
261
31.0k
        create_concrete<TYPE_TIMESTAMPTZ>(field.template get<TYPE_TIMESTAMPTZ>());
262
31.0k
        return;
263
3.32M
    case PrimitiveType::TYPE_DATETIME:
264
3.32M
        create_concrete<TYPE_DATETIME>(field.template get<TYPE_DATETIME>());
265
3.32M
        return;
266
3.39M
    case PrimitiveType::TYPE_DATE:
267
3.39M
        create_concrete<TYPE_DATE>(field.template get<TYPE_DATE>());
268
3.39M
        return;
269
3.97M
    case PrimitiveType::TYPE_BOOLEAN:
270
3.97M
        create_concrete<TYPE_BOOLEAN>(field.template get<TYPE_BOOLEAN>());
271
3.97M
        return;
272
5.01M
    case PrimitiveType::TYPE_TINYINT:
273
5.01M
        create_concrete<TYPE_TINYINT>(field.template get<TYPE_TINYINT>());
274
5.01M
        return;
275
4.00M
    case PrimitiveType::TYPE_SMALLINT:
276
4.00M
        create_concrete<TYPE_SMALLINT>(field.template get<TYPE_SMALLINT>());
277
4.00M
        return;
278
1.35M
    case PrimitiveType::TYPE_INT:
279
1.35M
        create_concrete<TYPE_INT>(field.template get<TYPE_INT>());
280
1.35M
        return;
281
9.75M
    case PrimitiveType::TYPE_BIGINT:
282
9.75M
        create_concrete<TYPE_BIGINT>(field.template get<TYPE_BIGINT>());
283
9.75M
        return;
284
3.23M
    case PrimitiveType::TYPE_LARGEINT:
285
3.23M
        create_concrete<TYPE_LARGEINT>(field.template get<TYPE_LARGEINT>());
286
3.23M
        return;
287
31.4k
    case PrimitiveType::TYPE_IPV4:
288
31.4k
        create_concrete<TYPE_IPV4>(field.template get<TYPE_IPV4>());
289
31.4k
        return;
290
20.7k
    case PrimitiveType::TYPE_IPV6:
291
20.7k
        create_concrete<TYPE_IPV6>(field.template get<TYPE_IPV6>());
292
20.7k
        return;
293
3.49M
    case PrimitiveType::TYPE_FLOAT:
294
3.49M
        create_concrete<TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
295
3.49M
        return;
296
8
    case PrimitiveType::TYPE_TIMEV2:
297
8
        create_concrete<TYPE_TIMEV2>(field.template get<TYPE_TIMEV2>());
298
8
        return;
299
4.02M
    case PrimitiveType::TYPE_DOUBLE:
300
4.02M
        create_concrete<TYPE_DOUBLE>(field.template get<TYPE_DOUBLE>());
301
4.02M
        return;
302
8.10M
    case PrimitiveType::TYPE_STRING:
303
8.10M
        create_concrete<TYPE_STRING>(field.template get<TYPE_STRING>());
304
8.10M
        return;
305
4.36k
    case PrimitiveType::TYPE_CHAR:
306
4.36k
        create_concrete<TYPE_CHAR>(field.template get<TYPE_CHAR>());
307
4.36k
        return;
308
12.5M
    case PrimitiveType::TYPE_VARCHAR:
309
12.5M
        create_concrete<TYPE_VARCHAR>(field.template get<TYPE_VARCHAR>());
310
12.5M
        return;
311
2.89M
    case PrimitiveType::TYPE_JSONB:
312
2.89M
        create_concrete<TYPE_JSONB>(field.template get<TYPE_JSONB>());
313
2.89M
        return;
314
93.1M
    case PrimitiveType::TYPE_ARRAY:
315
93.1M
        create_concrete<TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
316
93.1M
        return;
317
3.04M
    case PrimitiveType::TYPE_STRUCT:
318
3.04M
        create_concrete<TYPE_STRUCT>(field.template get<TYPE_STRUCT>());
319
3.04M
        return;
320
13.2M
    case PrimitiveType::TYPE_MAP:
321
13.2M
        create_concrete<TYPE_MAP>(field.template get<TYPE_MAP>());
322
13.2M
        return;
323
3.59M
    case PrimitiveType::TYPE_DECIMAL32:
324
3.59M
        create_concrete<TYPE_DECIMAL32>(field.template get<TYPE_DECIMAL32>());
325
3.59M
        return;
326
3.60M
    case PrimitiveType::TYPE_DECIMAL64:
327
3.60M
        create_concrete<TYPE_DECIMAL64>(field.template get<TYPE_DECIMAL64>());
328
3.60M
        return;
329
1.22k
    case PrimitiveType::TYPE_DECIMALV2:
330
1.22k
        create_concrete<TYPE_DECIMALV2>(field.template get<TYPE_DECIMALV2>());
331
1.22k
        return;
332
3.50M
    case PrimitiveType::TYPE_DECIMAL128I:
333
3.50M
        create_concrete<TYPE_DECIMAL128I>(field.template get<TYPE_DECIMAL128I>());
334
3.50M
        return;
335
3.67M
    case PrimitiveType::TYPE_DECIMAL256:
336
3.67M
        create_concrete<TYPE_DECIMAL256>(field.template get<TYPE_DECIMAL256>());
337
3.67M
        return;
338
75.5k
    case PrimitiveType::TYPE_VARIANT:
339
75.5k
        create_concrete<TYPE_VARIANT>(field.template get<TYPE_VARIANT>());
340
75.5k
        return;
341
0
    case PrimitiveType::TYPE_BITMAP:
342
0
        create_concrete<TYPE_BITMAP>(field.template get<TYPE_BITMAP>());
343
0
        return;
344
0
    case PrimitiveType::TYPE_HLL:
345
0
        create_concrete<TYPE_HLL>(field.template get<TYPE_HLL>());
346
0
        return;
347
0
    case PrimitiveType::TYPE_QUANTILE_STATE:
348
0
        create_concrete<TYPE_QUANTILE_STATE>(field.template get<TYPE_QUANTILE_STATE>());
349
0
        return;
350
0
    case PrimitiveType::TYPE_UINT32:
351
0
        create_concrete<TYPE_UINT32>(field.template get<TYPE_UINT32>());
352
0
        return;
353
0
    case PrimitiveType::TYPE_UINT64:
354
0
        create_concrete<TYPE_UINT64>(field.template get<TYPE_UINT64>());
355
0
        return;
356
0
    case PrimitiveType::TYPE_VARBINARY:
357
0
        create_concrete<TYPE_VARBINARY>(field.template get<TYPE_VARBINARY>());
358
0
        return;
359
0
    default:
360
0
        throw Exception(Status::FatalError("type not supported, type={}", field.get_type_name()));
361
237M
    }
362
237M
}
363
364
725M
void Field::destroy() {
365
725M
    switch (type) {
366
103M
    case PrimitiveType::TYPE_STRING:
367
103M
        destroy<TYPE_STRING>();
368
103M
        break;
369
180k
    case PrimitiveType::TYPE_CHAR:
370
180k
        destroy<TYPE_CHAR>();
371
180k
        break;
372
15.9M
    case PrimitiveType::TYPE_VARCHAR:
373
15.9M
        destroy<TYPE_VARCHAR>();
374
15.9M
        break;
375
9.50M
    case PrimitiveType::TYPE_JSONB:
376
9.50M
        destroy<TYPE_JSONB>();
377
9.50M
        break;
378
101M
    case PrimitiveType::TYPE_ARRAY:
379
101M
        destroy<TYPE_ARRAY>();
380
101M
        break;
381
3.06M
    case PrimitiveType::TYPE_STRUCT:
382
3.06M
        destroy<TYPE_STRUCT>();
383
3.06M
        break;
384
13.2M
    case PrimitiveType::TYPE_MAP:
385
13.2M
        destroy<TYPE_MAP>();
386
13.2M
        break;
387
558k
    case PrimitiveType::TYPE_VARIANT:
388
558k
        destroy<TYPE_VARIANT>();
389
558k
        break;
390
2.55k
    case PrimitiveType::TYPE_BITMAP:
391
2.55k
        destroy<TYPE_BITMAP>();
392
2.55k
        break;
393
430
    case PrimitiveType::TYPE_HLL:
394
430
        destroy<TYPE_HLL>();
395
430
        break;
396
22.4k
    case PrimitiveType::TYPE_QUANTILE_STATE:
397
22.4k
        destroy<TYPE_QUANTILE_STATE>();
398
22.4k
        break;
399
104
    case PrimitiveType::TYPE_VARBINARY:
400
104
        destroy<TYPE_VARBINARY>();
401
104
        break;
402
481M
    default:
403
481M
        break;
404
725M
    }
405
406
724M
    type = PrimitiveType::
407
724M
            TYPE_NULL; /// for exception safety in subsequent calls to destroy and create, when create fails.
408
724M
}
409
410
33.4M
void Field::assign(Field&& field) {
411
33.4M
    switch (field.type) {
412
30.4M
    case PrimitiveType::TYPE_NULL:
413
30.4M
        assign_concrete<TYPE_NULL>(std::move(field.template get<TYPE_NULL>()));
414
30.4M
        return;
415
80.5k
    case PrimitiveType::TYPE_DATETIMEV2:
416
80.5k
        assign_concrete<TYPE_DATETIMEV2>(std::move(field.template get<TYPE_DATETIMEV2>()));
417
80.5k
        return;
418
878
    case PrimitiveType::TYPE_DATETIME:
419
878
        assign_concrete<TYPE_DATETIME>(std::move(field.template get<TYPE_DATETIME>()));
420
878
        return;
421
441
    case PrimitiveType::TYPE_DATE:
422
441
        assign_concrete<TYPE_DATE>(std::move(field.template get<TYPE_DATE>()));
423
441
        return;
424
72.8k
    case PrimitiveType::TYPE_DATEV2:
425
72.8k
        assign_concrete<TYPE_DATEV2>(std::move(field.template get<TYPE_DATEV2>()));
426
72.8k
        return;
427
6.89k
    case PrimitiveType::TYPE_TIMESTAMPTZ:
428
6.89k
        assign_concrete<TYPE_TIMESTAMPTZ>(std::move(field.template get<TYPE_TIMESTAMPTZ>()));
429
6.89k
        return;
430
25.4k
    case PrimitiveType::TYPE_BOOLEAN:
431
25.4k
        assign_concrete<TYPE_BOOLEAN>(std::move(field.template get<TYPE_BOOLEAN>()));
432
25.4k
        return;
433
87.3k
    case PrimitiveType::TYPE_TINYINT:
434
87.3k
        assign_concrete<TYPE_TINYINT>(std::move(field.template get<TYPE_TINYINT>()));
435
87.3k
        return;
436
25.3k
    case PrimitiveType::TYPE_SMALLINT:
437
25.3k
        assign_concrete<TYPE_SMALLINT>(std::move(field.template get<TYPE_SMALLINT>()));
438
25.3k
        return;
439
1.06M
    case PrimitiveType::TYPE_INT:
440
1.06M
        assign_concrete<TYPE_INT>(std::move(field.template get<TYPE_INT>()));
441
1.06M
        return;
442
420k
    case PrimitiveType::TYPE_BIGINT:
443
420k
        assign_concrete<TYPE_BIGINT>(std::move(field.template get<TYPE_BIGINT>()));
444
420k
        return;
445
35.2k
    case PrimitiveType::TYPE_LARGEINT:
446
35.2k
        assign_concrete<TYPE_LARGEINT>(std::move(field.template get<TYPE_LARGEINT>()));
447
35.2k
        return;
448
1.19k
    case PrimitiveType::TYPE_IPV4:
449
1.19k
        assign_concrete<TYPE_IPV4>(std::move(field.template get<TYPE_IPV4>()));
450
1.19k
        return;
451
1.09k
    case PrimitiveType::TYPE_IPV6:
452
1.09k
        assign_concrete<TYPE_IPV6>(std::move(field.template get<TYPE_IPV6>()));
453
1.09k
        return;
454
15.6k
    case PrimitiveType::TYPE_FLOAT:
455
15.6k
        assign_concrete<TYPE_FLOAT>(std::move(field.template get<TYPE_FLOAT>()));
456
15.6k
        return;
457
0
    case PrimitiveType::TYPE_TIMEV2:
458
0
        assign_concrete<TYPE_TIMEV2>(std::move(field.template get<TYPE_TIMEV2>()));
459
0
        return;
460
31.5k
    case PrimitiveType::TYPE_DOUBLE:
461
31.5k
        assign_concrete<TYPE_DOUBLE>(std::move(field.template get<TYPE_DOUBLE>()));
462
31.5k
        return;
463
416k
    case PrimitiveType::TYPE_STRING:
464
416k
        assign_concrete<TYPE_STRING>(std::move(field.template get<TYPE_STRING>()));
465
416k
        return;
466
36.8k
    case PrimitiveType::TYPE_CHAR:
467
36.8k
        assign_concrete<TYPE_CHAR>(std::move(field.template get<TYPE_CHAR>()));
468
36.8k
        return;
469
358k
    case PrimitiveType::TYPE_VARCHAR:
470
358k
        assign_concrete<TYPE_VARCHAR>(std::move(field.template get<TYPE_VARCHAR>()));
471
358k
        return;
472
204k
    case PrimitiveType::TYPE_JSONB:
473
204k
        assign_concrete<TYPE_JSONB>(std::move(field.template get<TYPE_JSONB>()));
474
204k
        return;
475
40.2k
    case PrimitiveType::TYPE_ARRAY:
476
40.2k
        assign_concrete<TYPE_ARRAY>(std::move(field.template get<TYPE_ARRAY>()));
477
40.2k
        return;
478
338
    case PrimitiveType::TYPE_STRUCT:
479
338
        assign_concrete<TYPE_STRUCT>(std::move(field.template get<TYPE_STRUCT>()));
480
338
        return;
481
6.38k
    case PrimitiveType::TYPE_MAP:
482
6.38k
        assign_concrete<TYPE_MAP>(std::move(field.template get<TYPE_MAP>()));
483
6.38k
        return;
484
8.06k
    case PrimitiveType::TYPE_DECIMAL32:
485
8.06k
        assign_concrete<TYPE_DECIMAL32>(std::move(field.template get<TYPE_DECIMAL32>()));
486
8.06k
        return;
487
36.5k
    case PrimitiveType::TYPE_DECIMAL64:
488
36.5k
        assign_concrete<TYPE_DECIMAL64>(std::move(field.template get<TYPE_DECIMAL64>()));
489
36.5k
        return;
490
140
    case PrimitiveType::TYPE_DECIMALV2:
491
140
        assign_concrete<TYPE_DECIMALV2>(std::move(field.template get<TYPE_DECIMALV2>()));
492
140
        return;
493
21.5k
    case PrimitiveType::TYPE_DECIMAL128I:
494
21.5k
        assign_concrete<TYPE_DECIMAL128I>(std::move(field.template get<TYPE_DECIMAL128I>()));
495
21.5k
        return;
496
1.09k
    case PrimitiveType::TYPE_DECIMAL256:
497
1.09k
        assign_concrete<TYPE_DECIMAL256>(std::move(field.template get<TYPE_DECIMAL256>()));
498
1.09k
        return;
499
6.49k
    case PrimitiveType::TYPE_VARIANT:
500
6.49k
        assign_concrete<TYPE_VARIANT>(std::move(field.template get<TYPE_VARIANT>()));
501
6.49k
        return;
502
36
    case PrimitiveType::TYPE_BITMAP:
503
36
        assign_concrete<TYPE_BITMAP>(std::move(field.template get<TYPE_BITMAP>()));
504
36
        return;
505
1
    case PrimitiveType::TYPE_HLL:
506
1
        assign_concrete<TYPE_HLL>(std::move(field.template get<TYPE_HLL>()));
507
1
        return;
508
1
    case PrimitiveType::TYPE_QUANTILE_STATE:
509
1
        assign_concrete<TYPE_QUANTILE_STATE>(std::move(field.template get<TYPE_QUANTILE_STATE>()));
510
1
        return;
511
0
    case PrimitiveType::TYPE_VARBINARY:
512
0
        assign_concrete<TYPE_VARBINARY>(std::move(field.template get<TYPE_VARBINARY>()));
513
0
        return;
514
0
    default:
515
0
        throw Exception(Status::FatalError("type not supported, type={}", field.get_type_name()));
516
33.4M
    }
517
33.4M
}
518
519
1.76M
void Field::assign(const Field& field) {
520
1.76M
    switch (field.type) {
521
218k
    case PrimitiveType::TYPE_NULL:
522
218k
        assign_concrete<TYPE_NULL>(field.template get<TYPE_NULL>());
523
218k
        return;
524
74.4k
    case PrimitiveType::TYPE_DATETIMEV2:
525
74.4k
        assign_concrete<TYPE_DATETIMEV2>(field.template get<TYPE_DATETIMEV2>());
526
74.4k
        return;
527
715
    case PrimitiveType::TYPE_DATETIME:
528
715
        assign_concrete<TYPE_DATETIME>(field.template get<TYPE_DATETIME>());
529
715
        return;
530
387
    case PrimitiveType::TYPE_DATE:
531
387
        assign_concrete<TYPE_DATE>(field.template get<TYPE_DATE>());
532
387
        return;
533
58.4k
    case PrimitiveType::TYPE_DATEV2:
534
58.4k
        assign_concrete<TYPE_DATEV2>(field.template get<TYPE_DATEV2>());
535
58.4k
        return;
536
6.69k
    case PrimitiveType::TYPE_TIMESTAMPTZ:
537
6.69k
        assign_concrete<TYPE_TIMESTAMPTZ>(field.template get<TYPE_TIMESTAMPTZ>());
538
6.69k
        return;
539
20.4k
    case PrimitiveType::TYPE_BOOLEAN:
540
20.4k
        assign_concrete<TYPE_BOOLEAN>(field.template get<TYPE_BOOLEAN>());
541
20.4k
        return;
542
87.2k
    case PrimitiveType::TYPE_TINYINT:
543
87.2k
        assign_concrete<TYPE_TINYINT>(field.template get<TYPE_TINYINT>());
544
87.2k
        return;
545
23.9k
    case PrimitiveType::TYPE_SMALLINT:
546
23.9k
        assign_concrete<TYPE_SMALLINT>(field.template get<TYPE_SMALLINT>());
547
23.9k
        return;
548
197k
    case PrimitiveType::TYPE_INT:
549
197k
        assign_concrete<TYPE_INT>(field.template get<TYPE_INT>());
550
197k
        return;
551
337k
    case PrimitiveType::TYPE_BIGINT:
552
337k
        assign_concrete<TYPE_BIGINT>(field.template get<TYPE_BIGINT>());
553
337k
        return;
554
32.1k
    case PrimitiveType::TYPE_LARGEINT:
555
32.1k
        assign_concrete<TYPE_LARGEINT>(field.template get<TYPE_LARGEINT>());
556
32.1k
        return;
557
1.24k
    case PrimitiveType::TYPE_IPV4:
558
1.24k
        assign_concrete<TYPE_IPV4>(field.template get<TYPE_IPV4>());
559
1.24k
        return;
560
1.06k
    case PrimitiveType::TYPE_IPV6:
561
1.06k
        assign_concrete<TYPE_IPV6>(field.template get<TYPE_IPV6>());
562
1.06k
        return;
563
14.5k
    case PrimitiveType::TYPE_FLOAT:
564
14.5k
        assign_concrete<TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
565
14.5k
        return;
566
0
    case PrimitiveType::TYPE_TIMEV2:
567
0
        assign_concrete<TYPE_TIMEV2>(field.template get<TYPE_TIMEV2>());
568
0
        return;
569
28.0k
    case PrimitiveType::TYPE_DOUBLE:
570
28.0k
        assign_concrete<TYPE_DOUBLE>(field.template get<TYPE_DOUBLE>());
571
28.0k
        return;
572
175k
    case PrimitiveType::TYPE_STRING:
573
175k
        assign_concrete<TYPE_STRING>(field.template get<TYPE_STRING>());
574
175k
        return;
575
27.1k
    case PrimitiveType::TYPE_CHAR:
576
27.1k
        assign_concrete<TYPE_CHAR>(field.template get<TYPE_CHAR>());
577
27.1k
        return;
578
367k
    case PrimitiveType::TYPE_VARCHAR:
579
367k
        assign_concrete<TYPE_VARCHAR>(field.template get<TYPE_VARCHAR>());
580
367k
        return;
581
22
    case PrimitiveType::TYPE_JSONB:
582
22
        assign_concrete<TYPE_JSONB>(field.template get<TYPE_JSONB>());
583
22
        return;
584
38.4k
    case PrimitiveType::TYPE_ARRAY:
585
38.4k
        assign_concrete<TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
586
38.4k
        return;
587
0
    case PrimitiveType::TYPE_STRUCT:
588
0
        assign_concrete<TYPE_STRUCT>(field.template get<TYPE_STRUCT>());
589
0
        return;
590
1
    case PrimitiveType::TYPE_MAP:
591
1
        assign_concrete<TYPE_MAP>(field.template get<TYPE_MAP>());
592
1
        return;
593
14.9k
    case PrimitiveType::TYPE_DECIMAL32:
594
14.9k
        assign_concrete<TYPE_DECIMAL32>(field.template get<TYPE_DECIMAL32>());
595
14.9k
        return;
596
20.8k
    case PrimitiveType::TYPE_DECIMAL64:
597
20.8k
        assign_concrete<TYPE_DECIMAL64>(field.template get<TYPE_DECIMAL64>());
598
20.8k
        return;
599
138
    case PrimitiveType::TYPE_DECIMALV2:
600
138
        assign_concrete<TYPE_DECIMALV2>(field.template get<TYPE_DECIMALV2>());
601
138
        return;
602
19.1k
    case PrimitiveType::TYPE_DECIMAL128I:
603
19.1k
        assign_concrete<TYPE_DECIMAL128I>(field.template get<TYPE_DECIMAL128I>());
604
19.1k
        return;
605
1.08k
    case PrimitiveType::TYPE_DECIMAL256:
606
1.08k
        assign_concrete<TYPE_DECIMAL256>(field.template get<TYPE_DECIMAL256>());
607
1.08k
        return;
608
0
    case PrimitiveType::TYPE_VARIANT:
609
0
        assign_concrete<TYPE_VARIANT>(field.template get<TYPE_VARIANT>());
610
0
        return;
611
2
    case PrimitiveType::TYPE_BITMAP:
612
2
        assign_concrete<TYPE_BITMAP>(field.template get<TYPE_BITMAP>());
613
2
        return;
614
1
    case PrimitiveType::TYPE_HLL:
615
1
        assign_concrete<TYPE_HLL>(field.template get<TYPE_HLL>());
616
1
        return;
617
1
    case PrimitiveType::TYPE_QUANTILE_STATE:
618
1
        assign_concrete<TYPE_QUANTILE_STATE>(field.template get<TYPE_QUANTILE_STATE>());
619
1
        return;
620
0
    case PrimitiveType::TYPE_UINT32:
621
0
        assign_concrete<TYPE_UINT32>(field.template get<TYPE_UINT32>());
622
0
        return;
623
0
    case PrimitiveType::TYPE_UINT64:
624
0
        assign_concrete<TYPE_UINT64>(field.template get<TYPE_UINT64>());
625
0
        return;
626
0
    case PrimitiveType::TYPE_VARBINARY:
627
0
        assign_concrete<TYPE_VARBINARY>(field.template get<TYPE_VARBINARY>());
628
0
        return;
629
0
    default:
630
0
        throw Exception(Status::FatalError("type not supported, type={}", field.get_type_name()));
631
1.76M
    }
632
1.76M
}
633
634
/// Assuming same types.
635
template <PrimitiveType Type>
636
33.6M
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
33.6M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
33.6M
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
33.6M
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE1EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
30.6M
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
30.6M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
30.6M
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
30.6M
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE3EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
87.3k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
87.3k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
87.3k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
87.3k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE4EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
25.3k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
25.3k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
25.3k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
25.3k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE5EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
1.06M
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
1.06M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
1.06M
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
1.06M
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE6EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
420k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
420k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
420k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
420k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE7EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
35.2k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
35.2k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
35.2k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
35.2k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE11EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
441
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
441
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
441
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
441
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE12EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
878
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
878
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
878
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
878
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE25EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
72.8k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
72.8k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
72.8k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
72.8k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE26EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
80.5k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
80.5k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
80.5k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
80.5k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE28EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
8.06k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
8.06k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
8.06k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
8.06k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE29EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
36.5k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
36.5k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
36.5k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
36.5k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE20EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
140
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
140
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
140
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
140
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE30EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
21.5k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
21.5k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
21.5k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
21.5k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE35EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
1.09k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
1.09k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
1.09k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
1.09k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE15EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
36.8k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
36.8k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
36.8k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
36.8k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE10EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
358k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
358k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
358k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
358k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE23EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
416k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
416k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
416k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
416k
}
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE41EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE19EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
1
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
1
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
1
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
1
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE32EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
6.54k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
6.54k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
6.54k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
6.54k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE24EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
1
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
1
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
1
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
1
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE17EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
40.2k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
40.2k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
40.2k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
40.2k
}
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE21EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE42EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
6.89k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
6.89k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
6.89k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
6.89k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE36EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
1.19k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
1.19k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
1.19k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
1.19k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE37EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
1.09k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
1.09k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
1.09k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
1.09k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE2EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
25.4k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
25.4k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
25.4k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
25.4k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE8EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
15.6k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
15.6k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
15.6k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
15.6k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE9EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
31.5k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
31.5k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
31.5k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
31.5k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE31EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
204k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
204k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
204k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
204k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE16EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
338
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
338
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
338
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
338
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE18EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
6.38k
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
6.38k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
6.38k
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
6.38k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE22EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
636
36
void Field::assign_concrete(typename PrimitiveTypeTraits<Type>::CppType&& x) {
637
36
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
638
36
    *ptr = std::forward<typename PrimitiveTypeTraits<Type>::CppType>(x);
639
36
}
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE27EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE38EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE39EEEvONS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
640
641
template <PrimitiveType Type>
642
1.76M
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
1.76M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
1.76M
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
1.76M
}
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE21EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE1EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
218k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
218k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
218k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
218k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE3EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
87.2k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
87.2k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
87.2k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
87.2k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE4EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
23.9k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
23.9k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
23.9k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
23.9k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE5EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
197k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
197k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
197k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
197k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE6EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
337k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
337k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
337k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
337k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE7EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
32.1k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
32.1k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
32.1k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
32.1k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE11EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
387
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
387
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
387
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
387
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE12EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
715
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
715
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
715
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
715
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE25EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
58.4k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
58.4k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
58.4k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
58.4k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE26EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
74.4k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
74.4k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
74.4k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
74.4k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE42EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
6.69k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
6.69k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
6.69k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
6.69k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE28EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
14.9k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
14.9k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
14.9k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
14.9k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE29EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
20.8k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
20.8k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
20.8k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
20.8k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE20EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
138
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
138
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
138
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
138
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE30EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
19.1k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
19.1k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
19.1k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
19.1k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE35EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
1.08k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
1.08k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
1.08k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
1.08k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE15EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
27.1k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
27.1k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
27.1k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
27.1k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE10EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
367k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
367k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
367k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
367k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE23EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
175k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
175k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
175k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
175k
}
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE41EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE19EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
1
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
1
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
1
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
1
}
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE32EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE24EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
1
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
1
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
1
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
1
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE17EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
38.4k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
38.4k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
38.4k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
38.4k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE36EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
1.24k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
1.24k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
1.24k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
1.24k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE37EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
1.06k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
1.06k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
1.06k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
1.06k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE2EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
20.4k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
20.4k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
20.4k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
20.4k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE8EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
14.5k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
14.5k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
14.5k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
14.5k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE9EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
28.0k
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
28.0k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
28.0k
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
28.0k
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE31EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
22
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
22
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
22
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
22
}
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE16EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE18EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
1
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
1
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
1
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
1
}
_ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE22EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Line
Count
Source
642
2
void Field::assign_concrete(const typename PrimitiveTypeTraits<Type>::CppType& x) {
643
2
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<Type>::CppType*>(&storage);
644
2
    *ptr = std::forward<const typename PrimitiveTypeTraits<Type>::CppType>(x);
645
2
}
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE27EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE38EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
Unexecuted instantiation: _ZN5doris5Field15assign_concreteILNS_13PrimitiveTypeE39EEEvRKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeE
646
647
159
std::string Field::get_type_name() const {
648
159
    return type_to_string(type);
649
159
}
650
651
template <PrimitiveType T>
652
224M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
224M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
224M
    return *ptr;
657
224M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE1EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
31.1M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
31.1M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
31.1M
    return *ptr;
657
31.1M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE3EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
7.87M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
7.87M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
2.18k
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
7.87M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
7.87M
    return *ptr;
657
7.87M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE4EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
204k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
204k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
204k
    return *ptr;
657
204k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE5EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
75.4M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
75.4M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
75.4M
    return *ptr;
657
75.4M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE6EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
35.4M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
35.4M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
35.4M
    return *ptr;
657
35.4M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE7EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
242k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
242k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
242k
    return *ptr;
657
242k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE11EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
23.5k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
23.5k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
23.5k
    return *ptr;
657
23.5k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE12EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
31.1k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
31.1k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
31.1k
    return *ptr;
657
31.1k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE25EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
674k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
674k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
674k
    return *ptr;
657
674k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE26EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
3.71M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
3.71M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
230
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
3.71M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
3.71M
    return *ptr;
657
3.71M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE42EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
46.8k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
46.8k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
46.8k
    return *ptr;
657
46.8k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE28EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
89.0k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
89.0k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
89.0k
    return *ptr;
657
89.0k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE29EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
209k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
209k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
209k
    return *ptr;
657
209k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE20EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
9.50k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
9.50k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
9.50k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
9.50k
    return *ptr;
657
9.50k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE30EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
166k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
166k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
166k
    return *ptr;
657
166k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE35EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
52.3k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
52.3k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
52.3k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
52.3k
    return *ptr;
657
52.3k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE15EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
142k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
142k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
142k
    return *ptr;
657
142k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE10EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
2.21M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
2.21M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
431
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
2.21M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
2.21M
    return *ptr;
657
2.21M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE23EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
49.1M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
49.1M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
49.1M
    return *ptr;
657
49.1M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE41EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
58
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
58
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
58
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
58
    return *ptr;
657
58
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE19EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
4
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
4
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
4
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
4
    return *ptr;
657
4
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE32EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
491k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
491k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
491k
    return *ptr;
657
491k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE24EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
2
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
2
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
2
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
2
    return *ptr;
657
2
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE17EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
7.69M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
7.69M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
7.69M
    return *ptr;
657
7.69M
}
Unexecuted instantiation: _ZN5doris5Field3getILNS_13PrimitiveTypeE21EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
_ZN5doris5Field3getILNS_13PrimitiveTypeE36EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
45.2k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
45.2k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
1
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
45.2k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
45.2k
    return *ptr;
657
45.2k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE37EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
33.1k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
33.1k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
33.1k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
33.1k
    return *ptr;
657
33.1k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE2EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
1.21M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
1.21M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
39
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
1.21M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
1.21M
    return *ptr;
657
1.21M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE8EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
128k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
128k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
128k
    return *ptr;
657
128k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE9EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
3.78M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
3.78M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
3.78M
    return *ptr;
657
3.78M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE31EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
4.03M
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
4.03M
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
4.03M
    return *ptr;
657
4.03M
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE16EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
15.1k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
15.1k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
15.1k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
15.1k
    return *ptr;
657
15.1k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE18EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
36.3k
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
36.3k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
6
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
36.3k
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
36.3k
    return *ptr;
657
36.3k
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE22EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
204
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
204
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
204
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
204
    return *ptr;
657
204
}
_ZN5doris5Field3getILNS_13PrimitiveTypeE27EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
652
125
typename PrimitiveTypeTraits<T>::CppType& Field::get() {
653
125
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
654
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
655
125
    auto* MAY_ALIAS ptr = reinterpret_cast<typename PrimitiveTypeTraits<T>::CppType*>(&storage);
656
125
    return *ptr;
657
125
}
Unexecuted instantiation: _ZN5doris5Field3getILNS_13PrimitiveTypeE38EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Unexecuted instantiation: _ZN5doris5Field3getILNS_13PrimitiveTypeE39EEERNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
658
659
template <PrimitiveType T>
660
500M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
500M
    const auto* MAY_ALIAS ptr =
664
500M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
500M
    return *ptr;
666
500M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE1EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
40.2M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
40.2M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
512
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
40.2M
    const auto* MAY_ALIAS ptr =
664
40.2M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
40.2M
    return *ptr;
666
40.2M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE3EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
12.4M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
12.4M
    const auto* MAY_ALIAS ptr =
664
12.4M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
12.4M
    return *ptr;
666
12.4M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE4EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
5.18M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
5.18M
    const auto* MAY_ALIAS ptr =
664
5.18M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
5.18M
    return *ptr;
666
5.18M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE5EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
8.85M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
8.85M
    const auto* MAY_ALIAS ptr =
664
8.85M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
8.85M
    return *ptr;
666
8.85M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE6EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
50.0M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
50.0M
    const auto* MAY_ALIAS ptr =
664
50.0M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
50.0M
    return *ptr;
666
50.0M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE7EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
4.61M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
4.61M
    const auto* MAY_ALIAS ptr =
664
4.61M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
4.61M
    return *ptr;
666
4.61M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE11EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
4.42M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
4.42M
    const auto* MAY_ALIAS ptr =
664
4.42M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
4.42M
    return *ptr;
666
4.42M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE12EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
4.33M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
4.33M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
4.33M
    const auto* MAY_ALIAS ptr =
664
4.33M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
4.33M
    return *ptr;
666
4.33M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE25EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
8.79M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
8.79M
    const auto* MAY_ALIAS ptr =
664
8.79M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
8.79M
    return *ptr;
666
8.79M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE26EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
5.47M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
5.47M
    const auto* MAY_ALIAS ptr =
664
5.47M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
5.47M
    return *ptr;
666
5.47M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE42EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
106k
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
106k
    const auto* MAY_ALIAS ptr =
664
106k
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
106k
    return *ptr;
666
106k
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE28EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
4.65M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
4.65M
    const auto* MAY_ALIAS ptr =
664
4.65M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
4.65M
    return *ptr;
666
4.65M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE29EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
18.2M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.2M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
18.2M
    const auto* MAY_ALIAS ptr =
664
18.2M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
18.2M
    return *ptr;
666
18.2M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE20EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
17.9k
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
17.9k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
17.9k
    const auto* MAY_ALIAS ptr =
664
17.9k
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
17.9k
    return *ptr;
666
17.9k
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE30EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
4.60M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
4.60M
    const auto* MAY_ALIAS ptr =
664
4.60M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
4.60M
    return *ptr;
666
4.60M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE35EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
4.69M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
4.69M
    const auto* MAY_ALIAS ptr =
664
4.69M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
4.69M
    return *ptr;
666
4.69M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE15EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
103k
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
103k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
103k
    const auto* MAY_ALIAS ptr =
664
103k
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
103k
    return *ptr;
666
103k
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE10EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
18.6M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
18.6M
    const auto* MAY_ALIAS ptr =
664
18.6M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
18.6M
    return *ptr;
666
18.6M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE23EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
96.7M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
96.7M
    const auto* MAY_ALIAS ptr =
664
96.7M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
96.7M
    return *ptr;
666
96.7M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE41EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
58
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
58
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
58
    const auto* MAY_ALIAS ptr =
664
58
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
58
    return *ptr;
666
58
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE19EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
18
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
18
    const auto* MAY_ALIAS ptr =
664
18
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
18
    return *ptr;
666
18
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE32EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
229k
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
229k
    const auto* MAY_ALIAS ptr =
664
229k
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
229k
    return *ptr;
666
229k
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE24EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
20.0k
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
20.0k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
20.0k
    const auto* MAY_ALIAS ptr =
664
20.0k
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
20.0k
    return *ptr;
666
20.0k
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE17EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
127M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
127M
    const auto* MAY_ALIAS ptr =
664
127M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
127M
    return *ptr;
666
127M
}
Unexecuted instantiation: _ZNK5doris5Field3getILNS_13PrimitiveTypeE21EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
_ZNK5doris5Field3getILNS_13PrimitiveTypeE36EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
39.9k
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
39.9k
    const auto* MAY_ALIAS ptr =
664
39.9k
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
39.9k
    return *ptr;
666
39.9k
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE37EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
38.5k
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
38.5k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
38.5k
    const auto* MAY_ALIAS ptr =
664
38.5k
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
38.5k
    return *ptr;
666
38.5k
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE2EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
35.1M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
35.1M
    const auto* MAY_ALIAS ptr =
664
35.1M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
35.1M
    return *ptr;
666
35.1M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE8EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
4.57M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
4.57M
    const auto* MAY_ALIAS ptr =
664
4.57M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
4.57M
    return *ptr;
666
4.57M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE9EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
13.9M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
18.4E
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
13.9M
    const auto* MAY_ALIAS ptr =
664
13.9M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
13.9M
    return *ptr;
666
13.9M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE31EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
5.14M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
5.14M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
231
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
5.14M
    const auto* MAY_ALIAS ptr =
664
5.14M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
5.14M
    return *ptr;
666
5.14M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE16EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
4.05M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
4.05M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
4.05M
    const auto* MAY_ALIAS ptr =
664
4.05M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
4.05M
    return *ptr;
666
4.05M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE18EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
17.2M
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
17.2M
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
17.2M
    const auto* MAY_ALIAS ptr =
664
17.2M
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
17.2M
    return *ptr;
666
17.2M
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE22EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
17.5k
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
17.5k
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
17.5k
    const auto* MAY_ALIAS ptr =
664
17.5k
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
17.5k
    return *ptr;
666
17.5k
}
_ZNK5doris5Field3getILNS_13PrimitiveTypeE27EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
214
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
214
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
214
    const auto* MAY_ALIAS ptr =
664
214
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
214
    return *ptr;
666
214
}
Unexecuted instantiation: _ZNK5doris5Field3getILNS_13PrimitiveTypeE38EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
_ZNK5doris5Field3getILNS_13PrimitiveTypeE39EEERKNS_19PrimitiveTypeTraitsIXT_EE7CppTypeEv
Line
Count
Source
660
40
const typename PrimitiveTypeTraits<T>::CppType& Field::get() const {
661
40
    DCHECK(T == type || (is_string_type(type) && is_string_type(T)) || type == TYPE_NULL)
662
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
663
40
    const auto* MAY_ALIAS ptr =
664
40
            reinterpret_cast<const typename PrimitiveTypeTraits<T>::CppType*>(&storage);
665
40
    return *ptr;
666
40
}
667
668
template <PrimitiveType T>
669
247M
void Field::destroy() {
670
247M
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
18.4E
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
247M
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
247M
    ptr->~TargetType();
675
247M
}
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE1EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE3EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE4EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE5EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE6EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE7EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE11EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE12EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE25EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE26EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE42EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE28EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE29EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE20EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE30EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE35EEEvv
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE15EEEvv
Line
Count
Source
669
180k
void Field::destroy() {
670
180k
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
180k
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
2
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
180k
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
180k
    ptr->~TargetType();
675
180k
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE10EEEvv
Line
Count
Source
669
15.9M
void Field::destroy() {
670
15.9M
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
18.4E
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
15.9M
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
15.9M
    ptr->~TargetType();
675
15.9M
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE23EEEvv
Line
Count
Source
669
103M
void Field::destroy() {
670
103M
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
18.4E
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
103M
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
103M
    ptr->~TargetType();
675
103M
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE41EEEvv
Line
Count
Source
669
104
void Field::destroy() {
670
104
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
104
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
104
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
104
    ptr->~TargetType();
675
104
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE19EEEvv
Line
Count
Source
669
430
void Field::destroy() {
670
430
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
430
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
430
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
430
    ptr->~TargetType();
675
430
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE32EEEvv
Line
Count
Source
669
558k
void Field::destroy() {
670
558k
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
18.4E
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
558k
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
558k
    ptr->~TargetType();
675
558k
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE24EEEvv
Line
Count
Source
669
22.4k
void Field::destroy() {
670
22.4k
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
22.4k
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
22.4k
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
22.4k
    ptr->~TargetType();
675
22.4k
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE17EEEvv
Line
Count
Source
669
101M
void Field::destroy() {
670
101M
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
18.4E
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
101M
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
101M
    ptr->~TargetType();
675
101M
}
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE21EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE36EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE37EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE2EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE8EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE9EEEvv
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE31EEEvv
Line
Count
Source
669
9.50M
void Field::destroy() {
670
9.50M
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
18.4E
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
9.50M
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
9.50M
    ptr->~TargetType();
675
9.50M
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE16EEEvv
Line
Count
Source
669
3.06M
void Field::destroy() {
670
3.06M
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
3.06M
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
3.06M
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
3.06M
    ptr->~TargetType();
675
3.06M
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE18EEEvv
Line
Count
Source
669
13.2M
void Field::destroy() {
670
13.2M
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
18.4E
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
18.4E
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
13.2M
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
13.2M
    ptr->~TargetType();
675
13.2M
}
_ZN5doris5Field7destroyILNS_13PrimitiveTypeE22EEEvv
Line
Count
Source
669
2.55k
void Field::destroy() {
670
2.55k
    using TargetType = typename PrimitiveTypeTraits<T>::CppType;
671
2.55k
    DCHECK(T == type || ((is_string_type(type) && is_string_type(T))))
672
0
            << "Type mismatch: requested " << type_to_string(T) << ", actual " << get_type_name();
673
2.55k
    auto* MAY_ALIAS ptr = reinterpret_cast<TargetType*>(&storage);
674
2.55k
    ptr->~TargetType();
675
2.55k
}
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE27EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE38EEEvv
Unexecuted instantiation: _ZN5doris5Field7destroyILNS_13PrimitiveTypeE39EEEvv
676
677
35.2M
std::strong_ordering Field::operator<=>(const Field& rhs) const {
678
35.2M
    if (type == PrimitiveType::TYPE_NULL || rhs == PrimitiveType::TYPE_NULL) {
679
23.5M
        return type <=> rhs.type;
680
23.5M
    }
681
11.6M
    if (type != rhs.type) {
682
        // String-family types (STRING, CHAR, VARCHAR) all store String internally
683
        // and are inter-comparable.  This arises when comparing RowCursor fields
684
        // (which carry the declared column type) against Column::operator[] results
685
        // (which always return TYPE_STRING for ColumnString).
686
13.5k
        if (is_string_type(type) && is_string_type(rhs.type)) {
687
13.5k
            return get<TYPE_STRING>() <=> rhs.get<TYPE_STRING>();
688
13.5k
        }
689
1
        throw Exception(Status::FatalError("lhs type not equal with rhs, lhs={}, rhs={}",
690
1
                                           get_type_name(), rhs.get_type_name()));
691
13.5k
    }
692
693
11.6M
    switch (type) {
694
1.14k
    case PrimitiveType::TYPE_BITMAP:
695
1.35k
    case PrimitiveType::TYPE_HLL:
696
2.54k
    case PrimitiveType::TYPE_QUANTILE_STATE:
697
2.54k
    case PrimitiveType::INVALID_TYPE:
698
2.55k
    case PrimitiveType::TYPE_JSONB:
699
2.55k
    case PrimitiveType::TYPE_NULL:
700
9.12k
    case PrimitiveType::TYPE_ARRAY:
701
10.0k
    case PrimitiveType::TYPE_MAP:
702
10.7k
    case PrimitiveType::TYPE_STRUCT:
703
44.1k
    case PrimitiveType::TYPE_VARIANT:
704
44.1k
        return std::strong_ordering::equal; //TODO: throw Exception?
705
36.5k
    case PrimitiveType::TYPE_DATETIMEV2:
706
36.5k
        return get<PrimitiveType::TYPE_DATETIMEV2>().to_date_int_val() <=>
707
36.5k
               rhs.get<PrimitiveType::TYPE_DATETIMEV2>().to_date_int_val();
708
723k
    case PrimitiveType::TYPE_DATEV2:
709
723k
        return get<PrimitiveType::TYPE_DATEV2>().to_date_int_val() <=>
710
723k
               rhs.get<PrimitiveType::TYPE_DATEV2>().to_date_int_val();
711
7.39k
    case PrimitiveType::TYPE_TIMESTAMPTZ:
712
7.39k
        return get<PrimitiveType::TYPE_TIMESTAMPTZ>().to_date_int_val() <=>
713
7.39k
               rhs.get<PrimitiveType::TYPE_TIMESTAMPTZ>().to_date_int_val();
714
5.29k
    case PrimitiveType::TYPE_DATE:
715
5.29k
        return get<PrimitiveType::TYPE_DATE>() <=> rhs.get<PrimitiveType::TYPE_DATE>();
716
620
    case PrimitiveType::TYPE_DATETIME:
717
620
        return get<PrimitiveType::TYPE_DATETIME>() <=> rhs.get<PrimitiveType::TYPE_DATETIME>();
718
958k
    case PrimitiveType::TYPE_BIGINT:
719
958k
        return get<PrimitiveType::TYPE_BIGINT>() <=> rhs.get<PrimitiveType::TYPE_BIGINT>();
720
341k
    case PrimitiveType::TYPE_BOOLEAN:
721
341k
        return get<PrimitiveType::TYPE_BOOLEAN>() <=> rhs.get<PrimitiveType::TYPE_BOOLEAN>();
722
481k
    case PrimitiveType::TYPE_TINYINT:
723
481k
        return get<TYPE_TINYINT>() <=> rhs.get<TYPE_TINYINT>();
724
14.3k
    case PrimitiveType::TYPE_SMALLINT:
725
14.3k
        return get<TYPE_SMALLINT>() <=> rhs.get<TYPE_SMALLINT>();
726
1.97M
    case PrimitiveType::TYPE_INT:
727
1.97M
        return get<TYPE_INT>() <=> rhs.get<TYPE_INT>();
728
25.2k
    case PrimitiveType::TYPE_LARGEINT:
729
25.2k
        return get<TYPE_LARGEINT>() <=> rhs.get<TYPE_LARGEINT>();
730
5.34k
    case PrimitiveType::TYPE_IPV6:
731
5.34k
        return get<TYPE_IPV6>() <=> rhs.get<TYPE_IPV6>();
732
419
    case PrimitiveType::TYPE_IPV4:
733
419
        return get<TYPE_IPV4>() <=> rhs.get<TYPE_IPV4>();
734
1.11k
    case PrimitiveType::TYPE_FLOAT:
735
1.11k
        switch (Compare::compare(get<TYPE_FLOAT>(), rhs.get<TYPE_FLOAT>())) {
736
405
        case -1:
737
405
            return std::strong_ordering::less;
738
229
        case 0:
739
229
            return std::strong_ordering::equal;
740
482
        case 1:
741
482
            return std::strong_ordering::greater;
742
0
        default:
743
0
            LOG(FATAL) << "unexpected float compare result";
744
1.11k
        }
745
14
    case PrimitiveType::TYPE_TIMEV2:
746
14
        return get<TYPE_TIMEV2>() < rhs.get<TYPE_TIMEV2>()    ? std::strong_ordering::less
747
14
               : get<TYPE_TIMEV2>() == rhs.get<TYPE_TIMEV2>() ? std::strong_ordering::equal
748
14
                                                              : std::strong_ordering::greater;
749
4.38k
    case PrimitiveType::TYPE_DOUBLE:
750
4.38k
        switch (Compare::compare(get<TYPE_DOUBLE>(), rhs.get<TYPE_DOUBLE>())) {
751
455
        case -1:
752
455
            return std::strong_ordering::less;
753
3.45k
        case 0:
754
3.45k
            return std::strong_ordering::equal;
755
469
        case 1:
756
469
            return std::strong_ordering::greater;
757
0
        default:
758
0
            LOG(FATAL) << "unexpected double compare result";
759
4.38k
        }
760
4.30M
    case PrimitiveType::TYPE_STRING:
761
4.30M
        return get<TYPE_STRING>() <=> rhs.get<TYPE_STRING>();
762
28.0k
    case PrimitiveType::TYPE_CHAR:
763
28.0k
        return get<TYPE_CHAR>() <=> rhs.get<TYPE_CHAR>();
764
2.78M
    case PrimitiveType::TYPE_VARCHAR:
765
2.78M
        return get<TYPE_VARCHAR>() <=> rhs.get<TYPE_VARCHAR>();
766
0
    case PrimitiveType::TYPE_VARBINARY:
767
0
        return get<TYPE_VARBINARY>() <=> rhs.get<TYPE_VARBINARY>();
768
1.33k
    case PrimitiveType::TYPE_DECIMAL32:
769
1.33k
        return get<TYPE_DECIMAL32>() <=> rhs.get<TYPE_DECIMAL32>();
770
30.3k
    case PrimitiveType::TYPE_DECIMAL64:
771
30.3k
        return get<TYPE_DECIMAL64>() <=> rhs.get<TYPE_DECIMAL64>();
772
2.74k
    case PrimitiveType::TYPE_DECIMALV2:
773
2.74k
        return get<TYPE_DECIMALV2>() <=> rhs.get<TYPE_DECIMALV2>();
774
5.05k
    case PrimitiveType::TYPE_DECIMAL128I:
775
5.05k
        return get<TYPE_DECIMAL128I>() <=> rhs.get<TYPE_DECIMAL128I>();
776
2.15k
    case PrimitiveType::TYPE_DECIMAL256:
777
2.15k
        return get<TYPE_DECIMAL256>() <=> rhs.get<TYPE_DECIMAL256>();
778
0
    default:
779
0
        throw Exception(Status::FatalError("Unsupported type: {}", get_type_name()));
780
11.6M
    }
781
11.6M
}
782
783
#define MATCH_PRIMITIVE_TYPE(primitive_type)                                   \
784
4.46k
    if (type == primitive_type) {                                              \
785
847
        const auto& v = get<primitive_type>();                                 \
786
847
        return std::string_view(reinterpret_cast<const char*>(&v), sizeof(v)); \
787
847
    }
788
789
1.30k
std::string_view Field::as_string_view() const {
790
1.30k
    if (type == PrimitiveType::TYPE_STRING || type == PrimitiveType::TYPE_VARCHAR ||
791
1.30k
        type == PrimitiveType::TYPE_CHAR) {
792
460
        const auto& s = get<TYPE_STRING>();
793
460
        return {s.data(), s.size()};
794
460
    }
795
846
    if (type == PrimitiveType::TYPE_VARBINARY) {
796
0
        const auto& svf = get<TYPE_VARBINARY>();
797
0
        return {svf.data(), svf.size()};
798
0
    }
799
    // MATCH_PRIMITIVE_TYPE(INVALID_TYPE);
800
    // MATCH_PRIMITIVE_TYPE(TYPE_NULL);
801
846
    MATCH_PRIMITIVE_TYPE(TYPE_BOOLEAN);
802
846
    MATCH_PRIMITIVE_TYPE(TYPE_TINYINT);
803
832
    MATCH_PRIMITIVE_TYPE(TYPE_SMALLINT);
804
832
    MATCH_PRIMITIVE_TYPE(TYPE_INT);
805
160
    MATCH_PRIMITIVE_TYPE(TYPE_BIGINT);
806
96
    MATCH_PRIMITIVE_TYPE(TYPE_LARGEINT);
807
96
    MATCH_PRIMITIVE_TYPE(TYPE_FLOAT)
808
96
    MATCH_PRIMITIVE_TYPE(TYPE_DOUBLE);
809
    // MATCH_PRIMITIVE_TYPE(TYPE_VARCHAR);
810
96
    MATCH_PRIMITIVE_TYPE(TYPE_DATE);
811
96
    MATCH_PRIMITIVE_TYPE(TYPE_DATETIME);
812
96
    MATCH_PRIMITIVE_TYPE(TYPE_TIMESTAMPTZ);
813
    // MATCH_PRIMITIVE_TYPE(TYPE_BINARY);
814
    // MATCH_PRIMITIVE_TYPE(TYPE_DECIMAL);
815
    // MATCH_PRIMITIVE_TYPE(TYPE_CHAR);
816
    // MATCH_PRIMITIVE_TYPE(TYPE_STRUCT);
817
    // MATCH_PRIMITIVE_TYPE(TYPE_ARRAY);
818
    // MATCH_PRIMITIVE_TYPE(TYPE_MAP);
819
    // MATCH_PRIMITIVE_TYPE(TYPE_HLL);
820
96
    MATCH_PRIMITIVE_TYPE(TYPE_DECIMALV2);
821
96
    MATCH_PRIMITIVE_TYPE(TYPE_TIME);
822
    // MATCH_PRIMITIVE_TYPE(TYPE_BITMAP);
823
    // MATCH_PRIMITIVE_TYPE(TYPE_STRING);
824
    // MATCH_PRIMITIVE_TYPE(TYPE_QUANTILE_STATE);
825
96
    MATCH_PRIMITIVE_TYPE(TYPE_DATEV2);
826
68
    MATCH_PRIMITIVE_TYPE(TYPE_DATETIMEV2);
827
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_TIMEV2);
828
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_DECIMAL32);
829
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_DECIMAL64);
830
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_DECIMAL128I);
831
    // MATCH_PRIMITIVE_TYPE(TYPE_JSONB);
832
    // MATCH_PRIMITIVE_TYPE(TYPE_VARIANT);
833
    // MATCH_PRIMITIVE_TYPE(TYPE_LAMBDA_FUNCTION);
834
    // MATCH_PRIMITIVE_TYPE(TYPE_AGG_STATE);
835
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_DECIMAL256);
836
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_IPV4);
837
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_IPV6);
838
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_UINT32);
839
18.4E
    MATCH_PRIMITIVE_TYPE(TYPE_UINT64);
840
    // MATCH_PRIMITIVE_TYPE(TYPE_FIXED_LENGTH_OBJECT);
841
18.4E
    throw Exception(
842
18.4E
            Status::FatalError("type not supported for as_string_view, type={}", get_type_name()));
843
18.4E
}
844
845
#undef MATCH_PRIMITIVE_TYPE
846
847
// Important!!! This method is not accurate, for example, decimal to string, it uses scale == 0, because
848
// it do not know the actual scale of the decimal value. It is only used for debug printing, so it is fine.
849
24.4M
std::string Field::to_debug_string(int scale) const {
850
24.4M
    if (is_null()) {
851
0
        return "NULL";
852
0
    }
853
24.4M
    switch (type) {
854
8.25k
    case PrimitiveType::TYPE_BOOLEAN:
855
8.25k
        return get<TYPE_BOOLEAN>() ? "true" : "false";
856
1.25M
    case PrimitiveType::TYPE_TINYINT:
857
1.25M
        return CastToString::from_number(get<TYPE_TINYINT>());
858
29.5k
    case PrimitiveType::TYPE_SMALLINT:
859
29.5k
        return CastToString::from_number(get<TYPE_SMALLINT>());
860
835k
    case PrimitiveType::TYPE_INT:
861
835k
        return CastToString::from_number(get<TYPE_INT>());
862
387k
    case PrimitiveType::TYPE_BIGINT:
863
387k
        return CastToString::from_number(get<TYPE_BIGINT>());
864
56.0k
    case PrimitiveType::TYPE_LARGEINT:
865
56.0k
        return CastToString::from_number(get<TYPE_LARGEINT>());
866
0
    case PrimitiveType::TYPE_FLOAT:
867
0
        return CastToString::from_number(get<TYPE_FLOAT>());
868
0
    case PrimitiveType::TYPE_DOUBLE:
869
0
        return CastToString::from_number(get<TYPE_DOUBLE>());
870
0
    case PrimitiveType::TYPE_STRING:
871
2.37k
    case PrimitiveType::TYPE_CHAR:
872
20.9M
    case PrimitiveType::TYPE_VARCHAR:
873
20.9M
        return get<TYPE_STRING>();
874
0
    case PrimitiveType::TYPE_VARBINARY:
875
0
        return get<TYPE_VARBINARY>();
876
11.8k
    case PrimitiveType::TYPE_DATE:
877
11.8k
        return CastToString::from_date_or_datetime(get<TYPE_DATE>());
878
56
    case PrimitiveType::TYPE_DATETIME:
879
56
        return CastToString::from_date_or_datetime(get<TYPE_DATETIME>());
880
896k
    case PrimitiveType::TYPE_DATEV2:
881
896k
        return CastToString::from_datev2(get<TYPE_DATEV2>());
882
14.1k
    case PrimitiveType::TYPE_DATETIMEV2:
883
14.1k
        return CastToString::from_datetimev2(get<TYPE_DATETIMEV2>(), scale);
884
22.7k
    case PrimitiveType::TYPE_TIMESTAMPTZ:
885
22.7k
        return CastToString::from_timestamptz(get<TYPE_TIMESTAMPTZ>(), scale);
886
563
    case PrimitiveType::TYPE_DECIMALV2:
887
563
        return get<TYPE_DECIMALV2>().to_string();
888
1.44k
    case PrimitiveType::TYPE_DECIMAL32:
889
1.44k
        return CastToString::from_decimal(get<TYPE_DECIMAL32>(), scale);
890
2.56k
    case PrimitiveType::TYPE_DECIMAL64:
891
2.56k
        return CastToString::from_decimal(get<TYPE_DECIMAL64>(), scale);
892
4.16k
    case PrimitiveType::TYPE_DECIMAL128I:
893
4.16k
        return CastToString::from_decimal(get<TYPE_DECIMAL128I>(), scale);
894
1.57k
    case PrimitiveType::TYPE_DECIMAL256:
895
1.57k
        return CastToString::from_decimal(get<TYPE_DECIMAL256>(), scale);
896
0
    case PrimitiveType::TYPE_IPV4:
897
0
        return CastToString::from_ip(get<TYPE_IPV4>());
898
2
    case PrimitiveType::TYPE_IPV6:
899
2
        return CastToString::from_ip(get<TYPE_IPV6>());
900
0
    default:
901
0
        throw Exception(Status::FatalError("type not supported for to_debug_string, type={}",
902
0
                                           get_type_name()));
903
0
        __builtin_unreachable();
904
24.4M
    }
905
24.4M
}
906
907
#define DECLARE_FUNCTION(FUNC_NAME)                                                               \
908
    template void Field::FUNC_NAME<TYPE_NULL>(typename PrimitiveTypeTraits<TYPE_NULL>::CppType && \
909
                                              rhs);                                               \
910
    template void Field::FUNC_NAME<TYPE_TINYINT>(                                                 \
911
            typename PrimitiveTypeTraits<TYPE_TINYINT>::CppType && rhs);                          \
912
    template void Field::FUNC_NAME<TYPE_SMALLINT>(                                                \
913
            typename PrimitiveTypeTraits<TYPE_SMALLINT>::CppType && rhs);                         \
914
    template void Field::FUNC_NAME<TYPE_INT>(typename PrimitiveTypeTraits<TYPE_INT>::CppType &&   \
915
                                             rhs);                                                \
916
    template void Field::FUNC_NAME<TYPE_BIGINT>(                                                  \
917
            typename PrimitiveTypeTraits<TYPE_BIGINT>::CppType && rhs);                           \
918
    template void Field::FUNC_NAME<TYPE_LARGEINT>(                                                \
919
            typename PrimitiveTypeTraits<TYPE_LARGEINT>::CppType && rhs);                         \
920
    template void Field::FUNC_NAME<TYPE_DATE>(typename PrimitiveTypeTraits<TYPE_DATE>::CppType && \
921
                                              rhs);                                               \
922
    template void Field::FUNC_NAME<TYPE_DATETIME>(                                                \
923
            typename PrimitiveTypeTraits<TYPE_DATETIME>::CppType && rhs);                         \
924
    template void Field::FUNC_NAME<TYPE_DATEV2>(                                                  \
925
            typename PrimitiveTypeTraits<TYPE_DATEV2>::CppType && rhs);                           \
926
    template void Field::FUNC_NAME<TYPE_DATETIMEV2>(                                              \
927
            typename PrimitiveTypeTraits<TYPE_DATETIMEV2>::CppType && rhs);                       \
928
    template void Field::FUNC_NAME<TYPE_DECIMAL32>(                                               \
929
            typename PrimitiveTypeTraits<TYPE_DECIMAL32>::CppType && rhs);                        \
930
    template void Field::FUNC_NAME<TYPE_DECIMAL64>(                                               \
931
            typename PrimitiveTypeTraits<TYPE_DECIMAL64>::CppType && rhs);                        \
932
    template void Field::FUNC_NAME<TYPE_DECIMALV2>(                                               \
933
            typename PrimitiveTypeTraits<TYPE_DECIMALV2>::CppType && rhs);                        \
934
    template void Field::FUNC_NAME<TYPE_DECIMAL128I>(                                             \
935
            typename PrimitiveTypeTraits<TYPE_DECIMAL128I>::CppType && rhs);                      \
936
    template void Field::FUNC_NAME<TYPE_DECIMAL256>(                                              \
937
            typename PrimitiveTypeTraits<TYPE_DECIMAL256>::CppType && rhs);                       \
938
    template void Field::FUNC_NAME<TYPE_CHAR>(typename PrimitiveTypeTraits<TYPE_CHAR>::CppType && \
939
                                              rhs);                                               \
940
    template void Field::FUNC_NAME<TYPE_VARCHAR>(                                                 \
941
            typename PrimitiveTypeTraits<TYPE_VARCHAR>::CppType && rhs);                          \
942
    template void Field::FUNC_NAME<TYPE_STRING>(                                                  \
943
            typename PrimitiveTypeTraits<TYPE_STRING>::CppType && rhs);                           \
944
    template void Field::FUNC_NAME<TYPE_VARBINARY>(                                               \
945
            typename PrimitiveTypeTraits<TYPE_VARBINARY>::CppType && rhs);                        \
946
    template void Field::FUNC_NAME<TYPE_HLL>(typename PrimitiveTypeTraits<TYPE_HLL>::CppType &&   \
947
                                             rhs);                                                \
948
    template void Field::FUNC_NAME<TYPE_VARIANT>(                                                 \
949
            typename PrimitiveTypeTraits<TYPE_VARIANT>::CppType && rhs);                          \
950
    template void Field::FUNC_NAME<TYPE_QUANTILE_STATE>(                                          \
951
            typename PrimitiveTypeTraits<TYPE_QUANTILE_STATE>::CppType && rhs);                   \
952
    template void Field::FUNC_NAME<TYPE_ARRAY>(                                                   \
953
            typename PrimitiveTypeTraits<TYPE_ARRAY>::CppType && rhs);                            \
954
    template void Field::FUNC_NAME<TYPE_TIME>(typename PrimitiveTypeTraits<TYPE_TIME>::CppType && \
955
                                              rhs);                                               \
956
    template void Field::FUNC_NAME<TYPE_TIME>(                                                    \
957
            const typename PrimitiveTypeTraits<TYPE_TIME>::CppType& rhs);                         \
958
    template void Field::FUNC_NAME<TYPE_NULL>(                                                    \
959
            const typename PrimitiveTypeTraits<TYPE_NULL>::CppType& rhs);                         \
960
    template void Field::FUNC_NAME<TYPE_TINYINT>(                                                 \
961
            const typename PrimitiveTypeTraits<TYPE_TINYINT>::CppType& rhs);                      \
962
    template void Field::FUNC_NAME<TYPE_SMALLINT>(                                                \
963
            const typename PrimitiveTypeTraits<TYPE_SMALLINT>::CppType& rhs);                     \
964
    template void Field::FUNC_NAME<TYPE_INT>(                                                     \
965
            const typename PrimitiveTypeTraits<TYPE_INT>::CppType& rhs);                          \
966
    template void Field::FUNC_NAME<TYPE_BIGINT>(                                                  \
967
            const typename PrimitiveTypeTraits<TYPE_BIGINT>::CppType& rhs);                       \
968
    template void Field::FUNC_NAME<TYPE_LARGEINT>(                                                \
969
            const typename PrimitiveTypeTraits<TYPE_LARGEINT>::CppType& rhs);                     \
970
    template void Field::FUNC_NAME<TYPE_DATE>(                                                    \
971
            const typename PrimitiveTypeTraits<TYPE_DATE>::CppType& rhs);                         \
972
    template void Field::FUNC_NAME<TYPE_DATETIME>(                                                \
973
            const typename PrimitiveTypeTraits<TYPE_DATETIME>::CppType& rhs);                     \
974
    template void Field::FUNC_NAME<TYPE_DATEV2>(                                                  \
975
            const typename PrimitiveTypeTraits<TYPE_DATEV2>::CppType& rhs);                       \
976
    template void Field::FUNC_NAME<TYPE_DATETIMEV2>(                                              \
977
            const typename PrimitiveTypeTraits<TYPE_DATETIMEV2>::CppType& rhs);                   \
978
    template void Field::FUNC_NAME<TYPE_TIMESTAMPTZ>(                                             \
979
            const typename PrimitiveTypeTraits<TYPE_TIMESTAMPTZ>::CppType& rhs);                  \
980
    template void Field::FUNC_NAME<TYPE_TIMESTAMPTZ>(                                             \
981
            typename PrimitiveTypeTraits<TYPE_TIMESTAMPTZ>::CppType && rhs);                      \
982
    template void Field::FUNC_NAME<TYPE_DECIMAL32>(                                               \
983
            const typename PrimitiveTypeTraits<TYPE_DECIMAL32>::CppType& rhs);                    \
984
    template void Field::FUNC_NAME<TYPE_DECIMAL64>(                                               \
985
            const typename PrimitiveTypeTraits<TYPE_DECIMAL64>::CppType& rhs);                    \
986
    template void Field::FUNC_NAME<TYPE_DECIMALV2>(                                               \
987
            const typename PrimitiveTypeTraits<TYPE_DECIMALV2>::CppType& rhs);                    \
988
    template void Field::FUNC_NAME<TYPE_DECIMAL128I>(                                             \
989
            const typename PrimitiveTypeTraits<TYPE_DECIMAL128I>::CppType& rhs);                  \
990
    template void Field::FUNC_NAME<TYPE_DECIMAL256>(                                              \
991
            const typename PrimitiveTypeTraits<TYPE_DECIMAL256>::CppType& rhs);                   \
992
    template void Field::FUNC_NAME<TYPE_CHAR>(                                                    \
993
            const typename PrimitiveTypeTraits<TYPE_CHAR>::CppType& rhs);                         \
994
    template void Field::FUNC_NAME<TYPE_VARCHAR>(                                                 \
995
            const typename PrimitiveTypeTraits<TYPE_VARCHAR>::CppType& rhs);                      \
996
    template void Field::FUNC_NAME<TYPE_STRING>(                                                  \
997
            const typename PrimitiveTypeTraits<TYPE_STRING>::CppType& rhs);                       \
998
    template void Field::FUNC_NAME<TYPE_VARBINARY>(                                               \
999
            const typename PrimitiveTypeTraits<TYPE_VARBINARY>::CppType& rhs);                    \
1000
    template void Field::FUNC_NAME<TYPE_HLL>(                                                     \
1001
            const typename PrimitiveTypeTraits<TYPE_HLL>::CppType& rhs);                          \
1002
    template void Field::FUNC_NAME<TYPE_VARIANT>(                                                 \
1003
            const typename PrimitiveTypeTraits<TYPE_VARIANT>::CppType& rhs);                      \
1004
    template void Field::FUNC_NAME<TYPE_QUANTILE_STATE>(                                          \
1005
            const typename PrimitiveTypeTraits<TYPE_QUANTILE_STATE>::CppType& rhs);               \
1006
    template void Field::FUNC_NAME<TYPE_ARRAY>(                                                   \
1007
            const typename PrimitiveTypeTraits<TYPE_ARRAY>::CppType& rhs);                        \
1008
    template void Field::FUNC_NAME<TYPE_IPV4>(typename PrimitiveTypeTraits<TYPE_IPV4>::CppType && \
1009
                                              rhs);                                               \
1010
    template void Field::FUNC_NAME<TYPE_IPV4>(                                                    \
1011
            const typename PrimitiveTypeTraits<TYPE_IPV4>::CppType& rhs);                         \
1012
    template void Field::FUNC_NAME<TYPE_IPV6>(typename PrimitiveTypeTraits<TYPE_IPV6>::CppType && \
1013
                                              rhs);                                               \
1014
    template void Field::FUNC_NAME<TYPE_IPV6>(                                                    \
1015
            const typename PrimitiveTypeTraits<TYPE_IPV6>::CppType& rhs);                         \
1016
    template void Field::FUNC_NAME<TYPE_BOOLEAN>(                                                 \
1017
            typename PrimitiveTypeTraits<TYPE_BOOLEAN>::CppType && rhs);                          \
1018
    template void Field::FUNC_NAME<TYPE_BOOLEAN>(                                                 \
1019
            const typename PrimitiveTypeTraits<TYPE_BOOLEAN>::CppType& rhs);                      \
1020
    template void Field::FUNC_NAME<TYPE_FLOAT>(                                                   \
1021
            typename PrimitiveTypeTraits<TYPE_FLOAT>::CppType && rhs);                            \
1022
    template void Field::FUNC_NAME<TYPE_FLOAT>(                                                   \
1023
            const typename PrimitiveTypeTraits<TYPE_FLOAT>::CppType& rhs);                        \
1024
    template void Field::FUNC_NAME<TYPE_DOUBLE>(                                                  \
1025
            typename PrimitiveTypeTraits<TYPE_DOUBLE>::CppType && rhs);                           \
1026
    template void Field::FUNC_NAME<TYPE_DOUBLE>(                                                  \
1027
            const typename PrimitiveTypeTraits<TYPE_DOUBLE>::CppType& rhs);                       \
1028
    template void Field::FUNC_NAME<TYPE_JSONB>(                                                   \
1029
            typename PrimitiveTypeTraits<TYPE_JSONB>::CppType && rhs);                            \
1030
    template void Field::FUNC_NAME<TYPE_JSONB>(                                                   \
1031
            const typename PrimitiveTypeTraits<TYPE_JSONB>::CppType& rhs);                        \
1032
    template void Field::FUNC_NAME<TYPE_STRUCT>(                                                  \
1033
            typename PrimitiveTypeTraits<TYPE_STRUCT>::CppType && rhs);                           \
1034
    template void Field::FUNC_NAME<TYPE_STRUCT>(                                                  \
1035
            const typename PrimitiveTypeTraits<TYPE_STRUCT>::CppType& rhs);                       \
1036
    template void Field::FUNC_NAME<TYPE_MAP>(typename PrimitiveTypeTraits<TYPE_MAP>::CppType &&   \
1037
                                             rhs);                                                \
1038
    template void Field::FUNC_NAME<TYPE_MAP>(                                                     \
1039
            const typename PrimitiveTypeTraits<TYPE_MAP>::CppType& rhs);                          \
1040
    template void Field::FUNC_NAME<TYPE_BITMAP>(                                                  \
1041
            typename PrimitiveTypeTraits<TYPE_BITMAP>::CppType && rhs);                           \
1042
    template void Field::FUNC_NAME<TYPE_BITMAP>(                                                  \
1043
            const typename PrimitiveTypeTraits<TYPE_BITMAP>::CppType& rhs);                       \
1044
    template void Field::FUNC_NAME<TYPE_TIMEV2>(                                                  \
1045
            const typename PrimitiveTypeTraits<TYPE_TIMEV2>::CppType& rhs);                       \
1046
    template void Field::FUNC_NAME<TYPE_TIMEV2>(                                                  \
1047
            typename PrimitiveTypeTraits<TYPE_TIMEV2>::CppType && rhs);                           \
1048
    template void Field::FUNC_NAME<TYPE_UINT32>(                                                  \
1049
            const typename PrimitiveTypeTraits<TYPE_UINT32>::CppType& rhs);                       \
1050
    template void Field::FUNC_NAME<TYPE_UINT32>(                                                  \
1051
            typename PrimitiveTypeTraits<TYPE_UINT32>::CppType && rhs);                           \
1052
    template void Field::FUNC_NAME<TYPE_UINT64>(                                                  \
1053
            const typename PrimitiveTypeTraits<TYPE_UINT64>::CppType& rhs);                       \
1054
    template void Field::FUNC_NAME<TYPE_UINT64>(                                                  \
1055
            typename PrimitiveTypeTraits<TYPE_UINT64>::CppType && rhs);
1056
DECLARE_FUNCTION(create_concrete)
1057
DECLARE_FUNCTION(assign_concrete)
1058
#undef DECLARE_FUNCTION
1059
1060
#define DECLARE_FUNCTION(TYPE_NAME)                                                          \
1061
    template typename PrimitiveTypeTraits<TYPE_NAME>::CppType& Field::get<TYPE_NAME>();      \
1062
    template const typename PrimitiveTypeTraits<TYPE_NAME>::CppType& Field::get<TYPE_NAME>() \
1063
            const;                                                                           \
1064
    template void Field::destroy<TYPE_NAME>();
1065
DECLARE_FUNCTION(TYPE_NULL)
1066
DECLARE_FUNCTION(TYPE_TINYINT)
1067
DECLARE_FUNCTION(TYPE_SMALLINT)
1068
DECLARE_FUNCTION(TYPE_INT)
1069
DECLARE_FUNCTION(TYPE_BIGINT)
1070
DECLARE_FUNCTION(TYPE_LARGEINT)
1071
DECLARE_FUNCTION(TYPE_DATE)
1072
DECLARE_FUNCTION(TYPE_DATETIME)
1073
DECLARE_FUNCTION(TYPE_DATEV2)
1074
DECLARE_FUNCTION(TYPE_DATETIMEV2)
1075
DECLARE_FUNCTION(TYPE_TIMESTAMPTZ)
1076
DECLARE_FUNCTION(TYPE_DECIMAL32)
1077
DECLARE_FUNCTION(TYPE_DECIMAL64)
1078
DECLARE_FUNCTION(TYPE_DECIMALV2)
1079
DECLARE_FUNCTION(TYPE_DECIMAL128I)
1080
DECLARE_FUNCTION(TYPE_DECIMAL256)
1081
DECLARE_FUNCTION(TYPE_CHAR)
1082
DECLARE_FUNCTION(TYPE_VARCHAR)
1083
DECLARE_FUNCTION(TYPE_STRING)
1084
DECLARE_FUNCTION(TYPE_VARBINARY)
1085
DECLARE_FUNCTION(TYPE_HLL)
1086
DECLARE_FUNCTION(TYPE_VARIANT)
1087
DECLARE_FUNCTION(TYPE_QUANTILE_STATE)
1088
DECLARE_FUNCTION(TYPE_ARRAY)
1089
DECLARE_FUNCTION(TYPE_TIME)
1090
DECLARE_FUNCTION(TYPE_IPV4)
1091
DECLARE_FUNCTION(TYPE_IPV6)
1092
DECLARE_FUNCTION(TYPE_BOOLEAN)
1093
DECLARE_FUNCTION(TYPE_FLOAT)
1094
DECLARE_FUNCTION(TYPE_DOUBLE)
1095
DECLARE_FUNCTION(TYPE_JSONB)
1096
DECLARE_FUNCTION(TYPE_STRUCT)
1097
DECLARE_FUNCTION(TYPE_MAP)
1098
DECLARE_FUNCTION(TYPE_BITMAP)
1099
DECLARE_FUNCTION(TYPE_TIMEV2)
1100
DECLARE_FUNCTION(TYPE_UINT32)
1101
DECLARE_FUNCTION(TYPE_UINT64)
1102
#undef DECLARE_FUNCTION
1103
} // namespace doris