Coverage Report

Created: 2026-03-15 01:14

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exec/common/field_visitors.h
Line
Count
Source
1
// Licensed to the Apache Software Foundation (ASF) under one
2
// or more contributor license agreements.  See the NOTICE file
3
// distributed with this work for additional information
4
// regarding copyright ownership.  The ASF licenses this file
5
// to you under the Apache License, Version 2.0 (the
6
// "License"); you may not use this file except in compliance
7
// with the License.  You may obtain a copy of the License at
8
//
9
//   http://www.apache.org/licenses/LICENSE-2.0
10
//
11
// Unless required by applicable law or agreed to in writing,
12
// software distributed under the License is distributed on an
13
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
// KIND, either express or implied.  See the License for the
15
// specific language governing permissions and limitations
16
// under the License.
17
// This file is copied from
18
// https://github.com/ClickHouse/ClickHouse/blob/master/src/Common/FieldVisitors.h
19
// and modified by Doris
20
21
#pragma once
22
23
#include "common/demangle.h"
24
#include "common/exception.h"
25
#include "common/status.h"
26
#include "core/accurate_comparison.h"
27
#include "core/data_type/primitive_type.h"
28
#include "core/field.h"
29
30
namespace doris {
31
32
/** StaticVisitor (and its descendants) - class with overloaded operator() for all types of fields.
33
  * You could call visitor for field using function 'apply_visitor'.
34
  * Also "binary visitor" is supported - its operator() takes two arguments.
35
  */
36
template <typename R = void>
37
struct StaticVisitor {
38
    using ResultType = R;
39
};
40
41
/// F is template parameter, to allow universal reference for field, that is useful for const and non-const values.
42
template <typename Visitor, typename F>
43
4.49M
typename std::decay_t<Visitor>::ResultType apply_visitor(Visitor&& visitor, F&& field) {
44
4.49M
    switch (field.get_type()) {
45
48.1k
    case PrimitiveType::TYPE_NULL:
46
48.1k
        return visitor.template apply<PrimitiveType::TYPE_NULL>(field.template get<TYPE_NULL>());
47
0
    case PrimitiveType::TYPE_DATETIMEV2:
48
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIMEV2>(
49
0
                field.template get<TYPE_DATETIMEV2>());
50
0
    case PrimitiveType::TYPE_TIMESTAMPTZ:
51
0
        return visitor.template apply<PrimitiveType::TYPE_TIMESTAMPTZ>(
52
0
                field.template get<TYPE_TIMESTAMPTZ>());
53
81.9k
    case PrimitiveType::TYPE_LARGEINT:
54
81.9k
        return visitor.template apply<PrimitiveType::TYPE_LARGEINT>(
55
81.9k
                field.template get<TYPE_LARGEINT>());
56
0
    case PrimitiveType::TYPE_DATETIME:
57
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIME>(
58
0
                field.template get<TYPE_DATETIME>());
59
0
    case PrimitiveType::TYPE_DATE:
60
0
        return visitor.template apply<PrimitiveType::TYPE_DATE>(field.template get<TYPE_DATE>());
61
0
    case PrimitiveType::TYPE_DATEV2:
62
0
        return visitor.template apply<PrimitiveType::TYPE_DATEV2>(
63
0
                field.template get<TYPE_DATEV2>());
64
139k
    case PrimitiveType::TYPE_BOOLEAN:
65
139k
        return visitor.template apply<PrimitiveType::TYPE_BOOLEAN>(
66
139k
                field.template get<TYPE_BOOLEAN>());
67
12
    case PrimitiveType::TYPE_TINYINT:
68
12
        return visitor.template apply<PrimitiveType::TYPE_TINYINT>(
69
12
                field.template get<TYPE_TINYINT>());
70
14
    case PrimitiveType::TYPE_SMALLINT:
71
14
        return visitor.template apply<PrimitiveType::TYPE_SMALLINT>(
72
14
                field.template get<TYPE_SMALLINT>());
73
1.90k
    case PrimitiveType::TYPE_INT:
74
1.90k
        return visitor.template apply<PrimitiveType::TYPE_INT>(field.template get<TYPE_INT>());
75
1.70M
    case PrimitiveType::TYPE_BIGINT:
76
1.70M
        return visitor.template apply<PrimitiveType::TYPE_BIGINT>(
77
1.70M
                field.template get<TYPE_BIGINT>());
78
0
    case PrimitiveType::TYPE_UINT32:
79
0
        return visitor.template apply<PrimitiveType::TYPE_UINT32>(
80
0
                field.template get<TYPE_UINT32>());
81
0
    case PrimitiveType::TYPE_UINT64:
82
0
        return visitor.template apply<PrimitiveType::TYPE_UINT64>(
83
0
                field.template get<TYPE_UINT64>());
84
2
    case PrimitiveType::TYPE_FLOAT:
85
2
        return visitor.template apply<PrimitiveType::TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
86
0
    case PrimitiveType::TYPE_TIMEV2:
87
0
        return visitor.template apply<PrimitiveType::TYPE_TIMEV2>(
88
0
                field.template get<TYPE_TIMEV2>());
89
329k
    case PrimitiveType::TYPE_DOUBLE:
90
329k
        return visitor.template apply<PrimitiveType::TYPE_DOUBLE>(
91
329k
                field.template get<TYPE_DOUBLE>());
92
0
    case PrimitiveType::TYPE_IPV4:
93
0
        return visitor.template apply<PrimitiveType::TYPE_IPV4>(field.template get<TYPE_IPV4>());
94
0
    case PrimitiveType::TYPE_IPV6:
95
0
        return visitor.template apply<PrimitiveType::TYPE_IPV6>(field.template get<TYPE_IPV6>());
96
1.93M
    case PrimitiveType::TYPE_STRING:
97
1.93M
        return visitor.template apply<PrimitiveType::TYPE_STRING>(
98
1.93M
                field.template get<TYPE_STRING>());
99
0
    case PrimitiveType::TYPE_CHAR:
100
0
        return visitor.template apply<PrimitiveType::TYPE_CHAR>(field.template get<TYPE_CHAR>());
101
0
    case PrimitiveType::TYPE_VARCHAR:
102
0
        return visitor.template apply<PrimitiveType::TYPE_VARCHAR>(
103
0
                field.template get<TYPE_VARCHAR>());
104
0
    case PrimitiveType::TYPE_VARBINARY:
105
0
        return visitor.template apply<PrimitiveType::TYPE_VARBINARY>(
106
0
                field.template get<TYPE_VARBINARY>());
107
255k
    case PrimitiveType::TYPE_ARRAY:
108
255k
        return visitor.template apply<PrimitiveType::TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
109
2
    case PrimitiveType::TYPE_STRUCT:
110
2
        return visitor.template apply<PrimitiveType::TYPE_STRUCT>(
111
2
                field.template get<TYPE_STRUCT>());
112
0
    case PrimitiveType::TYPE_MAP:
113
0
        return visitor.template apply<PrimitiveType::TYPE_MAP>(field.template get<TYPE_MAP>());
114
2
    case PrimitiveType::TYPE_VARIANT:
115
2
        return visitor.template apply<PrimitiveType::TYPE_VARIANT>(
116
2
                field.template get<TYPE_VARIANT>());
117
0
    case PrimitiveType::TYPE_DECIMAL32:
118
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL32>(
119
0
                field.template get<TYPE_DECIMAL32>());
120
0
    case PrimitiveType::TYPE_DECIMAL64:
121
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL64>(
122
0
                field.template get<TYPE_DECIMAL64>());
123
0
    case PrimitiveType::TYPE_DECIMALV2:
124
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMALV2>(
125
0
                field.template get<TYPE_DECIMALV2>());
126
0
    case PrimitiveType::TYPE_DECIMAL128I:
127
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL128I>(
128
0
                field.template get<TYPE_DECIMAL128I>());
129
0
    case PrimitiveType::TYPE_DECIMAL256:
130
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL256>(
131
0
                field.template get<TYPE_DECIMAL256>());
132
0
    case PrimitiveType::TYPE_BITMAP:
133
0
        return visitor.template apply<PrimitiveType::TYPE_BITMAP>(
134
0
                field.template get<TYPE_BITMAP>());
135
0
    case PrimitiveType::TYPE_HLL:
136
0
        return visitor.template apply<PrimitiveType::TYPE_HLL>(field.template get<TYPE_HLL>());
137
0
    case PrimitiveType::TYPE_QUANTILE_STATE:
138
0
        return visitor.template apply<PrimitiveType::TYPE_QUANTILE_STATE>(
139
0
                field.template get<TYPE_QUANTILE_STATE>());
140
54
    case PrimitiveType::TYPE_JSONB:
141
54
        return visitor.template apply<PrimitiveType::TYPE_JSONB>(field.template get<TYPE_JSONB>());
142
0
    default:
143
0
        throw doris::Exception(ErrorCode::INTERNAL_ERROR, "Bad type of Field {}",
144
0
                               static_cast<int>(field.get_type()));
145
0
        return {};
146
4.49M
    }
147
4.49M
}
_ZN5doris13apply_visitorINS_26FieldVisitorReplaceScalarsERNS_5FieldEEENSt5decayIT_E4type10ResultTypeEOS5_OT0_
Line
Count
Source
43
2
typename std::decay_t<Visitor>::ResultType apply_visitor(Visitor&& visitor, F&& field) {
44
2
    switch (field.get_type()) {
45
0
    case PrimitiveType::TYPE_NULL:
46
0
        return visitor.template apply<PrimitiveType::TYPE_NULL>(field.template get<TYPE_NULL>());
47
0
    case PrimitiveType::TYPE_DATETIMEV2:
48
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIMEV2>(
49
0
                field.template get<TYPE_DATETIMEV2>());
50
0
    case PrimitiveType::TYPE_TIMESTAMPTZ:
51
0
        return visitor.template apply<PrimitiveType::TYPE_TIMESTAMPTZ>(
52
0
                field.template get<TYPE_TIMESTAMPTZ>());
53
0
    case PrimitiveType::TYPE_LARGEINT:
54
0
        return visitor.template apply<PrimitiveType::TYPE_LARGEINT>(
55
0
                field.template get<TYPE_LARGEINT>());
56
0
    case PrimitiveType::TYPE_DATETIME:
57
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIME>(
58
0
                field.template get<TYPE_DATETIME>());
59
0
    case PrimitiveType::TYPE_DATE:
60
0
        return visitor.template apply<PrimitiveType::TYPE_DATE>(field.template get<TYPE_DATE>());
61
0
    case PrimitiveType::TYPE_DATEV2:
62
0
        return visitor.template apply<PrimitiveType::TYPE_DATEV2>(
63
0
                field.template get<TYPE_DATEV2>());
64
0
    case PrimitiveType::TYPE_BOOLEAN:
65
0
        return visitor.template apply<PrimitiveType::TYPE_BOOLEAN>(
66
0
                field.template get<TYPE_BOOLEAN>());
67
0
    case PrimitiveType::TYPE_TINYINT:
68
0
        return visitor.template apply<PrimitiveType::TYPE_TINYINT>(
69
0
                field.template get<TYPE_TINYINT>());
70
0
    case PrimitiveType::TYPE_SMALLINT:
71
0
        return visitor.template apply<PrimitiveType::TYPE_SMALLINT>(
72
0
                field.template get<TYPE_SMALLINT>());
73
0
    case PrimitiveType::TYPE_INT:
74
0
        return visitor.template apply<PrimitiveType::TYPE_INT>(field.template get<TYPE_INT>());
75
0
    case PrimitiveType::TYPE_BIGINT:
76
0
        return visitor.template apply<PrimitiveType::TYPE_BIGINT>(
77
0
                field.template get<TYPE_BIGINT>());
78
0
    case PrimitiveType::TYPE_UINT32:
79
0
        return visitor.template apply<PrimitiveType::TYPE_UINT32>(
80
0
                field.template get<TYPE_UINT32>());
81
0
    case PrimitiveType::TYPE_UINT64:
82
0
        return visitor.template apply<PrimitiveType::TYPE_UINT64>(
83
0
                field.template get<TYPE_UINT64>());
84
0
    case PrimitiveType::TYPE_FLOAT:
85
0
        return visitor.template apply<PrimitiveType::TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
86
0
    case PrimitiveType::TYPE_TIMEV2:
87
0
        return visitor.template apply<PrimitiveType::TYPE_TIMEV2>(
88
0
                field.template get<TYPE_TIMEV2>());
89
0
    case PrimitiveType::TYPE_DOUBLE:
90
0
        return visitor.template apply<PrimitiveType::TYPE_DOUBLE>(
91
0
                field.template get<TYPE_DOUBLE>());
92
0
    case PrimitiveType::TYPE_IPV4:
93
0
        return visitor.template apply<PrimitiveType::TYPE_IPV4>(field.template get<TYPE_IPV4>());
94
0
    case PrimitiveType::TYPE_IPV6:
95
0
        return visitor.template apply<PrimitiveType::TYPE_IPV6>(field.template get<TYPE_IPV6>());
96
0
    case PrimitiveType::TYPE_STRING:
97
0
        return visitor.template apply<PrimitiveType::TYPE_STRING>(
98
0
                field.template get<TYPE_STRING>());
99
0
    case PrimitiveType::TYPE_CHAR:
100
0
        return visitor.template apply<PrimitiveType::TYPE_CHAR>(field.template get<TYPE_CHAR>());
101
0
    case PrimitiveType::TYPE_VARCHAR:
102
0
        return visitor.template apply<PrimitiveType::TYPE_VARCHAR>(
103
0
                field.template get<TYPE_VARCHAR>());
104
0
    case PrimitiveType::TYPE_VARBINARY:
105
0
        return visitor.template apply<PrimitiveType::TYPE_VARBINARY>(
106
0
                field.template get<TYPE_VARBINARY>());
107
2
    case PrimitiveType::TYPE_ARRAY:
108
2
        return visitor.template apply<PrimitiveType::TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
109
0
    case PrimitiveType::TYPE_STRUCT:
110
0
        return visitor.template apply<PrimitiveType::TYPE_STRUCT>(
111
0
                field.template get<TYPE_STRUCT>());
112
0
    case PrimitiveType::TYPE_MAP:
113
0
        return visitor.template apply<PrimitiveType::TYPE_MAP>(field.template get<TYPE_MAP>());
114
0
    case PrimitiveType::TYPE_VARIANT:
115
0
        return visitor.template apply<PrimitiveType::TYPE_VARIANT>(
116
0
                field.template get<TYPE_VARIANT>());
117
0
    case PrimitiveType::TYPE_DECIMAL32:
118
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL32>(
119
0
                field.template get<TYPE_DECIMAL32>());
120
0
    case PrimitiveType::TYPE_DECIMAL64:
121
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL64>(
122
0
                field.template get<TYPE_DECIMAL64>());
123
0
    case PrimitiveType::TYPE_DECIMALV2:
124
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMALV2>(
125
0
                field.template get<TYPE_DECIMALV2>());
126
0
    case PrimitiveType::TYPE_DECIMAL128I:
127
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL128I>(
128
0
                field.template get<TYPE_DECIMAL128I>());
129
0
    case PrimitiveType::TYPE_DECIMAL256:
130
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL256>(
131
0
                field.template get<TYPE_DECIMAL256>());
132
0
    case PrimitiveType::TYPE_BITMAP:
133
0
        return visitor.template apply<PrimitiveType::TYPE_BITMAP>(
134
0
                field.template get<TYPE_BITMAP>());
135
0
    case PrimitiveType::TYPE_HLL:
136
0
        return visitor.template apply<PrimitiveType::TYPE_HLL>(field.template get<TYPE_HLL>());
137
0
    case PrimitiveType::TYPE_QUANTILE_STATE:
138
0
        return visitor.template apply<PrimitiveType::TYPE_QUANTILE_STATE>(
139
0
                field.template get<TYPE_QUANTILE_STATE>());
140
0
    case PrimitiveType::TYPE_JSONB:
141
0
        return visitor.template apply<PrimitiveType::TYPE_JSONB>(field.template get<TYPE_JSONB>());
142
0
    default:
143
0
        throw doris::Exception(ErrorCode::INTERNAL_ERROR, "Bad type of Field {}",
144
0
                               static_cast<int>(field.get_type()));
145
0
        return {};
146
2
    }
147
2
}
_ZN5doris13apply_visitorINS_26FieldVisitorReplaceScalarsERKNS_5FieldEEENSt5decayIT_E4type10ResultTypeEOS6_OT0_
Line
Count
Source
43
3
typename std::decay_t<Visitor>::ResultType apply_visitor(Visitor&& visitor, F&& field) {
44
3
    switch (field.get_type()) {
45
0
    case PrimitiveType::TYPE_NULL:
46
0
        return visitor.template apply<PrimitiveType::TYPE_NULL>(field.template get<TYPE_NULL>());
47
0
    case PrimitiveType::TYPE_DATETIMEV2:
48
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIMEV2>(
49
0
                field.template get<TYPE_DATETIMEV2>());
50
0
    case PrimitiveType::TYPE_TIMESTAMPTZ:
51
0
        return visitor.template apply<PrimitiveType::TYPE_TIMESTAMPTZ>(
52
0
                field.template get<TYPE_TIMESTAMPTZ>());
53
0
    case PrimitiveType::TYPE_LARGEINT:
54
0
        return visitor.template apply<PrimitiveType::TYPE_LARGEINT>(
55
0
                field.template get<TYPE_LARGEINT>());
56
0
    case PrimitiveType::TYPE_DATETIME:
57
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIME>(
58
0
                field.template get<TYPE_DATETIME>());
59
0
    case PrimitiveType::TYPE_DATE:
60
0
        return visitor.template apply<PrimitiveType::TYPE_DATE>(field.template get<TYPE_DATE>());
61
0
    case PrimitiveType::TYPE_DATEV2:
62
0
        return visitor.template apply<PrimitiveType::TYPE_DATEV2>(
63
0
                field.template get<TYPE_DATEV2>());
64
0
    case PrimitiveType::TYPE_BOOLEAN:
65
0
        return visitor.template apply<PrimitiveType::TYPE_BOOLEAN>(
66
0
                field.template get<TYPE_BOOLEAN>());
67
0
    case PrimitiveType::TYPE_TINYINT:
68
0
        return visitor.template apply<PrimitiveType::TYPE_TINYINT>(
69
0
                field.template get<TYPE_TINYINT>());
70
0
    case PrimitiveType::TYPE_SMALLINT:
71
0
        return visitor.template apply<PrimitiveType::TYPE_SMALLINT>(
72
0
                field.template get<TYPE_SMALLINT>());
73
0
    case PrimitiveType::TYPE_INT:
74
0
        return visitor.template apply<PrimitiveType::TYPE_INT>(field.template get<TYPE_INT>());
75
3
    case PrimitiveType::TYPE_BIGINT:
76
3
        return visitor.template apply<PrimitiveType::TYPE_BIGINT>(
77
3
                field.template get<TYPE_BIGINT>());
78
0
    case PrimitiveType::TYPE_UINT32:
79
0
        return visitor.template apply<PrimitiveType::TYPE_UINT32>(
80
0
                field.template get<TYPE_UINT32>());
81
0
    case PrimitiveType::TYPE_UINT64:
82
0
        return visitor.template apply<PrimitiveType::TYPE_UINT64>(
83
0
                field.template get<TYPE_UINT64>());
84
0
    case PrimitiveType::TYPE_FLOAT:
85
0
        return visitor.template apply<PrimitiveType::TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
86
0
    case PrimitiveType::TYPE_TIMEV2:
87
0
        return visitor.template apply<PrimitiveType::TYPE_TIMEV2>(
88
0
                field.template get<TYPE_TIMEV2>());
89
0
    case PrimitiveType::TYPE_DOUBLE:
90
0
        return visitor.template apply<PrimitiveType::TYPE_DOUBLE>(
91
0
                field.template get<TYPE_DOUBLE>());
92
0
    case PrimitiveType::TYPE_IPV4:
93
0
        return visitor.template apply<PrimitiveType::TYPE_IPV4>(field.template get<TYPE_IPV4>());
94
0
    case PrimitiveType::TYPE_IPV6:
95
0
        return visitor.template apply<PrimitiveType::TYPE_IPV6>(field.template get<TYPE_IPV6>());
96
0
    case PrimitiveType::TYPE_STRING:
97
0
        return visitor.template apply<PrimitiveType::TYPE_STRING>(
98
0
                field.template get<TYPE_STRING>());
99
0
    case PrimitiveType::TYPE_CHAR:
100
0
        return visitor.template apply<PrimitiveType::TYPE_CHAR>(field.template get<TYPE_CHAR>());
101
0
    case PrimitiveType::TYPE_VARCHAR:
102
0
        return visitor.template apply<PrimitiveType::TYPE_VARCHAR>(
103
0
                field.template get<TYPE_VARCHAR>());
104
0
    case PrimitiveType::TYPE_VARBINARY:
105
0
        return visitor.template apply<PrimitiveType::TYPE_VARBINARY>(
106
0
                field.template get<TYPE_VARBINARY>());
107
0
    case PrimitiveType::TYPE_ARRAY:
108
0
        return visitor.template apply<PrimitiveType::TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
109
0
    case PrimitiveType::TYPE_STRUCT:
110
0
        return visitor.template apply<PrimitiveType::TYPE_STRUCT>(
111
0
                field.template get<TYPE_STRUCT>());
112
0
    case PrimitiveType::TYPE_MAP:
113
0
        return visitor.template apply<PrimitiveType::TYPE_MAP>(field.template get<TYPE_MAP>());
114
0
    case PrimitiveType::TYPE_VARIANT:
115
0
        return visitor.template apply<PrimitiveType::TYPE_VARIANT>(
116
0
                field.template get<TYPE_VARIANT>());
117
0
    case PrimitiveType::TYPE_DECIMAL32:
118
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL32>(
119
0
                field.template get<TYPE_DECIMAL32>());
120
0
    case PrimitiveType::TYPE_DECIMAL64:
121
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL64>(
122
0
                field.template get<TYPE_DECIMAL64>());
123
0
    case PrimitiveType::TYPE_DECIMALV2:
124
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMALV2>(
125
0
                field.template get<TYPE_DECIMALV2>());
126
0
    case PrimitiveType::TYPE_DECIMAL128I:
127
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL128I>(
128
0
                field.template get<TYPE_DECIMAL128I>());
129
0
    case PrimitiveType::TYPE_DECIMAL256:
130
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL256>(
131
0
                field.template get<TYPE_DECIMAL256>());
132
0
    case PrimitiveType::TYPE_BITMAP:
133
0
        return visitor.template apply<PrimitiveType::TYPE_BITMAP>(
134
0
                field.template get<TYPE_BITMAP>());
135
0
    case PrimitiveType::TYPE_HLL:
136
0
        return visitor.template apply<PrimitiveType::TYPE_HLL>(field.template get<TYPE_HLL>());
137
0
    case PrimitiveType::TYPE_QUANTILE_STATE:
138
0
        return visitor.template apply<PrimitiveType::TYPE_QUANTILE_STATE>(
139
0
                field.template get<TYPE_QUANTILE_STATE>());
140
0
    case PrimitiveType::TYPE_JSONB:
141
0
        return visitor.template apply<PrimitiveType::TYPE_JSONB>(field.template get<TYPE_JSONB>());
142
0
    default:
143
0
        throw doris::Exception(ErrorCode::INTERNAL_ERROR, "Bad type of Field {}",
144
0
                               static_cast<int>(field.get_type()));
145
0
        return {};
146
3
    }
147
3
}
Unexecuted instantiation: _ZN5doris13apply_visitorIRNS_26FieldVisitorToStringSimpleERKNS_5FieldEEENSt5decayIT_E4type10ResultTypeEOS7_OT0_
_ZN5doris13apply_visitorIRNS_12variant_util24FieldVisitorToScalarTypeERKNS_5FieldEEENSt5decayIT_E4type10ResultTypeEOS8_OT0_
Line
Count
Source
43
823k
typename std::decay_t<Visitor>::ResultType apply_visitor(Visitor&& visitor, F&& field) {
44
823k
    switch (field.get_type()) {
45
11.6k
    case PrimitiveType::TYPE_NULL:
46
11.6k
        return visitor.template apply<PrimitiveType::TYPE_NULL>(field.template get<TYPE_NULL>());
47
0
    case PrimitiveType::TYPE_DATETIMEV2:
48
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIMEV2>(
49
0
                field.template get<TYPE_DATETIMEV2>());
50
0
    case PrimitiveType::TYPE_TIMESTAMPTZ:
51
0
        return visitor.template apply<PrimitiveType::TYPE_TIMESTAMPTZ>(
52
0
                field.template get<TYPE_TIMESTAMPTZ>());
53
28.6k
    case PrimitiveType::TYPE_LARGEINT:
54
28.6k
        return visitor.template apply<PrimitiveType::TYPE_LARGEINT>(
55
28.6k
                field.template get<TYPE_LARGEINT>());
56
0
    case PrimitiveType::TYPE_DATETIME:
57
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIME>(
58
0
                field.template get<TYPE_DATETIME>());
59
0
    case PrimitiveType::TYPE_DATE:
60
0
        return visitor.template apply<PrimitiveType::TYPE_DATE>(field.template get<TYPE_DATE>());
61
0
    case PrimitiveType::TYPE_DATEV2:
62
0
        return visitor.template apply<PrimitiveType::TYPE_DATEV2>(
63
0
                field.template get<TYPE_DATEV2>());
64
57.2k
    case PrimitiveType::TYPE_BOOLEAN:
65
57.2k
        return visitor.template apply<PrimitiveType::TYPE_BOOLEAN>(
66
57.2k
                field.template get<TYPE_BOOLEAN>());
67
4
    case PrimitiveType::TYPE_TINYINT:
68
4
        return visitor.template apply<PrimitiveType::TYPE_TINYINT>(
69
4
                field.template get<TYPE_TINYINT>());
70
0
    case PrimitiveType::TYPE_SMALLINT:
71
0
        return visitor.template apply<PrimitiveType::TYPE_SMALLINT>(
72
0
                field.template get<TYPE_SMALLINT>());
73
381
    case PrimitiveType::TYPE_INT:
74
381
        return visitor.template apply<PrimitiveType::TYPE_INT>(field.template get<TYPE_INT>());
75
147k
    case PrimitiveType::TYPE_BIGINT:
76
147k
        return visitor.template apply<PrimitiveType::TYPE_BIGINT>(
77
147k
                field.template get<TYPE_BIGINT>());
78
0
    case PrimitiveType::TYPE_UINT32:
79
0
        return visitor.template apply<PrimitiveType::TYPE_UINT32>(
80
0
                field.template get<TYPE_UINT32>());
81
0
    case PrimitiveType::TYPE_UINT64:
82
0
        return visitor.template apply<PrimitiveType::TYPE_UINT64>(
83
0
                field.template get<TYPE_UINT64>());
84
0
    case PrimitiveType::TYPE_FLOAT:
85
0
        return visitor.template apply<PrimitiveType::TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
86
0
    case PrimitiveType::TYPE_TIMEV2:
87
0
        return visitor.template apply<PrimitiveType::TYPE_TIMEV2>(
88
0
                field.template get<TYPE_TIMEV2>());
89
151k
    case PrimitiveType::TYPE_DOUBLE:
90
151k
        return visitor.template apply<PrimitiveType::TYPE_DOUBLE>(
91
151k
                field.template get<TYPE_DOUBLE>());
92
0
    case PrimitiveType::TYPE_IPV4:
93
0
        return visitor.template apply<PrimitiveType::TYPE_IPV4>(field.template get<TYPE_IPV4>());
94
0
    case PrimitiveType::TYPE_IPV6:
95
0
        return visitor.template apply<PrimitiveType::TYPE_IPV6>(field.template get<TYPE_IPV6>());
96
297k
    case PrimitiveType::TYPE_STRING:
97
297k
        return visitor.template apply<PrimitiveType::TYPE_STRING>(
98
297k
                field.template get<TYPE_STRING>());
99
0
    case PrimitiveType::TYPE_CHAR:
100
0
        return visitor.template apply<PrimitiveType::TYPE_CHAR>(field.template get<TYPE_CHAR>());
101
0
    case PrimitiveType::TYPE_VARCHAR:
102
0
        return visitor.template apply<PrimitiveType::TYPE_VARCHAR>(
103
0
                field.template get<TYPE_VARCHAR>());
104
0
    case PrimitiveType::TYPE_VARBINARY:
105
0
        return visitor.template apply<PrimitiveType::TYPE_VARBINARY>(
106
0
                field.template get<TYPE_VARBINARY>());
107
127k
    case PrimitiveType::TYPE_ARRAY:
108
127k
        return visitor.template apply<PrimitiveType::TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
109
1
    case PrimitiveType::TYPE_STRUCT:
110
1
        return visitor.template apply<PrimitiveType::TYPE_STRUCT>(
111
1
                field.template get<TYPE_STRUCT>());
112
0
    case PrimitiveType::TYPE_MAP:
113
0
        return visitor.template apply<PrimitiveType::TYPE_MAP>(field.template get<TYPE_MAP>());
114
1
    case PrimitiveType::TYPE_VARIANT:
115
1
        return visitor.template apply<PrimitiveType::TYPE_VARIANT>(
116
1
                field.template get<TYPE_VARIANT>());
117
0
    case PrimitiveType::TYPE_DECIMAL32:
118
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL32>(
119
0
                field.template get<TYPE_DECIMAL32>());
120
0
    case PrimitiveType::TYPE_DECIMAL64:
121
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL64>(
122
0
                field.template get<TYPE_DECIMAL64>());
123
0
    case PrimitiveType::TYPE_DECIMALV2:
124
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMALV2>(
125
0
                field.template get<TYPE_DECIMALV2>());
126
0
    case PrimitiveType::TYPE_DECIMAL128I:
127
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL128I>(
128
0
                field.template get<TYPE_DECIMAL128I>());
129
0
    case PrimitiveType::TYPE_DECIMAL256:
130
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL256>(
131
0
                field.template get<TYPE_DECIMAL256>());
132
0
    case PrimitiveType::TYPE_BITMAP:
133
0
        return visitor.template apply<PrimitiveType::TYPE_BITMAP>(
134
0
                field.template get<TYPE_BITMAP>());
135
0
    case PrimitiveType::TYPE_HLL:
136
0
        return visitor.template apply<PrimitiveType::TYPE_HLL>(field.template get<TYPE_HLL>());
137
0
    case PrimitiveType::TYPE_QUANTILE_STATE:
138
0
        return visitor.template apply<PrimitiveType::TYPE_QUANTILE_STATE>(
139
0
                field.template get<TYPE_QUANTILE_STATE>());
140
26
    case PrimitiveType::TYPE_JSONB:
141
26
        return visitor.template apply<PrimitiveType::TYPE_JSONB>(field.template get<TYPE_JSONB>());
142
0
    default:
143
0
        throw doris::Exception(ErrorCode::INTERNAL_ERROR, "Bad type of Field {}",
144
0
                               static_cast<int>(field.get_type()));
145
0
        return {};
146
823k
    }
147
823k
}
_ZN5doris13apply_visitorINS_12variant_util32FieldVisitorToNumberOfDimensionsERKNS_5FieldEEENSt5decayIT_E4type10ResultTypeEOS7_OT0_
Line
Count
Source
43
1.50M
typename std::decay_t<Visitor>::ResultType apply_visitor(Visitor&& visitor, F&& field) {
44
1.50M
    switch (field.get_type()) {
45
12.3k
    case PrimitiveType::TYPE_NULL:
46
12.3k
        return visitor.template apply<PrimitiveType::TYPE_NULL>(field.template get<TYPE_NULL>());
47
0
    case PrimitiveType::TYPE_DATETIMEV2:
48
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIMEV2>(
49
0
                field.template get<TYPE_DATETIMEV2>());
50
0
    case PrimitiveType::TYPE_TIMESTAMPTZ:
51
0
        return visitor.template apply<PrimitiveType::TYPE_TIMESTAMPTZ>(
52
0
                field.template get<TYPE_TIMESTAMPTZ>());
53
12.3k
    case PrimitiveType::TYPE_LARGEINT:
54
12.3k
        return visitor.template apply<PrimitiveType::TYPE_LARGEINT>(
55
12.3k
                field.template get<TYPE_LARGEINT>());
56
0
    case PrimitiveType::TYPE_DATETIME:
57
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIME>(
58
0
                field.template get<TYPE_DATETIME>());
59
0
    case PrimitiveType::TYPE_DATE:
60
0
        return visitor.template apply<PrimitiveType::TYPE_DATE>(field.template get<TYPE_DATE>());
61
0
    case PrimitiveType::TYPE_DATEV2:
62
0
        return visitor.template apply<PrimitiveType::TYPE_DATEV2>(
63
0
                field.template get<TYPE_DATEV2>());
64
12.4k
    case PrimitiveType::TYPE_BOOLEAN:
65
12.4k
        return visitor.template apply<PrimitiveType::TYPE_BOOLEAN>(
66
12.4k
                field.template get<TYPE_BOOLEAN>());
67
2
    case PrimitiveType::TYPE_TINYINT:
68
2
        return visitor.template apply<PrimitiveType::TYPE_TINYINT>(
69
2
                field.template get<TYPE_TINYINT>());
70
7
    case PrimitiveType::TYPE_SMALLINT:
71
7
        return visitor.template apply<PrimitiveType::TYPE_SMALLINT>(
72
7
                field.template get<TYPE_SMALLINT>());
73
570
    case PrimitiveType::TYPE_INT:
74
570
        return visitor.template apply<PrimitiveType::TYPE_INT>(field.template get<TYPE_INT>());
75
703k
    case PrimitiveType::TYPE_BIGINT:
76
703k
        return visitor.template apply<PrimitiveType::TYPE_BIGINT>(
77
703k
                field.template get<TYPE_BIGINT>());
78
0
    case PrimitiveType::TYPE_UINT32:
79
0
        return visitor.template apply<PrimitiveType::TYPE_UINT32>(
80
0
                field.template get<TYPE_UINT32>());
81
0
    case PrimitiveType::TYPE_UINT64:
82
0
        return visitor.template apply<PrimitiveType::TYPE_UINT64>(
83
0
                field.template get<TYPE_UINT64>());
84
1
    case PrimitiveType::TYPE_FLOAT:
85
1
        return visitor.template apply<PrimitiveType::TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
86
0
    case PrimitiveType::TYPE_TIMEV2:
87
0
        return visitor.template apply<PrimitiveType::TYPE_TIMEV2>(
88
0
                field.template get<TYPE_TIMEV2>());
89
12.6k
    case PrimitiveType::TYPE_DOUBLE:
90
12.6k
        return visitor.template apply<PrimitiveType::TYPE_DOUBLE>(
91
12.6k
                field.template get<TYPE_DOUBLE>());
92
0
    case PrimitiveType::TYPE_IPV4:
93
0
        return visitor.template apply<PrimitiveType::TYPE_IPV4>(field.template get<TYPE_IPV4>());
94
0
    case PrimitiveType::TYPE_IPV6:
95
0
        return visitor.template apply<PrimitiveType::TYPE_IPV6>(field.template get<TYPE_IPV6>());
96
670k
    case PrimitiveType::TYPE_STRING:
97
670k
        return visitor.template apply<PrimitiveType::TYPE_STRING>(
98
670k
                field.template get<TYPE_STRING>());
99
0
    case PrimitiveType::TYPE_CHAR:
100
0
        return visitor.template apply<PrimitiveType::TYPE_CHAR>(field.template get<TYPE_CHAR>());
101
0
    case PrimitiveType::TYPE_VARCHAR:
102
0
        return visitor.template apply<PrimitiveType::TYPE_VARCHAR>(
103
0
                field.template get<TYPE_VARCHAR>());
104
0
    case PrimitiveType::TYPE_VARBINARY:
105
0
        return visitor.template apply<PrimitiveType::TYPE_VARBINARY>(
106
0
                field.template get<TYPE_VARBINARY>());
107
77.7k
    case PrimitiveType::TYPE_ARRAY:
108
77.7k
        return visitor.template apply<PrimitiveType::TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
109
1
    case PrimitiveType::TYPE_STRUCT:
110
1
        return visitor.template apply<PrimitiveType::TYPE_STRUCT>(
111
1
                field.template get<TYPE_STRUCT>());
112
0
    case PrimitiveType::TYPE_MAP:
113
0
        return visitor.template apply<PrimitiveType::TYPE_MAP>(field.template get<TYPE_MAP>());
114
1
    case PrimitiveType::TYPE_VARIANT:
115
1
        return visitor.template apply<PrimitiveType::TYPE_VARIANT>(
116
1
                field.template get<TYPE_VARIANT>());
117
0
    case PrimitiveType::TYPE_DECIMAL32:
118
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL32>(
119
0
                field.template get<TYPE_DECIMAL32>());
120
0
    case PrimitiveType::TYPE_DECIMAL64:
121
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL64>(
122
0
                field.template get<TYPE_DECIMAL64>());
123
0
    case PrimitiveType::TYPE_DECIMALV2:
124
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMALV2>(
125
0
                field.template get<TYPE_DECIMALV2>());
126
0
    case PrimitiveType::TYPE_DECIMAL128I:
127
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL128I>(
128
0
                field.template get<TYPE_DECIMAL128I>());
129
0
    case PrimitiveType::TYPE_DECIMAL256:
130
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL256>(
131
0
                field.template get<TYPE_DECIMAL256>());
132
0
    case PrimitiveType::TYPE_BITMAP:
133
0
        return visitor.template apply<PrimitiveType::TYPE_BITMAP>(
134
0
                field.template get<TYPE_BITMAP>());
135
0
    case PrimitiveType::TYPE_HLL:
136
0
        return visitor.template apply<PrimitiveType::TYPE_HLL>(field.template get<TYPE_HLL>());
137
0
    case PrimitiveType::TYPE_QUANTILE_STATE:
138
0
        return visitor.template apply<PrimitiveType::TYPE_QUANTILE_STATE>(
139
0
                field.template get<TYPE_QUANTILE_STATE>());
140
1
    case PrimitiveType::TYPE_JSONB:
141
1
        return visitor.template apply<PrimitiveType::TYPE_JSONB>(field.template get<TYPE_JSONB>());
142
0
    default:
143
0
        throw doris::Exception(ErrorCode::INTERNAL_ERROR, "Bad type of Field {}",
144
0
                               static_cast<int>(field.get_type()));
145
0
        return {};
146
1.50M
    }
147
1.50M
}
_ZN5doris13apply_visitorIRNS_12variant_util32FieldVisitorToNumberOfDimensionsERKNS_5FieldEEENSt5decayIT_E4type10ResultTypeEOS8_OT0_
Line
Count
Source
43
745k
typename std::decay_t<Visitor>::ResultType apply_visitor(Visitor&& visitor, F&& field) {
44
745k
    switch (field.get_type()) {
45
11.6k
    case PrimitiveType::TYPE_NULL:
46
11.6k
        return visitor.template apply<PrimitiveType::TYPE_NULL>(field.template get<TYPE_NULL>());
47
0
    case PrimitiveType::TYPE_DATETIMEV2:
48
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIMEV2>(
49
0
                field.template get<TYPE_DATETIMEV2>());
50
0
    case PrimitiveType::TYPE_TIMESTAMPTZ:
51
0
        return visitor.template apply<PrimitiveType::TYPE_TIMESTAMPTZ>(
52
0
                field.template get<TYPE_TIMESTAMPTZ>());
53
28.6k
    case PrimitiveType::TYPE_LARGEINT:
54
28.6k
        return visitor.template apply<PrimitiveType::TYPE_LARGEINT>(
55
28.6k
                field.template get<TYPE_LARGEINT>());
56
0
    case PrimitiveType::TYPE_DATETIME:
57
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIME>(
58
0
                field.template get<TYPE_DATETIME>());
59
0
    case PrimitiveType::TYPE_DATE:
60
0
        return visitor.template apply<PrimitiveType::TYPE_DATE>(field.template get<TYPE_DATE>());
61
0
    case PrimitiveType::TYPE_DATEV2:
62
0
        return visitor.template apply<PrimitiveType::TYPE_DATEV2>(
63
0
                field.template get<TYPE_DATEV2>());
64
57.2k
    case PrimitiveType::TYPE_BOOLEAN:
65
57.2k
        return visitor.template apply<PrimitiveType::TYPE_BOOLEAN>(
66
57.2k
                field.template get<TYPE_BOOLEAN>());
67
4
    case PrimitiveType::TYPE_TINYINT:
68
4
        return visitor.template apply<PrimitiveType::TYPE_TINYINT>(
69
4
                field.template get<TYPE_TINYINT>());
70
0
    case PrimitiveType::TYPE_SMALLINT:
71
0
        return visitor.template apply<PrimitiveType::TYPE_SMALLINT>(
72
0
                field.template get<TYPE_SMALLINT>());
73
381
    case PrimitiveType::TYPE_INT:
74
381
        return visitor.template apply<PrimitiveType::TYPE_INT>(field.template get<TYPE_INT>());
75
147k
    case PrimitiveType::TYPE_BIGINT:
76
147k
        return visitor.template apply<PrimitiveType::TYPE_BIGINT>(
77
147k
                field.template get<TYPE_BIGINT>());
78
0
    case PrimitiveType::TYPE_UINT32:
79
0
        return visitor.template apply<PrimitiveType::TYPE_UINT32>(
80
0
                field.template get<TYPE_UINT32>());
81
0
    case PrimitiveType::TYPE_UINT64:
82
0
        return visitor.template apply<PrimitiveType::TYPE_UINT64>(
83
0
                field.template get<TYPE_UINT64>());
84
0
    case PrimitiveType::TYPE_FLOAT:
85
0
        return visitor.template apply<PrimitiveType::TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
86
0
    case PrimitiveType::TYPE_TIMEV2:
87
0
        return visitor.template apply<PrimitiveType::TYPE_TIMEV2>(
88
0
                field.template get<TYPE_TIMEV2>());
89
151k
    case PrimitiveType::TYPE_DOUBLE:
90
151k
        return visitor.template apply<PrimitiveType::TYPE_DOUBLE>(
91
151k
                field.template get<TYPE_DOUBLE>());
92
0
    case PrimitiveType::TYPE_IPV4:
93
0
        return visitor.template apply<PrimitiveType::TYPE_IPV4>(field.template get<TYPE_IPV4>());
94
0
    case PrimitiveType::TYPE_IPV6:
95
0
        return visitor.template apply<PrimitiveType::TYPE_IPV6>(field.template get<TYPE_IPV6>());
96
297k
    case PrimitiveType::TYPE_STRING:
97
297k
        return visitor.template apply<PrimitiveType::TYPE_STRING>(
98
297k
                field.template get<TYPE_STRING>());
99
0
    case PrimitiveType::TYPE_CHAR:
100
0
        return visitor.template apply<PrimitiveType::TYPE_CHAR>(field.template get<TYPE_CHAR>());
101
0
    case PrimitiveType::TYPE_VARCHAR:
102
0
        return visitor.template apply<PrimitiveType::TYPE_VARCHAR>(
103
0
                field.template get<TYPE_VARCHAR>());
104
0
    case PrimitiveType::TYPE_VARBINARY:
105
0
        return visitor.template apply<PrimitiveType::TYPE_VARBINARY>(
106
0
                field.template get<TYPE_VARBINARY>());
107
50.0k
    case PrimitiveType::TYPE_ARRAY:
108
50.0k
        return visitor.template apply<PrimitiveType::TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
109
0
    case PrimitiveType::TYPE_STRUCT:
110
0
        return visitor.template apply<PrimitiveType::TYPE_STRUCT>(
111
0
                field.template get<TYPE_STRUCT>());
112
0
    case PrimitiveType::TYPE_MAP:
113
0
        return visitor.template apply<PrimitiveType::TYPE_MAP>(field.template get<TYPE_MAP>());
114
0
    case PrimitiveType::TYPE_VARIANT:
115
0
        return visitor.template apply<PrimitiveType::TYPE_VARIANT>(
116
0
                field.template get<TYPE_VARIANT>());
117
0
    case PrimitiveType::TYPE_DECIMAL32:
118
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL32>(
119
0
                field.template get<TYPE_DECIMAL32>());
120
0
    case PrimitiveType::TYPE_DECIMAL64:
121
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL64>(
122
0
                field.template get<TYPE_DECIMAL64>());
123
0
    case PrimitiveType::TYPE_DECIMALV2:
124
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMALV2>(
125
0
                field.template get<TYPE_DECIMALV2>());
126
0
    case PrimitiveType::TYPE_DECIMAL128I:
127
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL128I>(
128
0
                field.template get<TYPE_DECIMAL128I>());
129
0
    case PrimitiveType::TYPE_DECIMAL256:
130
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL256>(
131
0
                field.template get<TYPE_DECIMAL256>());
132
0
    case PrimitiveType::TYPE_BITMAP:
133
0
        return visitor.template apply<PrimitiveType::TYPE_BITMAP>(
134
0
                field.template get<TYPE_BITMAP>());
135
0
    case PrimitiveType::TYPE_HLL:
136
0
        return visitor.template apply<PrimitiveType::TYPE_HLL>(field.template get<TYPE_HLL>());
137
0
    case PrimitiveType::TYPE_QUANTILE_STATE:
138
0
        return visitor.template apply<PrimitiveType::TYPE_QUANTILE_STATE>(
139
0
                field.template get<TYPE_QUANTILE_STATE>());
140
26
    case PrimitiveType::TYPE_JSONB:
141
26
        return visitor.template apply<PrimitiveType::TYPE_JSONB>(field.template get<TYPE_JSONB>());
142
0
    default:
143
0
        throw doris::Exception(ErrorCode::INTERNAL_ERROR, "Bad type of Field {}",
144
0
                               static_cast<int>(field.get_type()));
145
0
        return {};
146
745k
    }
147
745k
}
_ZN5doris13apply_visitorIRNS_12variant_util30SimpleFieldVisitorToScalarTypeERKNS_5FieldEEENSt5decayIT_E4type10ResultTypeEOS8_OT0_
Line
Count
Source
43
1.42M
typename std::decay_t<Visitor>::ResultType apply_visitor(Visitor&& visitor, F&& field) {
44
1.42M
    switch (field.get_type()) {
45
12.3k
    case PrimitiveType::TYPE_NULL:
46
12.3k
        return visitor.template apply<PrimitiveType::TYPE_NULL>(field.template get<TYPE_NULL>());
47
0
    case PrimitiveType::TYPE_DATETIMEV2:
48
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIMEV2>(
49
0
                field.template get<TYPE_DATETIMEV2>());
50
0
    case PrimitiveType::TYPE_TIMESTAMPTZ:
51
0
        return visitor.template apply<PrimitiveType::TYPE_TIMESTAMPTZ>(
52
0
                field.template get<TYPE_TIMESTAMPTZ>());
53
12.3k
    case PrimitiveType::TYPE_LARGEINT:
54
12.3k
        return visitor.template apply<PrimitiveType::TYPE_LARGEINT>(
55
12.3k
                field.template get<TYPE_LARGEINT>());
56
0
    case PrimitiveType::TYPE_DATETIME:
57
0
        return visitor.template apply<PrimitiveType::TYPE_DATETIME>(
58
0
                field.template get<TYPE_DATETIME>());
59
0
    case PrimitiveType::TYPE_DATE:
60
0
        return visitor.template apply<PrimitiveType::TYPE_DATE>(field.template get<TYPE_DATE>());
61
0
    case PrimitiveType::TYPE_DATEV2:
62
0
        return visitor.template apply<PrimitiveType::TYPE_DATEV2>(
63
0
                field.template get<TYPE_DATEV2>());
64
12.4k
    case PrimitiveType::TYPE_BOOLEAN:
65
12.4k
        return visitor.template apply<PrimitiveType::TYPE_BOOLEAN>(
66
12.4k
                field.template get<TYPE_BOOLEAN>());
67
2
    case PrimitiveType::TYPE_TINYINT:
68
2
        return visitor.template apply<PrimitiveType::TYPE_TINYINT>(
69
2
                field.template get<TYPE_TINYINT>());
70
7
    case PrimitiveType::TYPE_SMALLINT:
71
7
        return visitor.template apply<PrimitiveType::TYPE_SMALLINT>(
72
7
                field.template get<TYPE_SMALLINT>());
73
570
    case PrimitiveType::TYPE_INT:
74
570
        return visitor.template apply<PrimitiveType::TYPE_INT>(field.template get<TYPE_INT>());
75
703k
    case PrimitiveType::TYPE_BIGINT:
76
703k
        return visitor.template apply<PrimitiveType::TYPE_BIGINT>(
77
703k
                field.template get<TYPE_BIGINT>());
78
0
    case PrimitiveType::TYPE_UINT32:
79
0
        return visitor.template apply<PrimitiveType::TYPE_UINT32>(
80
0
                field.template get<TYPE_UINT32>());
81
0
    case PrimitiveType::TYPE_UINT64:
82
0
        return visitor.template apply<PrimitiveType::TYPE_UINT64>(
83
0
                field.template get<TYPE_UINT64>());
84
1
    case PrimitiveType::TYPE_FLOAT:
85
1
        return visitor.template apply<PrimitiveType::TYPE_FLOAT>(field.template get<TYPE_FLOAT>());
86
0
    case PrimitiveType::TYPE_TIMEV2:
87
0
        return visitor.template apply<PrimitiveType::TYPE_TIMEV2>(
88
0
                field.template get<TYPE_TIMEV2>());
89
12.6k
    case PrimitiveType::TYPE_DOUBLE:
90
12.6k
        return visitor.template apply<PrimitiveType::TYPE_DOUBLE>(
91
12.6k
                field.template get<TYPE_DOUBLE>());
92
0
    case PrimitiveType::TYPE_IPV4:
93
0
        return visitor.template apply<PrimitiveType::TYPE_IPV4>(field.template get<TYPE_IPV4>());
94
0
    case PrimitiveType::TYPE_IPV6:
95
0
        return visitor.template apply<PrimitiveType::TYPE_IPV6>(field.template get<TYPE_IPV6>());
96
670k
    case PrimitiveType::TYPE_STRING:
97
670k
        return visitor.template apply<PrimitiveType::TYPE_STRING>(
98
670k
                field.template get<TYPE_STRING>());
99
0
    case PrimitiveType::TYPE_CHAR:
100
0
        return visitor.template apply<PrimitiveType::TYPE_CHAR>(field.template get<TYPE_CHAR>());
101
0
    case PrimitiveType::TYPE_VARCHAR:
102
0
        return visitor.template apply<PrimitiveType::TYPE_VARCHAR>(
103
0
                field.template get<TYPE_VARCHAR>());
104
0
    case PrimitiveType::TYPE_VARBINARY:
105
0
        return visitor.template apply<PrimitiveType::TYPE_VARBINARY>(
106
0
                field.template get<TYPE_VARBINARY>());
107
0
    case PrimitiveType::TYPE_ARRAY:
108
0
        return visitor.template apply<PrimitiveType::TYPE_ARRAY>(field.template get<TYPE_ARRAY>());
109
0
    case PrimitiveType::TYPE_STRUCT:
110
0
        return visitor.template apply<PrimitiveType::TYPE_STRUCT>(
111
0
                field.template get<TYPE_STRUCT>());
112
0
    case PrimitiveType::TYPE_MAP:
113
0
        return visitor.template apply<PrimitiveType::TYPE_MAP>(field.template get<TYPE_MAP>());
114
0
    case PrimitiveType::TYPE_VARIANT:
115
0
        return visitor.template apply<PrimitiveType::TYPE_VARIANT>(
116
0
                field.template get<TYPE_VARIANT>());
117
0
    case PrimitiveType::TYPE_DECIMAL32:
118
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL32>(
119
0
                field.template get<TYPE_DECIMAL32>());
120
0
    case PrimitiveType::TYPE_DECIMAL64:
121
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL64>(
122
0
                field.template get<TYPE_DECIMAL64>());
123
0
    case PrimitiveType::TYPE_DECIMALV2:
124
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMALV2>(
125
0
                field.template get<TYPE_DECIMALV2>());
126
0
    case PrimitiveType::TYPE_DECIMAL128I:
127
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL128I>(
128
0
                field.template get<TYPE_DECIMAL128I>());
129
0
    case PrimitiveType::TYPE_DECIMAL256:
130
0
        return visitor.template apply<PrimitiveType::TYPE_DECIMAL256>(
131
0
                field.template get<TYPE_DECIMAL256>());
132
0
    case PrimitiveType::TYPE_BITMAP:
133
0
        return visitor.template apply<PrimitiveType::TYPE_BITMAP>(
134
0
                field.template get<TYPE_BITMAP>());
135
0
    case PrimitiveType::TYPE_HLL:
136
0
        return visitor.template apply<PrimitiveType::TYPE_HLL>(field.template get<TYPE_HLL>());
137
0
    case PrimitiveType::TYPE_QUANTILE_STATE:
138
0
        return visitor.template apply<PrimitiveType::TYPE_QUANTILE_STATE>(
139
0
                field.template get<TYPE_QUANTILE_STATE>());
140
1
    case PrimitiveType::TYPE_JSONB:
141
1
        return visitor.template apply<PrimitiveType::TYPE_JSONB>(field.template get<TYPE_JSONB>());
142
0
    default:
143
0
        throw doris::Exception(ErrorCode::INTERNAL_ERROR, "Bad type of Field {}",
144
0
                               static_cast<int>(field.get_type()));
145
0
        return {};
146
1.42M
    }
147
1.42M
}
148
149
} // namespace doris