Coverage Report

Created: 2026-03-23 17:10

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exprs/aggregate/aggregate_function_distinct.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/AggregateFunctions/AggregateFunctionDistinct.h
19
// and modified by Doris
20
21
#pragma once
22
23
#include <assert.h>
24
#include <glog/logging.h>
25
#include <stddef.h>
26
27
#include <type_traits>
28
#include <utility>
29
#include <vector>
30
31
#include "core/assert_cast.h"
32
#include "core/column/column.h"
33
#include "core/data_type/data_type.h"
34
#include "core/string_ref.h"
35
#include "core/types.h"
36
#include "exprs/aggregate/aggregate_function.h"
37
38
namespace doris {
39
#include "common/compile_check_begin.h"
40
class Arena;
41
class BufferReadable;
42
class BufferWritable;
43
template <PrimitiveType>
44
class ColumnVector;
45
} // namespace doris
46
template <typename, typename>
47
struct DefaultHash;
48
49
namespace doris {
50
51
template <PrimitiveType T, bool stable>
52
struct AggregateFunctionDistinctSingleNumericData {
53
    /// When creating, the hash table must be small.
54
    using Container = std::conditional_t<
55
            stable, phmap::flat_hash_map<typename PrimitiveTypeTraits<T>::CppType, uint32_t>,
56
            phmap::flat_hash_set<typename PrimitiveTypeTraits<T>::CppType>>;
57
    using Self = AggregateFunctionDistinctSingleNumericData<T, stable>;
58
    Container data;
59
60
8
    void clear() { data.clear(); }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE5clearEv
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE5clearEv
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE5clearEv
Line
Count
Source
60
3
    void clear() { data.clear(); }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE5clearEv
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE5clearEv
Line
Count
Source
60
5
    void clear() { data.clear(); }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE5clearEv
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE5clearEv
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE5clearEv
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE5clearEv
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE5clearEv
61
62
7
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena&) {
63
7
        const auto& vec =
64
7
                assert_cast<const ColumnVector<T>&, TypeCheckOnRelease::DISABLE>(*columns[0])
65
7
                        .get_data();
66
7
        if constexpr (stable) {
67
0
            data.emplace(vec[row_num], data.size());
68
7
        } else {
69
7
            data.insert(vec[row_num]);
70
7
        }
71
7
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
62
3
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena&) {
63
3
        const auto& vec =
64
3
                assert_cast<const ColumnVector<T>&, TypeCheckOnRelease::DISABLE>(*columns[0])
65
3
                        .get_data();
66
        if constexpr (stable) {
67
            data.emplace(vec[row_num], data.size());
68
3
        } else {
69
3
            data.insert(vec[row_num]);
70
3
        }
71
3
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
62
4
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena&) {
63
4
        const auto& vec =
64
4
                assert_cast<const ColumnVector<T>&, TypeCheckOnRelease::DISABLE>(*columns[0])
65
4
                        .get_data();
66
        if constexpr (stable) {
67
            data.emplace(vec[row_num], data.size());
68
4
        } else {
69
4
            data.insert(vec[row_num]);
70
4
        }
71
4
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
72
73
0
    void merge(const Self& rhs, Arena&) {
74
0
        DCHECK(!stable);
75
0
        if constexpr (!stable) {
76
0
            data.merge(Container(rhs.data));
77
0
        }
78
0
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE5mergeERKS2_RNS_5ArenaE
79
80
0
    void serialize(BufferWritable& buf) const {
81
0
        DCHECK(!stable);
82
0
        if constexpr (!stable) {
83
0
            buf.write_var_uint(data.size());
84
0
            for (const auto& value : data) {
85
0
                buf.write_binary(value);
86
0
            }
87
0
        }
88
0
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE9serializeERNS_14BufferWritableE
89
90
0
    void deserialize(BufferReadable& buf, Arena&) {
91
0
        DCHECK(!stable);
92
0
        if constexpr (!stable) {
93
0
            uint64_t new_size = 0;
94
0
            buf.read_var_uint(new_size);
95
0
            typename PrimitiveTypeTraits<T>::CppType x;
96
0
            for (size_t i = 0; i < new_size; ++i) {
97
0
                buf.read_binary(x);
98
0
                data.insert(x);
99
0
            }
100
0
        }
101
0
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
102
103
7
    MutableColumns get_arguments(const DataTypes& argument_types) const {
104
7
        MutableColumns argument_columns;
105
7
        argument_columns.emplace_back(argument_types[0]->create_column());
106
107
7
        if constexpr (stable) {
108
0
            argument_columns[0]->resize(data.size());
109
            // argument_columns[0] is a mutable column created using create_column.
110
            // since get_raw_data returns a StringRef, const_cast is required here.
111
0
            auto ptr = (typename PrimitiveTypeTraits<T>::CppType*)const_cast<char*>(
112
0
                    argument_columns[0]->get_raw_data().data);
113
0
            for (auto it : data) {
114
0
                ptr[it.second] = it.first;
115
0
            }
116
7
        } else {
117
7
            for (const auto& elem : data) {
118
4
                argument_columns[0]->insert(Field::create_field<T>(elem));
119
4
            }
120
7
        }
121
122
7
        return argument_columns;
123
7
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
_ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
103
3
    MutableColumns get_arguments(const DataTypes& argument_types) const {
104
3
        MutableColumns argument_columns;
105
3
        argument_columns.emplace_back(argument_types[0]->create_column());
106
107
        if constexpr (stable) {
108
            argument_columns[0]->resize(data.size());
109
            // argument_columns[0] is a mutable column created using create_column.
110
            // since get_raw_data returns a StringRef, const_cast is required here.
111
            auto ptr = (typename PrimitiveTypeTraits<T>::CppType*)const_cast<char*>(
112
                    argument_columns[0]->get_raw_data().data);
113
            for (auto it : data) {
114
                ptr[it.second] = it.first;
115
            }
116
3
        } else {
117
3
            for (const auto& elem : data) {
118
3
                argument_columns[0]->insert(Field::create_field<T>(elem));
119
3
            }
120
3
        }
121
122
3
        return argument_columns;
123
3
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
_ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
103
4
    MutableColumns get_arguments(const DataTypes& argument_types) const {
104
4
        MutableColumns argument_columns;
105
4
        argument_columns.emplace_back(argument_types[0]->create_column());
106
107
        if constexpr (stable) {
108
            argument_columns[0]->resize(data.size());
109
            // argument_columns[0] is a mutable column created using create_column.
110
            // since get_raw_data returns a StringRef, const_cast is required here.
111
            auto ptr = (typename PrimitiveTypeTraits<T>::CppType*)const_cast<char*>(
112
                    argument_columns[0]->get_raw_data().data);
113
            for (auto it : data) {
114
                ptr[it.second] = it.first;
115
            }
116
4
        } else {
117
4
            for (const auto& elem : data) {
118
1
                argument_columns[0]->insert(Field::create_field<T>(elem));
119
1
            }
120
4
        }
121
122
4
        return argument_columns;
123
4
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
124
};
125
126
template <bool stable>
127
struct AggregateFunctionDistinctGenericData {
128
    /// When creating, the hash table must be small.
129
    using Container = std::conditional_t<stable, phmap::flat_hash_map<StringRef, uint32_t>,
130
                                         phmap::flat_hash_set<StringRef, StringRefHash>>;
131
    using Self = AggregateFunctionDistinctGenericData;
132
    Container data;
133
134
43
    void clear() { data.clear(); }
_ZN5doris36AggregateFunctionDistinctGenericDataILb0EE5clearEv
Line
Count
Source
134
29
    void clear() { data.clear(); }
_ZN5doris36AggregateFunctionDistinctGenericDataILb1EE5clearEv
Line
Count
Source
134
14
    void clear() { data.clear(); }
135
136
16
    void merge(const Self& rhs, Arena& arena) {
137
16
        DCHECK(!stable);
138
16
        if constexpr (!stable) {
139
16
            for (const auto& elem : rhs.data) {
140
16
                StringRef key = elem;
141
16
                key.data = arena.insert(key.data, key.size);
142
16
                data.emplace(key);
143
16
            }
144
16
        }
145
16
    }
_ZN5doris36AggregateFunctionDistinctGenericDataILb0EE5mergeERKS1_RNS_5ArenaE
Line
Count
Source
136
16
    void merge(const Self& rhs, Arena& arena) {
137
16
        DCHECK(!stable);
138
16
        if constexpr (!stable) {
139
16
            for (const auto& elem : rhs.data) {
140
16
                StringRef key = elem;
141
16
                key.data = arena.insert(key.data, key.size);
142
16
                data.emplace(key);
143
16
            }
144
16
        }
145
16
    }
Unexecuted instantiation: _ZN5doris36AggregateFunctionDistinctGenericDataILb1EE5mergeERKS1_RNS_5ArenaE
146
147
16
    void serialize(BufferWritable& buf) const {
148
16
        DCHECK(!stable);
149
16
        if constexpr (!stable) {
150
16
            buf.write_var_uint(data.size());
151
16
            for (const auto& elem : data) {
152
16
                buf.write_binary(elem);
153
16
            }
154
16
        }
155
16
    }
_ZNK5doris36AggregateFunctionDistinctGenericDataILb0EE9serializeERNS_14BufferWritableE
Line
Count
Source
147
16
    void serialize(BufferWritable& buf) const {
148
16
        DCHECK(!stable);
149
16
        if constexpr (!stable) {
150
16
            buf.write_var_uint(data.size());
151
16
            for (const auto& elem : data) {
152
16
                buf.write_binary(elem);
153
16
            }
154
16
        }
155
16
    }
Unexecuted instantiation: _ZNK5doris36AggregateFunctionDistinctGenericDataILb1EE9serializeERNS_14BufferWritableE
156
157
16
    void deserialize(BufferReadable& buf, Arena& arena) {
158
16
        DCHECK(!stable);
159
16
        if constexpr (!stable) {
160
16
            UInt64 size;
161
16
            buf.read_var_uint(size);
162
163
16
            StringRef ref;
164
32
            for (size_t i = 0; i < size; ++i) {
165
16
                buf.read_binary(ref);
166
16
                data.insert(ref);
167
16
            }
168
16
        }
169
16
    }
_ZN5doris36AggregateFunctionDistinctGenericDataILb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
157
16
    void deserialize(BufferReadable& buf, Arena& arena) {
158
16
        DCHECK(!stable);
159
16
        if constexpr (!stable) {
160
16
            UInt64 size;
161
16
            buf.read_var_uint(size);
162
163
16
            StringRef ref;
164
32
            for (size_t i = 0; i < size; ++i) {
165
16
                buf.read_binary(ref);
166
16
                data.insert(ref);
167
16
            }
168
16
        }
169
16
    }
Unexecuted instantiation: _ZN5doris36AggregateFunctionDistinctGenericDataILb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
170
};
171
172
template <bool stable>
173
struct AggregateFunctionDistinctSingleGenericData
174
        : public AggregateFunctionDistinctGenericData<stable> {
175
    using Base = AggregateFunctionDistinctGenericData<stable>;
176
    using Base::data;
177
113
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena& arena) {
178
113
        auto key = columns[0]->get_data_at(row_num);
179
113
        key.data = arena.insert(key.data, key.size);
180
181
113
        if constexpr (stable) {
182
15
            data.emplace(key, data.size());
183
98
        } else {
184
98
            data.insert(key);
185
98
        }
186
113
    }
_ZN5doris42AggregateFunctionDistinctSingleGenericDataILb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
177
98
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena& arena) {
178
98
        auto key = columns[0]->get_data_at(row_num);
179
98
        key.data = arena.insert(key.data, key.size);
180
181
        if constexpr (stable) {
182
            data.emplace(key, data.size());
183
98
        } else {
184
98
            data.insert(key);
185
98
        }
186
98
    }
_ZN5doris42AggregateFunctionDistinctSingleGenericDataILb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
177
15
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena& arena) {
178
15
        auto key = columns[0]->get_data_at(row_num);
179
15
        key.data = arena.insert(key.data, key.size);
180
181
15
        if constexpr (stable) {
182
15
            data.emplace(key, data.size());
183
        } else {
184
            data.insert(key);
185
        }
186
15
    }
187
188
23
    MutableColumns get_arguments(const DataTypes& argument_types) const {
189
23
        MutableColumns argument_columns;
190
23
        argument_columns.emplace_back(argument_types[0]->create_column());
191
23
        if constexpr (stable) {
192
7
            std::vector<StringRef> tmp(data.size());
193
14
            for (auto it : data) {
194
14
                tmp[it.second] = it.first;
195
14
            }
196
21
            for (int i = 0; i < data.size(); i++) {
197
14
                argument_columns[0]->insert_data(tmp[i].data, tmp[i].size);
198
14
            }
199
16
        } else {
200
45
            for (const auto& elem : data) {
201
45
                argument_columns[0]->insert_data(elem.data, elem.size);
202
45
            }
203
16
        }
204
205
23
        return argument_columns;
206
23
    }
_ZNK5doris42AggregateFunctionDistinctSingleGenericDataILb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS6_EE
Line
Count
Source
188
16
    MutableColumns get_arguments(const DataTypes& argument_types) const {
189
16
        MutableColumns argument_columns;
190
16
        argument_columns.emplace_back(argument_types[0]->create_column());
191
        if constexpr (stable) {
192
            std::vector<StringRef> tmp(data.size());
193
            for (auto it : data) {
194
                tmp[it.second] = it.first;
195
            }
196
            for (int i = 0; i < data.size(); i++) {
197
                argument_columns[0]->insert_data(tmp[i].data, tmp[i].size);
198
            }
199
16
        } else {
200
45
            for (const auto& elem : data) {
201
45
                argument_columns[0]->insert_data(elem.data, elem.size);
202
45
            }
203
16
        }
204
205
16
        return argument_columns;
206
16
    }
_ZNK5doris42AggregateFunctionDistinctSingleGenericDataILb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS6_EE
Line
Count
Source
188
7
    MutableColumns get_arguments(const DataTypes& argument_types) const {
189
7
        MutableColumns argument_columns;
190
7
        argument_columns.emplace_back(argument_types[0]->create_column());
191
7
        if constexpr (stable) {
192
7
            std::vector<StringRef> tmp(data.size());
193
14
            for (auto it : data) {
194
14
                tmp[it.second] = it.first;
195
14
            }
196
21
            for (int i = 0; i < data.size(); i++) {
197
14
                argument_columns[0]->insert_data(tmp[i].data, tmp[i].size);
198
14
            }
199
        } else {
200
            for (const auto& elem : data) {
201
                argument_columns[0]->insert_data(elem.data, elem.size);
202
            }
203
        }
204
205
7
        return argument_columns;
206
7
    }
207
};
208
209
template <bool stable>
210
struct AggregateFunctionDistinctMultipleGenericData
211
        : public AggregateFunctionDistinctGenericData<stable> {
212
    using Base = AggregateFunctionDistinctGenericData<stable>;
213
    using Base::data;
214
33
    void add(const IColumn** columns, size_t columns_num, size_t row_num, Arena& arena) {
215
33
        const char* begin = nullptr;
216
33
        StringRef key(begin, 0);
217
99
        for (size_t i = 0; i < columns_num; ++i) {
218
66
            auto cur_ref = columns[i]->serialize_value_into_arena(row_num, arena, begin);
219
66
            key.data = cur_ref.data - key.size;
220
66
            key.size += cur_ref.size;
221
66
        }
222
223
33
        if constexpr (stable) {
224
15
            data.emplace(key, data.size());
225
18
        } else {
226
18
            data.emplace(key);
227
18
        }
228
33
    }
_ZN5doris44AggregateFunctionDistinctMultipleGenericDataILb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
214
18
    void add(const IColumn** columns, size_t columns_num, size_t row_num, Arena& arena) {
215
18
        const char* begin = nullptr;
216
18
        StringRef key(begin, 0);
217
54
        for (size_t i = 0; i < columns_num; ++i) {
218
36
            auto cur_ref = columns[i]->serialize_value_into_arena(row_num, arena, begin);
219
36
            key.data = cur_ref.data - key.size;
220
36
            key.size += cur_ref.size;
221
36
        }
222
223
        if constexpr (stable) {
224
            data.emplace(key, data.size());
225
18
        } else {
226
18
            data.emplace(key);
227
18
        }
228
18
    }
_ZN5doris44AggregateFunctionDistinctMultipleGenericDataILb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
214
15
    void add(const IColumn** columns, size_t columns_num, size_t row_num, Arena& arena) {
215
15
        const char* begin = nullptr;
216
15
        StringRef key(begin, 0);
217
45
        for (size_t i = 0; i < columns_num; ++i) {
218
30
            auto cur_ref = columns[i]->serialize_value_into_arena(row_num, arena, begin);
219
30
            key.data = cur_ref.data - key.size;
220
30
            key.size += cur_ref.size;
221
30
        }
222
223
15
        if constexpr (stable) {
224
15
            data.emplace(key, data.size());
225
        } else {
226
            data.emplace(key);
227
        }
228
15
    }
229
230
19
    MutableColumns get_arguments(const DataTypes& argument_types) const {
231
19
        MutableColumns argument_columns(argument_types.size());
232
57
        for (size_t i = 0; i < argument_types.size(); ++i) {
233
38
            argument_columns[i] = argument_types[i]->create_column();
234
38
        }
235
236
19
        if constexpr (stable) {
237
7
            std::vector<StringRef> tmp(data.size());
238
14
            for (auto it : data) {
239
14
                tmp[it.second] = it.first;
240
14
            }
241
21
            for (int i = 0; i < data.size(); i++) {
242
14
                const char* begin = tmp[i].data;
243
28
                for (auto& column : argument_columns) {
244
28
                    begin = column->deserialize_and_insert_from_arena(begin);
245
28
                }
246
14
            }
247
12
        } else {
248
12
            for (const auto& elem : data) {
249
12
                const char* begin = elem.data;
250
24
                for (auto& column : argument_columns) {
251
24
                    begin = column->deserialize_and_insert_from_arena(begin);
252
24
                }
253
12
            }
254
12
        }
255
256
19
        return argument_columns;
257
19
    }
_ZNK5doris44AggregateFunctionDistinctMultipleGenericDataILb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS6_EE
Line
Count
Source
230
12
    MutableColumns get_arguments(const DataTypes& argument_types) const {
231
12
        MutableColumns argument_columns(argument_types.size());
232
36
        for (size_t i = 0; i < argument_types.size(); ++i) {
233
24
            argument_columns[i] = argument_types[i]->create_column();
234
24
        }
235
236
        if constexpr (stable) {
237
            std::vector<StringRef> tmp(data.size());
238
            for (auto it : data) {
239
                tmp[it.second] = it.first;
240
            }
241
            for (int i = 0; i < data.size(); i++) {
242
                const char* begin = tmp[i].data;
243
                for (auto& column : argument_columns) {
244
                    begin = column->deserialize_and_insert_from_arena(begin);
245
                }
246
            }
247
12
        } else {
248
12
            for (const auto& elem : data) {
249
12
                const char* begin = elem.data;
250
24
                for (auto& column : argument_columns) {
251
24
                    begin = column->deserialize_and_insert_from_arena(begin);
252
24
                }
253
12
            }
254
12
        }
255
256
12
        return argument_columns;
257
12
    }
_ZNK5doris44AggregateFunctionDistinctMultipleGenericDataILb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS6_EE
Line
Count
Source
230
7
    MutableColumns get_arguments(const DataTypes& argument_types) const {
231
7
        MutableColumns argument_columns(argument_types.size());
232
21
        for (size_t i = 0; i < argument_types.size(); ++i) {
233
14
            argument_columns[i] = argument_types[i]->create_column();
234
14
        }
235
236
7
        if constexpr (stable) {
237
7
            std::vector<StringRef> tmp(data.size());
238
14
            for (auto it : data) {
239
14
                tmp[it.second] = it.first;
240
14
            }
241
21
            for (int i = 0; i < data.size(); i++) {
242
14
                const char* begin = tmp[i].data;
243
28
                for (auto& column : argument_columns) {
244
28
                    begin = column->deserialize_and_insert_from_arena(begin);
245
28
                }
246
14
            }
247
        } else {
248
            for (const auto& elem : data) {
249
                const char* begin = elem.data;
250
                for (auto& column : argument_columns) {
251
                    begin = column->deserialize_and_insert_from_arena(begin);
252
                }
253
            }
254
        }
255
256
7
        return argument_columns;
257
7
    }
258
};
259
260
/** Adaptor for aggregate functions.
261
  * Adding -Distinct suffix to aggregate function
262
**/
263
template <template <bool stable> typename Data, bool stable = false>
264
class AggregateFunctionDistinct
265
        : public IAggregateFunctionDataHelper<Data<stable>,
266
                                              AggregateFunctionDistinct<Data, stable>>,
267
          VarargsExpression,
268
          NullableAggregateFunction {
269
private:
270
    size_t prefix_size;
271
    AggregateFunctionPtr nested_func;
272
    size_t arguments_num;
273
274
342
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
342
        return place + prefix_size;
276
342
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE16get_nested_placeEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE16get_nested_placeEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE16get_nested_placeEPc
Line
Count
Source
274
12
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
12
        return place + prefix_size;
276
12
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE16get_nested_placeEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE16get_nested_placeEPc
Line
Count
Source
274
11
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
11
        return place + prefix_size;
276
11
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE16get_nested_placeEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE16get_nested_placeEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE16get_nested_placeEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE16get_nested_placeEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE16get_nested_placeEPc
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE16get_nested_placeEPc
Line
Count
Source
274
75
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
75
        return place + prefix_size;
276
75
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE16get_nested_placeEPc
Line
Count
Source
274
74
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
74
        return place + prefix_size;
276
74
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE16get_nested_placeEPc
Line
Count
Source
274
96
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
96
        return place + prefix_size;
276
96
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE16get_nested_placeEPc
Line
Count
Source
274
74
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
74
        return place + prefix_size;
276
74
    }
277
278
    ConstAggregateDataPtr get_nested_place(ConstAggregateDataPtr __restrict place) const noexcept {
279
        return place + prefix_size;
280
    }
281
282
public:
283
    AggregateFunctionDistinct(AggregateFunctionPtr nested_func_, const DataTypes& arguments)
284
31
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
31
                      arguments),
286
31
              nested_func(std::move(nested_func_)),
287
31
              arguments_num(arguments.size()) {
288
31
        size_t nested_size = nested_func->align_of_data();
289
31
        CHECK_GT(nested_size, 0);
290
31
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
31
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
_ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
Line
Count
Source
284
1
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
1
                      arguments),
286
1
              nested_func(std::move(nested_func_)),
287
1
              arguments_num(arguments.size()) {
288
1
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
1
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
1
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
_ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
Line
Count
Source
284
3
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
3
                      arguments),
286
3
              nested_func(std::move(nested_func_)),
287
3
              arguments_num(arguments.size()) {
288
3
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
3
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
3
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
_ZN5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS3_IKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
284
9
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
9
                      arguments),
286
9
              nested_func(std::move(nested_func_)),
287
9
              arguments_num(arguments.size()) {
288
9
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
9
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
9
    }
_ZN5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS3_IKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
284
2
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
2
                      arguments),
286
2
              nested_func(std::move(nested_func_)),
287
2
              arguments_num(arguments.size()) {
288
2
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
2
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
2
    }
_ZN5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS3_IKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
284
14
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
14
                      arguments),
286
14
              nested_func(std::move(nested_func_)),
287
14
              arguments_num(arguments.size()) {
288
14
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
14
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
14
    }
_ZN5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS3_IKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
284
2
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
2
                      arguments),
286
2
              nested_func(std::move(nested_func_)),
287
2
              arguments_num(arguments.size()) {
288
2
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
2
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
2
    }
292
293
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
294
153
             Arena& arena) const override {
295
153
        this->data(place).add(columns, arguments_num, row_num, arena);
296
153
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
3
             Arena& arena) const override {
295
3
        this->data(place).add(columns, arguments_num, row_num, arena);
296
3
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
4
             Arena& arena) const override {
295
4
        this->data(place).add(columns, arguments_num, row_num, arena);
296
4
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
98
             Arena& arena) const override {
295
98
        this->data(place).add(columns, arguments_num, row_num, arena);
296
98
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
15
             Arena& arena) const override {
295
15
        this->data(place).add(columns, arguments_num, row_num, arena);
296
15
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
18
             Arena& arena) const override {
295
18
        this->data(place).add(columns, arguments_num, row_num, arena);
296
18
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
15
             Arena& arena) const override {
295
15
        this->data(place).add(columns, arguments_num, row_num, arena);
296
15
    }
297
298
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
299
16
               Arena& arena) const override {
300
16
        this->data(place).merge(this->data(rhs), arena);
301
16
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE5mergeEPcPKcRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
299
4
               Arena& arena) const override {
300
4
        this->data(place).merge(this->data(rhs), arena);
301
4
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE5mergeEPcPKcRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
299
12
               Arena& arena) const override {
300
12
        this->data(place).merge(this->data(rhs), arena);
301
12
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE5mergeEPcPKcRNS_5ArenaE
302
303
16
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
304
16
        this->data(place).serialize(buf);
305
16
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
303
4
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
304
4
        this->data(place).serialize(buf);
305
4
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
303
12
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
304
12
        this->data(place).serialize(buf);
305
12
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE9serializeEPKcRNS_14BufferWritableE
306
307
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
308
16
                     Arena& arena) const override {
309
16
        this->data(place).deserialize(buf, arena);
310
16
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
308
4
                     Arena& arena) const override {
309
4
        this->data(place).deserialize(buf, arena);
310
4
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
308
12
                     Arena& arena) const override {
309
12
        this->data(place).deserialize(buf, arena);
310
12
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
311
312
49
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
49
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
49
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
49
        ColumnRawPtrs arguments_raw(arguments.size());
317
117
        for (size_t i = 0; i < arguments.size(); ++i) {
318
68
            arguments_raw[i] = arguments[i].get();
319
68
        }
320
321
49
        assert(!arguments.empty());
322
49
        Arena arena;
323
49
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
49
                                            arguments_raw.data(), arena);
325
49
        nested_func->insert_result_into(get_nested_place(place), to);
326
        // for distinct agg function, the real calculate is add_batch_single_place at last step of insert_result_into function.
327
        // but with distinct agg and over() window function together, the result will be inserted into many times with different rows
328
        // so we need to clear the data, thus not to affect the next insert_result_into
329
49
        this->data(place).clear();
330
49
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
3
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
3
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
3
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
3
        ColumnRawPtrs arguments_raw(arguments.size());
317
6
        for (size_t i = 0; i < arguments.size(); ++i) {
318
3
            arguments_raw[i] = arguments[i].get();
319
3
        }
320
321
3
        assert(!arguments.empty());
322
3
        Arena arena;
323
3
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
3
                                            arguments_raw.data(), arena);
325
3
        nested_func->insert_result_into(get_nested_place(place), to);
326
        // for distinct agg function, the real calculate is add_batch_single_place at last step of insert_result_into function.
327
        // but with distinct agg and over() window function together, the result will be inserted into many times with different rows
328
        // so we need to clear the data, thus not to affect the next insert_result_into
329
3
        this->data(place).clear();
330
3
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
4
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
4
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
4
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
4
        ColumnRawPtrs arguments_raw(arguments.size());
317
8
        for (size_t i = 0; i < arguments.size(); ++i) {
318
4
            arguments_raw[i] = arguments[i].get();
319
4
        }
320
321
4
        assert(!arguments.empty());
322
4
        Arena arena;
323
4
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
4
                                            arguments_raw.data(), arena);
325
4
        nested_func->insert_result_into(get_nested_place(place), to);
326
        // for distinct agg function, the real calculate is add_batch_single_place at last step of insert_result_into function.
327
        // but with distinct agg and over() window function together, the result will be inserted into many times with different rows
328
        // so we need to clear the data, thus not to affect the next insert_result_into
329
4
        this->data(place).clear();
330
4
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE18insert_result_intoEPKcRNS_7IColumnE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
16
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
16
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
16
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
16
        ColumnRawPtrs arguments_raw(arguments.size());
317
32
        for (size_t i = 0; i < arguments.size(); ++i) {
318
16
            arguments_raw[i] = arguments[i].get();
319
16
        }
320
321
16
        assert(!arguments.empty());
322
16
        Arena arena;
323
16
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
16
                                            arguments_raw.data(), arena);
325
16
        nested_func->insert_result_into(get_nested_place(place), to);
326
        // for distinct agg function, the real calculate is add_batch_single_place at last step of insert_result_into function.
327
        // but with distinct agg and over() window function together, the result will be inserted into many times with different rows
328
        // so we need to clear the data, thus not to affect the next insert_result_into
329
16
        this->data(place).clear();
330
16
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
7
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
7
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
7
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
7
        ColumnRawPtrs arguments_raw(arguments.size());
317
14
        for (size_t i = 0; i < arguments.size(); ++i) {
318
7
            arguments_raw[i] = arguments[i].get();
319
7
        }
320
321
7
        assert(!arguments.empty());
322
7
        Arena arena;
323
7
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
7
                                            arguments_raw.data(), arena);
325
7
        nested_func->insert_result_into(get_nested_place(place), to);
326
        // for distinct agg function, the real calculate is add_batch_single_place at last step of insert_result_into function.
327
        // but with distinct agg and over() window function together, the result will be inserted into many times with different rows
328
        // so we need to clear the data, thus not to affect the next insert_result_into
329
7
        this->data(place).clear();
330
7
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
12
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
12
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
12
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
12
        ColumnRawPtrs arguments_raw(arguments.size());
317
36
        for (size_t i = 0; i < arguments.size(); ++i) {
318
24
            arguments_raw[i] = arguments[i].get();
319
24
        }
320
321
12
        assert(!arguments.empty());
322
12
        Arena arena;
323
12
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
12
                                            arguments_raw.data(), arena);
325
12
        nested_func->insert_result_into(get_nested_place(place), to);
326
        // for distinct agg function, the real calculate is add_batch_single_place at last step of insert_result_into function.
327
        // but with distinct agg and over() window function together, the result will be inserted into many times with different rows
328
        // so we need to clear the data, thus not to affect the next insert_result_into
329
12
        this->data(place).clear();
330
12
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
7
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
7
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
7
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
7
        ColumnRawPtrs arguments_raw(arguments.size());
317
21
        for (size_t i = 0; i < arguments.size(); ++i) {
318
14
            arguments_raw[i] = arguments[i].get();
319
14
        }
320
321
7
        assert(!arguments.empty());
322
7
        Arena arena;
323
7
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
7
                                            arguments_raw.data(), arena);
325
7
        nested_func->insert_result_into(get_nested_place(place), to);
326
        // for distinct agg function, the real calculate is add_batch_single_place at last step of insert_result_into function.
327
        // but with distinct agg and over() window function together, the result will be inserted into many times with different rows
328
        // so we need to clear the data, thus not to affect the next insert_result_into
329
7
        this->data(place).clear();
330
7
    }
331
332
2
    void reset(AggregateDataPtr place) const override {
333
2
        this->data(place).clear();
334
2
        nested_func->reset(get_nested_place(place));
335
2
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE5resetEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE5resetEPc
Line
Count
Source
332
1
    void reset(AggregateDataPtr place) const override {
333
1
        this->data(place).clear();
334
1
        nested_func->reset(get_nested_place(place));
335
1
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE5resetEPc
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE5resetEPc
Line
Count
Source
332
1
    void reset(AggregateDataPtr place) const override {
333
1
        this->data(place).clear();
334
1
        nested_func->reset(get_nested_place(place));
335
1
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE5resetEPc
336
337
129
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE12size_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE12size_of_dataEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE12size_of_dataEv
Line
Count
Source
337
1
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE12size_of_dataEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE12size_of_dataEv
Line
Count
Source
337
3
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE12size_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE12size_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE12size_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE12size_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE12size_of_dataEv
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE12size_of_dataEv
Line
Count
Source
337
19
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE12size_of_dataEv
Line
Count
Source
337
29
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE12size_of_dataEv
Line
Count
Source
337
48
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE12size_of_dataEv
Line
Count
Source
337
29
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
338
339
52
    size_t align_of_data() const override { return nested_func->align_of_data(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE13align_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE13align_of_dataEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE13align_of_dataEv
Line
Count
Source
339
3
    size_t align_of_data() const override { return nested_func->align_of_data(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE13align_of_dataEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE13align_of_dataEv
Line
Count
Source
339
7
    size_t align_of_data() const override { return nested_func->align_of_data(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE13align_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE13align_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE13align_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE13align_of_dataEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE13align_of_dataEv
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE13align_of_dataEv
Line
Count
Source
339
14
    size_t align_of_data() const override { return nested_func->align_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE13align_of_dataEv
Line
Count
Source
339
4
    size_t align_of_data() const override { return nested_func->align_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE13align_of_dataEv
Line
Count
Source
339
20
    size_t align_of_data() const override { return nested_func->align_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE13align_of_dataEv
Line
Count
Source
339
4
    size_t align_of_data() const override { return nested_func->align_of_data(); }
340
341
121
    void create(AggregateDataPtr __restrict place) const override {
342
121
        new (place) Data<stable>;
343
121
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
121
                    this->data(place).~Data<stable>());
345
121
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE6createEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE6createEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE6createEPc
Line
Count
Source
341
3
    void create(AggregateDataPtr __restrict place) const override {
342
3
        new (place) Data<stable>;
343
3
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
3
                    this->data(place).~Data<stable>());
345
3
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE6createEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE6createEPc
Line
Count
Source
341
1
    void create(AggregateDataPtr __restrict place) const override {
342
1
        new (place) Data<stable>;
343
1
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
1
                    this->data(place).~Data<stable>());
345
1
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE6createEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE6createEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE6createEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE6createEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE6createEPc
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE6createEPc
Line
Count
Source
341
21
    void create(AggregateDataPtr __restrict place) const override {
342
21
        new (place) Data<stable>;
343
21
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
21
                    this->data(place).~Data<stable>());
345
21
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE6createEPc
Line
Count
Source
341
30
    void create(AggregateDataPtr __restrict place) const override {
342
30
        new (place) Data<stable>;
343
30
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
30
                    this->data(place).~Data<stable>());
345
30
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE6createEPc
Line
Count
Source
341
36
    void create(AggregateDataPtr __restrict place) const override {
342
36
        new (place) Data<stable>;
343
36
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
36
                    this->data(place).~Data<stable>());
345
36
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE6createEPc
Line
Count
Source
341
30
    void create(AggregateDataPtr __restrict place) const override {
342
30
        new (place) Data<stable>;
343
30
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
30
                    this->data(place).~Data<stable>());
345
30
    }
346
347
121
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
121
        this->data(place).~Data<stable>();
349
121
        nested_func->destroy(get_nested_place(place));
350
121
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE7destroyEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE7destroyEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE7destroyEPc
Line
Count
Source
347
3
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
3
        this->data(place).~Data<stable>();
349
3
        nested_func->destroy(get_nested_place(place));
350
3
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE7destroyEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE7destroyEPc
Line
Count
Source
347
1
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
1
        this->data(place).~Data<stable>();
349
1
        nested_func->destroy(get_nested_place(place));
350
1
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE7destroyEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE7destroyEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE7destroyEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE7destroyEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE7destroyEPc
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE7destroyEPc
Line
Count
Source
347
21
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
21
        this->data(place).~Data<stable>();
349
21
        nested_func->destroy(get_nested_place(place));
350
21
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE7destroyEPc
Line
Count
Source
347
30
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
30
        this->data(place).~Data<stable>();
349
30
        nested_func->destroy(get_nested_place(place));
350
30
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE7destroyEPc
Line
Count
Source
347
36
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
36
        this->data(place).~Data<stable>();
349
36
        nested_func->destroy(get_nested_place(place));
350
36
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE7destroyEPc
Line
Count
Source
347
30
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
30
        this->data(place).~Data<stable>();
349
30
        nested_func->destroy(get_nested_place(place));
350
30
    }
351
352
2
    String get_name() const override { return nested_func->get_name() + "Distinct"; }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE8get_nameB5cxx11Ev
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE8get_nameB5cxx11Ev
Line
Count
Source
352
1
    String get_name() const override { return nested_func->get_name() + "Distinct"; }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE8get_nameB5cxx11Ev
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE8get_nameB5cxx11Ev
Line
Count
Source
352
1
    String get_name() const override { return nested_func->get_name() + "Distinct"; }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE8get_nameB5cxx11Ev
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE8get_nameB5cxx11Ev
353
354
43
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE15get_return_typeEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE15get_return_typeEv
Line
Count
Source
354
2
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE15get_return_typeEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE15get_return_typeEv
Line
Count
Source
354
5
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE15get_return_typeEv
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE15get_return_typeEv
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE15get_return_typeEv
Line
Count
Source
354
12
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE15get_return_typeEv
Line
Count
Source
354
3
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE15get_return_typeEv
Line
Count
Source
354
18
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE15get_return_typeEv
Line
Count
Source
354
3
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
355
356
4
    IAggregateFunction* transmit_to_stable() override {
357
4
        return new AggregateFunctionDistinct<Data, true>(nested_func,
358
4
                                                         IAggregateFunction::argument_types);
359
4
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE18transmit_to_stableEv
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE18transmit_to_stableEv
_ZN5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE18transmit_to_stableEv
Line
Count
Source
356
2
    IAggregateFunction* transmit_to_stable() override {
357
2
        return new AggregateFunctionDistinct<Data, true>(nested_func,
358
2
                                                         IAggregateFunction::argument_types);
359
2
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE18transmit_to_stableEv
_ZN5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE18transmit_to_stableEv
Line
Count
Source
356
2
    IAggregateFunction* transmit_to_stable() override {
357
2
        return new AggregateFunctionDistinct<Data, true>(nested_func,
358
2
                                                         IAggregateFunction::argument_types);
359
2
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE18transmit_to_stableEv
360
};
361
362
template <typename T>
363
struct FunctionStableTransfer {
364
    using FunctionStable = T;
365
};
366
367
template <template <bool stable> typename Data>
368
struct FunctionStableTransfer<AggregateFunctionDistinct<Data, false>> {
369
    using FunctionStable = AggregateFunctionDistinct<Data, true>;
370
};
371
372
} // namespace doris
373
374
#include "common/compile_check_end.h"