Coverage Report

Created: 2026-04-03 12:33

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
423
    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
342
    void clear() { data.clear(); }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE5clearEv
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE5clearEv
Line
Count
Source
60
78
    void clear() { data.clear(); }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE5clearEv
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE5clearEv
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE5clearEv
61
62
788
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena&) {
63
788
        const auto& vec =
64
788
                assert_cast<const ColumnVector<T>&, TypeCheckOnRelease::DISABLE>(*columns[0])
65
788
                        .get_data();
66
788
        if constexpr (stable) {
67
0
            data.emplace(vec[row_num], data.size());
68
788
        } else {
69
788
            data.insert(vec[row_num]);
70
788
        }
71
788
    }
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
716
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena&) {
63
716
        const auto& vec =
64
716
                assert_cast<const ColumnVector<T>&, TypeCheckOnRelease::DISABLE>(*columns[0])
65
716
                        .get_data();
66
        if constexpr (stable) {
67
            data.emplace(vec[row_num], data.size());
68
716
        } else {
69
716
            data.insert(vec[row_num]);
70
716
        }
71
716
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
62
69
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena&) {
63
69
        const auto& vec =
64
69
                assert_cast<const ColumnVector<T>&, TypeCheckOnRelease::DISABLE>(*columns[0])
65
69
                        .get_data();
66
        if constexpr (stable) {
67
            data.emplace(vec[row_num], data.size());
68
69
        } else {
69
69
            data.insert(vec[row_num]);
70
69
        }
71
69
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
72
73
481
    void merge(const Self& rhs, Arena&) {
74
481
        DCHECK(!stable);
75
481
        if constexpr (!stable) {
76
481
            data.merge(Container(rhs.data));
77
481
        }
78
481
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE5mergeERKS2_RNS_5ArenaE
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE5mergeERKS2_RNS_5ArenaE
Line
Count
Source
73
435
    void merge(const Self& rhs, Arena&) {
74
435
        DCHECK(!stable);
75
435
        if constexpr (!stable) {
76
435
            data.merge(Container(rhs.data));
77
435
        }
78
435
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE5mergeERKS2_RNS_5ArenaE
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE5mergeERKS2_RNS_5ArenaE
Line
Count
Source
73
46
    void merge(const Self& rhs, Arena&) {
74
46
        DCHECK(!stable);
75
46
        if constexpr (!stable) {
76
46
            data.merge(Container(rhs.data));
77
46
        }
78
46
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE5mergeERKS2_RNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE5mergeERKS2_RNS_5ArenaE
79
80
559
    void serialize(BufferWritable& buf) const {
81
559
        DCHECK(!stable);
82
559
        if constexpr (!stable) {
83
559
            buf.write_var_uint(data.size());
84
559
            for (const auto& value : data) {
85
559
                buf.write_binary(value);
86
559
            }
87
559
        }
88
559
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE9serializeERNS_14BufferWritableE
_ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE9serializeERNS_14BufferWritableE
Line
Count
Source
80
513
    void serialize(BufferWritable& buf) const {
81
513
        DCHECK(!stable);
82
513
        if constexpr (!stable) {
83
513
            buf.write_var_uint(data.size());
84
515
            for (const auto& value : data) {
85
515
                buf.write_binary(value);
86
515
            }
87
513
        }
88
513
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE9serializeERNS_14BufferWritableE
_ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE9serializeERNS_14BufferWritableE
Line
Count
Source
80
46
    void serialize(BufferWritable& buf) const {
81
46
        DCHECK(!stable);
82
46
        if constexpr (!stable) {
83
46
            buf.write_var_uint(data.size());
84
46
            for (const auto& value : data) {
85
44
                buf.write_binary(value);
86
44
            }
87
46
        }
88
46
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE9serializeERNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE9serializeERNS_14BufferWritableE
89
90
481
    void deserialize(BufferReadable& buf, Arena&) {
91
481
        DCHECK(!stable);
92
481
        if constexpr (!stable) {
93
481
            uint64_t new_size = 0;
94
481
            buf.read_var_uint(new_size);
95
481
            typename PrimitiveTypeTraits<T>::CppType x;
96
962
            for (size_t i = 0; i < new_size; ++i) {
97
481
                buf.read_binary(x);
98
481
                data.insert(x);
99
481
            }
100
481
        }
101
481
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE3ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE4ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
90
435
    void deserialize(BufferReadable& buf, Arena&) {
91
435
        DCHECK(!stable);
92
435
        if constexpr (!stable) {
93
435
            uint64_t new_size = 0;
94
435
            buf.read_var_uint(new_size);
95
435
            typename PrimitiveTypeTraits<T>::CppType x;
96
872
            for (size_t i = 0; i < new_size; ++i) {
97
437
                buf.read_binary(x);
98
437
                data.insert(x);
99
437
            }
100
435
        }
101
435
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
_ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
90
46
    void deserialize(BufferReadable& buf, Arena&) {
91
46
        DCHECK(!stable);
92
46
        if constexpr (!stable) {
93
46
            uint64_t new_size = 0;
94
46
            buf.read_var_uint(new_size);
95
46
            typename PrimitiveTypeTraits<T>::CppType x;
96
90
            for (size_t i = 0; i < new_size; ++i) {
97
44
                buf.read_binary(x);
98
44
                data.insert(x);
99
44
            }
100
46
        }
101
46
    }
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Unexecuted instantiation: _ZN5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE7ELb1EE11deserializeERNS_14BufferReadableERNS_5ArenaE
102
103
349
    MutableColumns get_arguments(const DataTypes& argument_types) const {
104
349
        MutableColumns argument_columns;
105
349
        argument_columns.emplace_back(argument_types[0]->create_column());
106
107
349
        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
349
        } else {
117
425
            for (const auto& elem : data) {
118
425
                argument_columns[0]->insert(Field::create_field<T>(elem));
119
425
            }
120
349
        }
121
122
349
        return argument_columns;
123
349
    }
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
284
    MutableColumns get_arguments(const DataTypes& argument_types) const {
104
284
        MutableColumns argument_columns;
105
284
        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
284
        } else {
117
368
            for (const auto& elem : data) {
118
368
                argument_columns[0]->insert(Field::create_field<T>(elem));
119
368
            }
120
284
        }
121
122
284
        return argument_columns;
123
284
    }
Unexecuted instantiation: _ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE5ELb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
_ZNK5doris42AggregateFunctionDistinctSingleNumericDataILNS_13PrimitiveTypeE6ELb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS7_EE
Line
Count
Source
103
62
    MutableColumns get_arguments(const DataTypes& argument_types) const {
104
62
        MutableColumns argument_columns;
105
62
        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
62
        } else {
117
62
            for (const auto& elem : data) {
118
54
                argument_columns[0]->insert(Field::create_field<T>(elem));
119
54
            }
120
62
        }
121
122
62
        return argument_columns;
123
62
    }
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
315
    void clear() { data.clear(); }
_ZN5doris36AggregateFunctionDistinctGenericDataILb0EE5clearEv
Line
Count
Source
134
229
    void clear() { data.clear(); }
_ZN5doris36AggregateFunctionDistinctGenericDataILb1EE5clearEv
Line
Count
Source
134
86
    void clear() { data.clear(); }
135
136
228
    void merge(const Self& rhs, Arena& arena) {
137
228
        DCHECK(!stable);
138
228
        if constexpr (!stable) {
139
258
            for (const auto& elem : rhs.data) {
140
258
                StringRef key = elem;
141
258
                key.data = arena.insert(key.data, key.size);
142
258
                data.emplace(key);
143
258
            }
144
228
        }
145
228
    }
_ZN5doris36AggregateFunctionDistinctGenericDataILb0EE5mergeERKS1_RNS_5ArenaE
Line
Count
Source
136
228
    void merge(const Self& rhs, Arena& arena) {
137
228
        DCHECK(!stable);
138
228
        if constexpr (!stable) {
139
258
            for (const auto& elem : rhs.data) {
140
258
                StringRef key = elem;
141
258
                key.data = arena.insert(key.data, key.size);
142
258
                data.emplace(key);
143
258
            }
144
228
        }
145
228
    }
Unexecuted instantiation: _ZN5doris36AggregateFunctionDistinctGenericDataILb1EE5mergeERKS1_RNS_5ArenaE
146
147
270
    void serialize(BufferWritable& buf) const {
148
270
        DCHECK(!stable);
149
270
        if constexpr (!stable) {
150
270
            buf.write_var_uint(data.size());
151
303
            for (const auto& elem : data) {
152
303
                buf.write_binary(elem);
153
303
            }
154
270
        }
155
270
    }
_ZNK5doris36AggregateFunctionDistinctGenericDataILb0EE9serializeERNS_14BufferWritableE
Line
Count
Source
147
270
    void serialize(BufferWritable& buf) const {
148
270
        DCHECK(!stable);
149
270
        if constexpr (!stable) {
150
270
            buf.write_var_uint(data.size());
151
303
            for (const auto& elem : data) {
152
303
                buf.write_binary(elem);
153
303
            }
154
270
        }
155
270
    }
Unexecuted instantiation: _ZNK5doris36AggregateFunctionDistinctGenericDataILb1EE9serializeERNS_14BufferWritableE
156
157
228
    void deserialize(BufferReadable& buf, Arena& arena) {
158
228
        DCHECK(!stable);
159
228
        if constexpr (!stable) {
160
228
            UInt64 size;
161
228
            buf.read_var_uint(size);
162
163
228
            StringRef ref;
164
486
            for (size_t i = 0; i < size; ++i) {
165
258
                buf.read_binary(ref);
166
258
                data.insert(ref);
167
258
            }
168
228
        }
169
228
    }
_ZN5doris36AggregateFunctionDistinctGenericDataILb0EE11deserializeERNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
157
228
    void deserialize(BufferReadable& buf, Arena& arena) {
158
228
        DCHECK(!stable);
159
228
        if constexpr (!stable) {
160
228
            UInt64 size;
161
228
            buf.read_var_uint(size);
162
163
228
            StringRef ref;
164
486
            for (size_t i = 0; i < size; ++i) {
165
258
                buf.read_binary(ref);
166
258
                data.insert(ref);
167
258
            }
168
228
        }
169
228
    }
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
637
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena& arena) {
178
637
        auto key = columns[0]->get_data_at(row_num);
179
637
        key.data = arena.insert(key.data, key.size);
180
181
637
        if constexpr (stable) {
182
164
            data.emplace(key, data.size());
183
473
        } else {
184
473
            data.insert(key);
185
473
        }
186
637
    }
_ZN5doris42AggregateFunctionDistinctSingleGenericDataILb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
177
473
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena& arena) {
178
473
        auto key = columns[0]->get_data_at(row_num);
179
473
        key.data = arena.insert(key.data, key.size);
180
181
        if constexpr (stable) {
182
            data.emplace(key, data.size());
183
473
        } else {
184
473
            data.insert(key);
185
473
        }
186
473
    }
_ZN5doris42AggregateFunctionDistinctSingleGenericDataILb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
177
164
    void add(const IColumn** columns, size_t /* columns_num */, size_t row_num, Arena& arena) {
178
164
        auto key = columns[0]->get_data_at(row_num);
179
164
        key.data = arena.insert(key.data, key.size);
180
181
164
        if constexpr (stable) {
182
164
            data.emplace(key, data.size());
183
        } else {
184
            data.insert(key);
185
        }
186
164
    }
187
188
220
    MutableColumns get_arguments(const DataTypes& argument_types) const {
189
220
        MutableColumns argument_columns;
190
220
        argument_columns.emplace_back(argument_types[0]->create_column());
191
220
        if constexpr (stable) {
192
57
            std::vector<StringRef> tmp(data.size());
193
95
            for (auto it : data) {
194
95
                tmp[it.second] = it.first;
195
95
            }
196
152
            for (int i = 0; i < data.size(); i++) {
197
95
                argument_columns[0]->insert_data(tmp[i].data, tmp[i].size);
198
95
            }
199
163
        } else {
200
219
            for (const auto& elem : data) {
201
219
                argument_columns[0]->insert_data(elem.data, elem.size);
202
219
            }
203
163
        }
204
205
220
        return argument_columns;
206
220
    }
_ZNK5doris42AggregateFunctionDistinctSingleGenericDataILb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS6_EE
Line
Count
Source
188
163
    MutableColumns get_arguments(const DataTypes& argument_types) const {
189
163
        MutableColumns argument_columns;
190
163
        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
163
        } else {
200
219
            for (const auto& elem : data) {
201
219
                argument_columns[0]->insert_data(elem.data, elem.size);
202
219
            }
203
163
        }
204
205
163
        return argument_columns;
206
163
    }
_ZNK5doris42AggregateFunctionDistinctSingleGenericDataILb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS6_EE
Line
Count
Source
188
57
    MutableColumns get_arguments(const DataTypes& argument_types) const {
189
57
        MutableColumns argument_columns;
190
57
        argument_columns.emplace_back(argument_types[0]->create_column());
191
57
        if constexpr (stable) {
192
57
            std::vector<StringRef> tmp(data.size());
193
95
            for (auto it : data) {
194
95
                tmp[it.second] = it.first;
195
95
            }
196
152
            for (int i = 0; i < data.size(); i++) {
197
95
                argument_columns[0]->insert_data(tmp[i].data, tmp[i].size);
198
95
            }
199
        } else {
200
            for (const auto& elem : data) {
201
                argument_columns[0]->insert_data(elem.data, elem.size);
202
            }
203
        }
204
205
57
        return argument_columns;
206
57
    }
207
};
208
209
template <bool stable>
210
struct AggregateFunctionDistinctMultipleGenericData
211
        : public AggregateFunctionDistinctGenericData<stable> {
212
    using Base = AggregateFunctionDistinctGenericData<stable>;
213
    using Base::data;
214
84
    void add(const IColumn** columns, size_t columns_num, size_t row_num, Arena& arena) {
215
84
        const char* begin = nullptr;
216
84
        StringRef key(begin, 0);
217
252
        for (size_t i = 0; i < columns_num; ++i) {
218
168
            auto cur_ref = columns[i]->serialize_value_into_arena(row_num, arena, begin);
219
168
            key.data = cur_ref.data - key.size;
220
168
            key.size += cur_ref.size;
221
168
        }
222
223
84
        if constexpr (stable) {
224
55
            data.emplace(key, data.size());
225
55
        } else {
226
29
            data.emplace(key);
227
29
        }
228
84
    }
_ZN5doris44AggregateFunctionDistinctMultipleGenericDataILb0EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
214
29
    void add(const IColumn** columns, size_t columns_num, size_t row_num, Arena& arena) {
215
29
        const char* begin = nullptr;
216
29
        StringRef key(begin, 0);
217
87
        for (size_t i = 0; i < columns_num; ++i) {
218
58
            auto cur_ref = columns[i]->serialize_value_into_arena(row_num, arena, begin);
219
58
            key.data = cur_ref.data - key.size;
220
58
            key.size += cur_ref.size;
221
58
        }
222
223
        if constexpr (stable) {
224
            data.emplace(key, data.size());
225
29
        } else {
226
29
            data.emplace(key);
227
29
        }
228
29
    }
_ZN5doris44AggregateFunctionDistinctMultipleGenericDataILb1EE3addEPPKNS_7IColumnEmmRNS_5ArenaE
Line
Count
Source
214
55
    void add(const IColumn** columns, size_t columns_num, size_t row_num, Arena& arena) {
215
55
        const char* begin = nullptr;
216
55
        StringRef key(begin, 0);
217
165
        for (size_t i = 0; i < columns_num; ++i) {
218
110
            auto cur_ref = columns[i]->serialize_value_into_arena(row_num, arena, begin);
219
110
            key.data = cur_ref.data - key.size;
220
110
            key.size += cur_ref.size;
221
110
        }
222
223
55
        if constexpr (stable) {
224
55
            data.emplace(key, data.size());
225
        } else {
226
            data.emplace(key);
227
        }
228
55
    }
229
230
47
    MutableColumns get_arguments(const DataTypes& argument_types) const {
231
47
        MutableColumns argument_columns(argument_types.size());
232
141
        for (size_t i = 0; i < argument_types.size(); ++i) {
233
94
            argument_columns[i] = argument_types[i]->create_column();
234
94
        }
235
236
47
        if constexpr (stable) {
237
29
            std::vector<StringRef> tmp(data.size());
238
54
            for (auto it : data) {
239
54
                tmp[it.second] = it.first;
240
54
            }
241
83
            for (int i = 0; i < data.size(); i++) {
242
54
                const char* begin = tmp[i].data;
243
108
                for (auto& column : argument_columns) {
244
108
                    begin = column->deserialize_and_insert_from_arena(begin);
245
108
                }
246
54
            }
247
29
        } else {
248
18
            for (const auto& elem : data) {
249
18
                const char* begin = elem.data;
250
36
                for (auto& column : argument_columns) {
251
36
                    begin = column->deserialize_and_insert_from_arena(begin);
252
36
                }
253
18
            }
254
18
        }
255
256
47
        return argument_columns;
257
47
    }
_ZNK5doris44AggregateFunctionDistinctMultipleGenericDataILb0EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS6_EE
Line
Count
Source
230
18
    MutableColumns get_arguments(const DataTypes& argument_types) const {
231
18
        MutableColumns argument_columns(argument_types.size());
232
54
        for (size_t i = 0; i < argument_types.size(); ++i) {
233
36
            argument_columns[i] = argument_types[i]->create_column();
234
36
        }
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
18
        } else {
248
18
            for (const auto& elem : data) {
249
18
                const char* begin = elem.data;
250
36
                for (auto& column : argument_columns) {
251
36
                    begin = column->deserialize_and_insert_from_arena(begin);
252
36
                }
253
18
            }
254
18
        }
255
256
18
        return argument_columns;
257
18
    }
_ZNK5doris44AggregateFunctionDistinctMultipleGenericDataILb1EE13get_argumentsERKSt6vectorISt10shared_ptrIKNS_9IDataTypeEESaIS6_EE
Line
Count
Source
230
29
    MutableColumns get_arguments(const DataTypes& argument_types) const {
231
29
        MutableColumns argument_columns(argument_types.size());
232
87
        for (size_t i = 0; i < argument_types.size(); ++i) {
233
58
            argument_columns[i] = argument_types[i]->create_column();
234
58
        }
235
236
29
        if constexpr (stable) {
237
29
            std::vector<StringRef> tmp(data.size());
238
54
            for (auto it : data) {
239
54
                tmp[it.second] = it.first;
240
54
            }
241
83
            for (int i = 0; i < data.size(); i++) {
242
54
                const char* begin = tmp[i].data;
243
108
                for (auto& column : argument_columns) {
244
108
                    begin = column->deserialize_and_insert_from_arena(begin);
245
108
                }
246
54
            }
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
29
        return argument_columns;
257
29
    }
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
6.27k
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
6.27k
        return place + prefix_size;
276
6.27k
    }
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
3.17k
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
3.17k
        return place + prefix_size;
276
3.17k
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE16get_nested_placeEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE16get_nested_placeEPc
Line
Count
Source
274
494
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
494
        return place + prefix_size;
276
494
    }
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
1.66k
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
1.66k
        return place + prefix_size;
276
1.66k
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE16get_nested_placeEPc
Line
Count
Source
274
518
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
518
        return place + prefix_size;
276
518
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE16get_nested_placeEPc
Line
Count
Source
274
136
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
136
        return place + prefix_size;
276
136
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE16get_nested_placeEPc
Line
Count
Source
274
277
    AggregateDataPtr get_nested_place(AggregateDataPtr __restrict place) const noexcept {
275
277
        return place + prefix_size;
276
277
    }
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
1.75k
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
1.75k
                      arguments),
286
1.75k
              nested_func(std::move(nested_func_)),
287
1.75k
              arguments_num(arguments.size()) {
288
1.75k
        size_t nested_size = nested_func->align_of_data();
289
1.75k
        CHECK_GT(nested_size, 0);
290
1.75k
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
1.75k
    }
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
579
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
579
                      arguments),
286
579
              nested_func(std::move(nested_func_)),
287
579
              arguments_num(arguments.size()) {
288
579
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
579
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
579
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
_ZN5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS6_IKNS_9IDataTypeEESaISC_EE
Line
Count
Source
284
353
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
353
                      arguments),
286
353
              nested_func(std::move(nested_func_)),
287
353
              arguments_num(arguments.size()) {
288
353
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
353
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
353
    }
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
743
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
743
                      arguments),
286
743
              nested_func(std::move(nested_func_)),
287
743
              arguments_num(arguments.size()) {
288
743
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
743
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
743
    }
_ZN5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS3_IKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
284
45
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
45
                      arguments),
286
45
              nested_func(std::move(nested_func_)),
287
45
              arguments_num(arguments.size()) {
288
45
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
45
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
45
    }
_ZN5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS3_IKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
284
25
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
25
                      arguments),
286
25
              nested_func(std::move(nested_func_)),
287
25
              arguments_num(arguments.size()) {
288
25
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
25
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
25
    }
_ZN5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EEC2ESt10shared_ptrINS_18IAggregateFunctionEERKSt6vectorIS3_IKNS_9IDataTypeEESaIS9_EE
Line
Count
Source
284
10
            : IAggregateFunctionDataHelper<Data<stable>, AggregateFunctionDistinct<Data, stable>>(
285
10
                      arguments),
286
10
              nested_func(std::move(nested_func_)),
287
10
              arguments_num(arguments.size()) {
288
10
        size_t nested_size = nested_func->align_of_data();
289
        CHECK_GT(nested_size, 0);
290
10
        prefix_size = (sizeof(Data<stable>) + nested_size - 1) / nested_size * nested_size;
291
10
    }
292
293
    void add(AggregateDataPtr __restrict place, const IColumn** columns, ssize_t row_num,
294
1.50k
             Arena& arena) const override {
295
1.50k
        this->data(place).add(columns, arguments_num, row_num, arena);
296
1.50k
    }
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
716
             Arena& arena) const override {
295
716
        this->data(place).add(columns, arguments_num, row_num, arena);
296
716
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
69
             Arena& arena) const override {
295
69
        this->data(place).add(columns, arguments_num, row_num, arena);
296
69
    }
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
473
             Arena& arena) const override {
295
473
        this->data(place).add(columns, arguments_num, row_num, arena);
296
473
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
164
             Arena& arena) const override {
295
164
        this->data(place).add(columns, arguments_num, row_num, arena);
296
164
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
29
             Arena& arena) const override {
295
29
        this->data(place).add(columns, arguments_num, row_num, arena);
296
29
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE3addEPcPPKNS_7IColumnElRNS_5ArenaE
Line
Count
Source
294
55
             Arena& arena) const override {
295
55
        this->data(place).add(columns, arguments_num, row_num, arena);
296
55
    }
297
298
    void merge(AggregateDataPtr __restrict place, ConstAggregateDataPtr rhs,
299
709
               Arena& arena) const override {
300
709
        this->data(place).merge(this->data(rhs), arena);
301
709
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE5mergeEPcPKcRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
299
435
               Arena& arena) const override {
300
435
        this->data(place).merge(this->data(rhs), arena);
301
435
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE5mergeEPcPKcRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
299
46
               Arena& arena) const override {
300
46
        this->data(place).merge(this->data(rhs), arena);
301
46
    }
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
213
               Arena& arena) const override {
300
213
        this->data(place).merge(this->data(rhs), arena);
301
213
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE5mergeEPcPKcRNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE5mergeEPcPKcRNS_5ArenaE
Line
Count
Source
299
15
               Arena& arena) const override {
300
15
        this->data(place).merge(this->data(rhs), arena);
301
15
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE5mergeEPcPKcRNS_5ArenaE
302
303
829
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
304
829
        this->data(place).serialize(buf);
305
829
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE3EE6OutputELb1EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE4EE6OutputELb1EE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
303
513
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
304
513
        this->data(place).serialize(buf);
305
513
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
303
46
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
304
46
        this->data(place).serialize(buf);
305
46
    }
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
255
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
304
255
        this->data(place).serialize(buf);
305
255
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE9serializeEPKcRNS_14BufferWritableE
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE9serializeEPKcRNS_14BufferWritableE
Line
Count
Source
303
15
    void serialize(ConstAggregateDataPtr __restrict place, BufferWritable& buf) const override {
304
15
        this->data(place).serialize(buf);
305
15
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE9serializeEPKcRNS_14BufferWritableE
306
307
    void deserialize(AggregateDataPtr __restrict place, BufferReadable& buf,
308
709
                     Arena& arena) const override {
309
709
        this->data(place).deserialize(buf, arena);
310
709
    }
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
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
308
435
                     Arena& arena) const override {
309
435
        this->data(place).deserialize(buf, arena);
310
435
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
308
46
                     Arena& arena) const override {
309
46
        this->data(place).deserialize(buf, arena);
310
46
    }
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
213
                     Arena& arena) const override {
309
213
        this->data(place).deserialize(buf, arena);
310
213
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
Line
Count
Source
308
15
                     Arena& arena) const override {
309
15
        this->data(place).deserialize(buf, arena);
310
15
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE11deserializeEPcRNS_14BufferReadableERNS_5ArenaE
311
312
616
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
616
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
616
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
616
        ColumnRawPtrs arguments_raw(arguments.size());
317
1.27k
        for (size_t i = 0; i < arguments.size(); ++i) {
318
663
            arguments_raw[i] = arguments[i].get();
319
663
        }
320
321
616
        assert(!arguments.empty());
322
616
        Arena arena;
323
616
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
616
                                            arguments_raw.data(), arena);
325
616
        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
616
        this->data(place).clear();
330
616
    }
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
284
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
284
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
284
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
284
        ColumnRawPtrs arguments_raw(arguments.size());
317
568
        for (size_t i = 0; i < arguments.size(); ++i) {
318
284
            arguments_raw[i] = arguments[i].get();
319
284
        }
320
321
284
        assert(!arguments.empty());
322
284
        Arena arena;
323
284
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
284
                                            arguments_raw.data(), arena);
325
284
        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
284
        this->data(place).clear();
330
284
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE18insert_result_intoEPKcRNS_7IColumnE
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
62
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
62
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
62
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
62
        ColumnRawPtrs arguments_raw(arguments.size());
317
124
        for (size_t i = 0; i < arguments.size(); ++i) {
318
62
            arguments_raw[i] = arguments[i].get();
319
62
        }
320
321
62
        assert(!arguments.empty());
322
62
        Arena arena;
323
62
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
62
                                            arguments_raw.data(), arena);
325
62
        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
62
        this->data(place).clear();
330
62
    }
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
163
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
163
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
163
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
163
        ColumnRawPtrs arguments_raw(arguments.size());
317
326
        for (size_t i = 0; i < arguments.size(); ++i) {
318
163
            arguments_raw[i] = arguments[i].get();
319
163
        }
320
321
163
        assert(!arguments.empty());
322
163
        Arena arena;
323
163
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
163
                                            arguments_raw.data(), arena);
325
163
        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
163
        this->data(place).clear();
330
163
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
57
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
57
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
57
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
57
        ColumnRawPtrs arguments_raw(arguments.size());
317
114
        for (size_t i = 0; i < arguments.size(); ++i) {
318
57
            arguments_raw[i] = arguments[i].get();
319
57
        }
320
321
57
        assert(!arguments.empty());
322
57
        Arena arena;
323
57
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
57
                                            arguments_raw.data(), arena);
325
57
        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
57
        this->data(place).clear();
330
57
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
18
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
18
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
18
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
18
        ColumnRawPtrs arguments_raw(arguments.size());
317
54
        for (size_t i = 0; i < arguments.size(); ++i) {
318
36
            arguments_raw[i] = arguments[i].get();
319
36
        }
320
321
18
        assert(!arguments.empty());
322
18
        Arena arena;
323
18
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
18
                                            arguments_raw.data(), arena);
325
18
        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
18
        this->data(place).clear();
330
18
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE18insert_result_intoEPKcRNS_7IColumnE
Line
Count
Source
312
29
    void insert_result_into(ConstAggregateDataPtr targetplace, IColumn& to) const override {
313
        // place is essentially an AggregateDataPtr, passed as a ConstAggregateDataPtr.
314
29
        auto* place = const_cast<AggregateDataPtr>(targetplace);
315
29
        auto arguments = this->data(place).get_arguments(this->argument_types);
316
29
        ColumnRawPtrs arguments_raw(arguments.size());
317
87
        for (size_t i = 0; i < arguments.size(); ++i) {
318
58
            arguments_raw[i] = arguments[i].get();
319
58
        }
320
321
29
        assert(!arguments.empty());
322
29
        Arena arena;
323
29
        nested_func->add_batch_single_place(arguments[0]->size(), get_nested_place(place),
324
29
                                            arguments_raw.data(), arena);
325
29
        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
29
        this->data(place).clear();
330
29
    }
331
332
121
    void reset(AggregateDataPtr place) const override {
333
121
        this->data(place).clear();
334
121
        nested_func->reset(get_nested_place(place));
335
121
    }
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
57
    void reset(AggregateDataPtr place) const override {
333
57
        this->data(place).clear();
334
57
        nested_func->reset(get_nested_place(place));
335
57
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE5resetEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE5resetEPc
Line
Count
Source
332
16
    void reset(AggregateDataPtr place) const override {
333
16
        this->data(place).clear();
334
16
        nested_func->reset(get_nested_place(place));
335
16
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE5resetEPc
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE5resetEPc
Line
Count
Source
332
48
    void reset(AggregateDataPtr place) const override {
333
48
        this->data(place).clear();
334
48
        nested_func->reset(get_nested_place(place));
335
48
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE5resetEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE5resetEPc
336
337
1.54k
    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
681
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE12size_of_dataEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE12size_of_dataEv
Line
Count
Source
337
134
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
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
409
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE12size_of_dataEv
Line
Count
Source
337
173
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE12size_of_dataEv
Line
Count
Source
337
57
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE12size_of_dataEv
Line
Count
Source
337
91
    size_t size_of_data() const override { return prefix_size + nested_func->size_of_data(); }
338
339
1.66k
    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
392
    size_t align_of_data() const override { return nested_func->align_of_data(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE13align_of_dataEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE13align_of_dataEv
Line
Count
Source
339
364
    size_t align_of_data() const override { return nested_func->align_of_data(); }
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
778
    size_t align_of_data() const override { return nested_func->align_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE13align_of_dataEv
Line
Count
Source
339
72
    size_t align_of_data() const override { return nested_func->align_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE13align_of_dataEv
Line
Count
Source
339
34
    size_t align_of_data() const override { return nested_func->align_of_data(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE13align_of_dataEv
Line
Count
Source
339
20
    size_t align_of_data() const override { return nested_func->align_of_data(); }
340
341
2.46k
    void create(AggregateDataPtr __restrict place) const override {
342
2.46k
        new (place) Data<stable>;
343
2.46k
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
2.46k
                    this->data(place).~Data<stable>());
345
2.46k
    }
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.27k
    void create(AggregateDataPtr __restrict place) const override {
342
1.27k
        new (place) Data<stable>;
343
1.27k
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
1.27k
                    this->data(place).~Data<stable>());
345
1.27k
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE6createEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE6createEPc
Line
Count
Source
341
177
    void create(AggregateDataPtr __restrict place) const override {
342
177
        new (place) Data<stable>;
343
177
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
177
                    this->data(place).~Data<stable>());
345
177
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE6createEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE6createEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE6createEPc
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE6createEPc
Line
Count
Source
341
645
    void create(AggregateDataPtr __restrict place) const override {
342
645
        new (place) Data<stable>;
343
645
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
645
                    this->data(place).~Data<stable>());
345
645
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE6createEPc
Line
Count
Source
341
202
    void create(AggregateDataPtr __restrict place) const override {
342
202
        new (place) Data<stable>;
343
202
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
202
                    this->data(place).~Data<stable>());
345
202
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE6createEPc
Line
Count
Source
341
50
    void create(AggregateDataPtr __restrict place) const override {
342
50
        new (place) Data<stable>;
343
50
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
50
                    this->data(place).~Data<stable>());
345
50
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE6createEPc
Line
Count
Source
341
109
    void create(AggregateDataPtr __restrict place) const override {
342
109
        new (place) Data<stable>;
343
109
        SAFE_CREATE(nested_func->create(get_nested_place(place)),
344
109
                    this->data(place).~Data<stable>());
345
109
    }
346
347
2.46k
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
2.46k
        this->data(place).~Data<stable>();
349
2.46k
        nested_func->destroy(get_nested_place(place));
350
2.46k
    }
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.27k
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
1.27k
        this->data(place).~Data<stable>();
349
1.27k
        nested_func->destroy(get_nested_place(place));
350
1.27k
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE7destroyEPc
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE7destroyEPc
Line
Count
Source
347
177
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
177
        this->data(place).~Data<stable>();
349
177
        nested_func->destroy(get_nested_place(place));
350
177
    }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb1EE7destroyEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb0EE7destroyEPc
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE7EE6OutputELb1EE7destroyEPc
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb0EE7destroyEPc
Line
Count
Source
347
644
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
644
        this->data(place).~Data<stable>();
349
644
        nested_func->destroy(get_nested_place(place));
350
644
    }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE7destroyEPc
Line
Count
Source
347
202
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
202
        this->data(place).~Data<stable>();
349
202
        nested_func->destroy(get_nested_place(place));
350
202
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE7destroyEPc
Line
Count
Source
347
50
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
50
        this->data(place).~Data<stable>();
349
50
        nested_func->destroy(get_nested_place(place));
350
50
    }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE7destroyEPc
Line
Count
Source
347
110
    void destroy(AggregateDataPtr __restrict place) const noexcept override {
348
110
        this->data(place).~Data<stable>();
349
110
        nested_func->destroy(get_nested_place(place));
350
110
    }
351
352
156
    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
57
    String get_name() const override { return nested_func->get_name() + "Distinct"; }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE8get_nameB5cxx11Ev
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE8get_nameB5cxx11Ev
Line
Count
Source
352
32
    String get_name() const override { return nested_func->get_name() + "Distinct"; }
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
67
    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
545
    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
239
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
Unexecuted instantiation: _ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE5EE6OutputELb1EE15get_return_typeEv
_ZNK5doris25AggregateFunctionDistinctINS_7ReducerILNS_13PrimitiveTypeE6EE6OutputELb0EE15get_return_typeEv
Line
Count
Source
354
28
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
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
156
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
_ZNK5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE15get_return_typeEv
Line
Count
Source
354
80
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE15get_return_typeEv
Line
Count
Source
354
23
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
_ZNK5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb1EE15get_return_typeEv
Line
Count
Source
354
17
    DataTypePtr get_return_type() const override { return nested_func->get_return_type(); }
355
356
55
    IAggregateFunction* transmit_to_stable() override {
357
55
        return new AggregateFunctionDistinct<Data, true>(nested_func,
358
55
                                                         IAggregateFunction::argument_types);
359
55
    }
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
45
    IAggregateFunction* transmit_to_stable() override {
357
45
        return new AggregateFunctionDistinct<Data, true>(nested_func,
358
45
                                                         IAggregateFunction::argument_types);
359
45
    }
Unexecuted instantiation: _ZN5doris25AggregateFunctionDistinctINS_42AggregateFunctionDistinctSingleGenericDataELb1EE18transmit_to_stableEv
_ZN5doris25AggregateFunctionDistinctINS_44AggregateFunctionDistinctMultipleGenericDataELb0EE18transmit_to_stableEv
Line
Count
Source
356
10
    IAggregateFunction* transmit_to_stable() override {
357
10
        return new AggregateFunctionDistinct<Data, true>(nested_func,
358
10
                                                         IAggregateFunction::argument_types);
359
10
    }
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"