Coverage Report

Created: 2026-07-02 14:47

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/exec/common/varbinaryop_subbinary.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
18
#pragma once
19
20
#include "core/block/block.h"
21
#include "core/column/column_const.h"
22
#include "core/column/column_varbinary.h"
23
#include "core/data_type/data_type_number.h"
24
#include "core/data_type/data_type_varbinary.h"
25
#include "core/types.h"
26
27
namespace doris {
28
29
constexpr auto SIZE_OF_UINT = sizeof(uint32_t);
30
31
struct VarBinaryOP {
32
    static void check_and_insert_data(doris::StringView& sView, const char* data, uint32_t len,
33
40
                                      bool before_is_inline) {
34
40
        if (before_is_inline) {
35
28
            sView.set_size(len);
36
28
        } else {
37
12
            sView = doris::StringView(data, len);
38
12
        }
39
40
    }
40
41
66
    static std::pair<bool, char*> alloc(ColumnVarbinary* res_col, size_t index, uint32_t len) {
42
66
        bool is_inline = StringView::isInline(len);
43
66
        char* dst = nullptr;
44
66
        if (is_inline) {
45
54
            dst = reinterpret_cast<char*>(&(res_col->get_data()[index])) + SIZE_OF_UINT;
46
54
        } else {
47
12
            dst = res_col->alloc(len);
48
12
        }
49
66
        return {is_inline, dst};
50
66
    }
51
};
52
53
struct SubBinaryUtil {
54
    static void sub_binary_execute(Block& block, const ColumnNumbers& arguments, uint32_t result,
55
2.01k
                                   size_t input_rows_count) {
56
2.01k
        DCHECK_EQ(arguments.size(), 3);
57
2.01k
        auto res = ColumnVarbinary::create();
58
59
2.01k
        bool col_const[3];
60
2.01k
        ColumnPtr argument_columns[3];
61
8.07k
        for (int i = 0; i < 3; ++i) {
62
6.05k
            std::tie(argument_columns[i], col_const[i]) =
63
6.05k
                    unpack_if_const(block.get_by_position(arguments[i]).column);
64
6.05k
        }
65
66
2.01k
        const auto* specific_binary_column =
67
2.01k
                assert_cast<const ColumnVarbinary*>(argument_columns[0].get());
68
2.01k
        const auto* specific_start_column =
69
2.01k
                assert_cast<const ColumnInt32*>(argument_columns[1].get());
70
2.01k
        const auto* specific_len_column =
71
2.01k
                assert_cast<const ColumnInt32*>(argument_columns[2].get());
72
73
2.01k
        std::visit(
74
2.01k
                [&](auto binary_const, auto start_const, auto len_const) {
75
2.01k
                    vectors<binary_const, start_const, len_const>(
76
2.01k
                            specific_binary_column, specific_start_column, specific_len_column,
77
2.01k
                            res.get(), input_rows_count);
78
2.01k
                },
_ZZN5doris13SubBinaryUtil18sub_binary_executeERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlT_T0_T1_E_clISt17integral_constantIbLb0EESE_SE_EEDaS8_S9_SA_
Line
Count
Source
74
290
                [&](auto binary_const, auto start_const, auto len_const) {
75
290
                    vectors<binary_const, start_const, len_const>(
76
290
                            specific_binary_column, specific_start_column, specific_len_column,
77
290
                            res.get(), input_rows_count);
78
290
                },
Unexecuted instantiation: _ZZN5doris13SubBinaryUtil18sub_binary_executeERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlT_T0_T1_E_clISt17integral_constantIbLb1EESE_SE_EEDaS8_S9_SA_
_ZZN5doris13SubBinaryUtil18sub_binary_executeERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlT_T0_T1_E_clISt17integral_constantIbLb1EESE_SD_IbLb0EEEEDaS8_S9_SA_
Line
Count
Source
74
288
                [&](auto binary_const, auto start_const, auto len_const) {
75
288
                    vectors<binary_const, start_const, len_const>(
76
288
                            specific_binary_column, specific_start_column, specific_len_column,
77
288
                            res.get(), input_rows_count);
78
288
                },
_ZZN5doris13SubBinaryUtil18sub_binary_executeERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlT_T0_T1_E_clISt17integral_constantIbLb1EESD_IbLb0EESE_EEDaS8_S9_SA_
Line
Count
Source
74
288
                [&](auto binary_const, auto start_const, auto len_const) {
75
288
                    vectors<binary_const, start_const, len_const>(
76
288
                            specific_binary_column, specific_start_column, specific_len_column,
77
288
                            res.get(), input_rows_count);
78
288
                },
_ZZN5doris13SubBinaryUtil18sub_binary_executeERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlT_T0_T1_E_clISt17integral_constantIbLb1EESD_IbLb0EESF_EEDaS8_S9_SA_
Line
Count
Source
74
288
                [&](auto binary_const, auto start_const, auto len_const) {
75
288
                    vectors<binary_const, start_const, len_const>(
76
288
                            specific_binary_column, specific_start_column, specific_len_column,
77
288
                            res.get(), input_rows_count);
78
288
                },
_ZZN5doris13SubBinaryUtil18sub_binary_executeERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlT_T0_T1_E_clISt17integral_constantIbLb0EESD_IbLb1EESF_EEDaS8_S9_SA_
Line
Count
Source
74
288
                [&](auto binary_const, auto start_const, auto len_const) {
75
288
                    vectors<binary_const, start_const, len_const>(
76
288
                            specific_binary_column, specific_start_column, specific_len_column,
77
288
                            res.get(), input_rows_count);
78
288
                },
_ZZN5doris13SubBinaryUtil18sub_binary_executeERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlT_T0_T1_E_clISt17integral_constantIbLb0EESD_IbLb1EESE_EEDaS8_S9_SA_
Line
Count
Source
74
288
                [&](auto binary_const, auto start_const, auto len_const) {
75
288
                    vectors<binary_const, start_const, len_const>(
76
288
                            specific_binary_column, specific_start_column, specific_len_column,
77
288
                            res.get(), input_rows_count);
78
288
                },
_ZZN5doris13SubBinaryUtil18sub_binary_executeERNS_5BlockERKSt6vectorIjSaIjEEjmENKUlT_T0_T1_E_clISt17integral_constantIbLb0EESE_SD_IbLb1EEEEDaS8_S9_SA_
Line
Count
Source
74
288
                [&](auto binary_const, auto start_const, auto len_const) {
75
288
                    vectors<binary_const, start_const, len_const>(
76
288
                            specific_binary_column, specific_start_column, specific_len_column,
77
288
                            res.get(), input_rows_count);
78
288
                },
79
2.01k
                make_bool_variant(col_const[0]), make_bool_variant(col_const[1]),
80
2.01k
                make_bool_variant(col_const[2]));
81
2.01k
        block.get_by_position(result).column = std::move(res);
82
2.01k
    }
83
84
private:
85
    template <bool binary_const, bool start_const, bool len_const>
86
    static void vectors(const ColumnVarbinary* binarys, const ColumnInt32* start,
87
2.01k
                        const ColumnInt32* len, ColumnVarbinary* res, size_t size) {
88
2.01k
        res->get_data().reserve(size);
89
90
4.53k
        for (size_t i = 0; i < size; ++i) {
91
2.51k
            doris::StringView binary = binarys->get_data()[index_check_const<binary_const>(i)];
92
2.51k
            int binary_size = static_cast<int>(binary.size());
93
94
2.51k
            int start_value = start->get_data()[index_check_const<start_const>(i)];
95
2.51k
            int len_value = len->get_data()[index_check_const<len_const>(i)];
96
97
2.51k
            bool start_out_of_range = (start_value > binary_size) || (start_value < -binary_size);
98
2.51k
            bool len_non_positive = len_value <= 0;
99
2.51k
            bool input_empty = binary_size == 0;
100
101
2.51k
            if (start_out_of_range || len_non_positive || input_empty) {
102
1.31k
                res->insert_default();
103
1.31k
                continue;
104
1.31k
            }
105
1.20k
            int fixed_pos = start_value - 1;
106
1.20k
            if (fixed_pos < 0) {
107
432
                fixed_pos = binary_size + fixed_pos + 1;
108
432
            }
109
1.20k
            int fixed_len = std::min(binary_size - fixed_pos, len_value);
110
111
1.20k
            res->insert_data(binary.data() + fixed_pos, fixed_len);
112
1.20k
        }
113
2.01k
    }
_ZN5doris13SubBinaryUtil7vectorsILb0ELb0ELb0EEEvPKNS_15ColumnVarbinaryEPKNS_12ColumnVectorILNS_13PrimitiveTypeE5EEES9_PS2_m
Line
Count
Source
87
290
                        const ColumnInt32* len, ColumnVarbinary* res, size_t size) {
88
290
        res->get_data().reserve(size);
89
90
1.07k
        for (size_t i = 0; i < size; ++i) {
91
788
            doris::StringView binary = binarys->get_data()[index_check_const<binary_const>(i)];
92
788
            int binary_size = static_cast<int>(binary.size());
93
94
788
            int start_value = start->get_data()[index_check_const<start_const>(i)];
95
788
            int len_value = len->get_data()[index_check_const<len_const>(i)];
96
97
788
            bool start_out_of_range = (start_value > binary_size) || (start_value < -binary_size);
98
788
            bool len_non_positive = len_value <= 0;
99
788
            bool input_empty = binary_size == 0;
100
101
788
            if (start_out_of_range || len_non_positive || input_empty) {
102
452
                res->insert_default();
103
452
                continue;
104
452
            }
105
336
            int fixed_pos = start_value - 1;
106
336
            if (fixed_pos < 0) {
107
144
                fixed_pos = binary_size + fixed_pos + 1;
108
144
            }
109
336
            int fixed_len = std::min(binary_size - fixed_pos, len_value);
110
111
336
            res->insert_data(binary.data() + fixed_pos, fixed_len);
112
336
        }
113
290
    }
Unexecuted instantiation: _ZN5doris13SubBinaryUtil7vectorsILb1ELb1ELb1EEEvPKNS_15ColumnVarbinaryEPKNS_12ColumnVectorILNS_13PrimitiveTypeE5EEES9_PS2_m
_ZN5doris13SubBinaryUtil7vectorsILb1ELb1ELb0EEEvPKNS_15ColumnVarbinaryEPKNS_12ColumnVectorILNS_13PrimitiveTypeE5EEES9_PS2_m
Line
Count
Source
87
288
                        const ColumnInt32* len, ColumnVarbinary* res, size_t size) {
88
288
        res->get_data().reserve(size);
89
90
576
        for (size_t i = 0; i < size; ++i) {
91
288
            doris::StringView binary = binarys->get_data()[index_check_const<binary_const>(i)];
92
288
            int binary_size = static_cast<int>(binary.size());
93
94
288
            int start_value = start->get_data()[index_check_const<start_const>(i)];
95
288
            int len_value = len->get_data()[index_check_const<len_const>(i)];
96
97
288
            bool start_out_of_range = (start_value > binary_size) || (start_value < -binary_size);
98
288
            bool len_non_positive = len_value <= 0;
99
288
            bool input_empty = binary_size == 0;
100
101
288
            if (start_out_of_range || len_non_positive || input_empty) {
102
144
                res->insert_default();
103
144
                continue;
104
144
            }
105
144
            int fixed_pos = start_value - 1;
106
144
            if (fixed_pos < 0) {
107
48
                fixed_pos = binary_size + fixed_pos + 1;
108
48
            }
109
144
            int fixed_len = std::min(binary_size - fixed_pos, len_value);
110
111
144
            res->insert_data(binary.data() + fixed_pos, fixed_len);
112
144
        }
113
288
    }
_ZN5doris13SubBinaryUtil7vectorsILb1ELb0ELb1EEEvPKNS_15ColumnVarbinaryEPKNS_12ColumnVectorILNS_13PrimitiveTypeE5EEES9_PS2_m
Line
Count
Source
87
288
                        const ColumnInt32* len, ColumnVarbinary* res, size_t size) {
88
288
        res->get_data().reserve(size);
89
90
576
        for (size_t i = 0; i < size; ++i) {
91
288
            doris::StringView binary = binarys->get_data()[index_check_const<binary_const>(i)];
92
288
            int binary_size = static_cast<int>(binary.size());
93
94
288
            int start_value = start->get_data()[index_check_const<start_const>(i)];
95
288
            int len_value = len->get_data()[index_check_const<len_const>(i)];
96
97
288
            bool start_out_of_range = (start_value > binary_size) || (start_value < -binary_size);
98
288
            bool len_non_positive = len_value <= 0;
99
288
            bool input_empty = binary_size == 0;
100
101
288
            if (start_out_of_range || len_non_positive || input_empty) {
102
144
                res->insert_default();
103
144
                continue;
104
144
            }
105
144
            int fixed_pos = start_value - 1;
106
144
            if (fixed_pos < 0) {
107
48
                fixed_pos = binary_size + fixed_pos + 1;
108
48
            }
109
144
            int fixed_len = std::min(binary_size - fixed_pos, len_value);
110
111
144
            res->insert_data(binary.data() + fixed_pos, fixed_len);
112
144
        }
113
288
    }
_ZN5doris13SubBinaryUtil7vectorsILb1ELb0ELb0EEEvPKNS_15ColumnVarbinaryEPKNS_12ColumnVectorILNS_13PrimitiveTypeE5EEES9_PS2_m
Line
Count
Source
87
288
                        const ColumnInt32* len, ColumnVarbinary* res, size_t size) {
88
288
        res->get_data().reserve(size);
89
90
576
        for (size_t i = 0; i < size; ++i) {
91
288
            doris::StringView binary = binarys->get_data()[index_check_const<binary_const>(i)];
92
288
            int binary_size = static_cast<int>(binary.size());
93
94
288
            int start_value = start->get_data()[index_check_const<start_const>(i)];
95
288
            int len_value = len->get_data()[index_check_const<len_const>(i)];
96
97
288
            bool start_out_of_range = (start_value > binary_size) || (start_value < -binary_size);
98
288
            bool len_non_positive = len_value <= 0;
99
288
            bool input_empty = binary_size == 0;
100
101
288
            if (start_out_of_range || len_non_positive || input_empty) {
102
144
                res->insert_default();
103
144
                continue;
104
144
            }
105
144
            int fixed_pos = start_value - 1;
106
144
            if (fixed_pos < 0) {
107
48
                fixed_pos = binary_size + fixed_pos + 1;
108
48
            }
109
144
            int fixed_len = std::min(binary_size - fixed_pos, len_value);
110
111
144
            res->insert_data(binary.data() + fixed_pos, fixed_len);
112
144
        }
113
288
    }
_ZN5doris13SubBinaryUtil7vectorsILb0ELb1ELb1EEEvPKNS_15ColumnVarbinaryEPKNS_12ColumnVectorILNS_13PrimitiveTypeE5EEES9_PS2_m
Line
Count
Source
87
288
                        const ColumnInt32* len, ColumnVarbinary* res, size_t size) {
88
288
        res->get_data().reserve(size);
89
90
576
        for (size_t i = 0; i < size; ++i) {
91
288
            doris::StringView binary = binarys->get_data()[index_check_const<binary_const>(i)];
92
288
            int binary_size = static_cast<int>(binary.size());
93
94
288
            int start_value = start->get_data()[index_check_const<start_const>(i)];
95
288
            int len_value = len->get_data()[index_check_const<len_const>(i)];
96
97
288
            bool start_out_of_range = (start_value > binary_size) || (start_value < -binary_size);
98
288
            bool len_non_positive = len_value <= 0;
99
288
            bool input_empty = binary_size == 0;
100
101
288
            if (start_out_of_range || len_non_positive || input_empty) {
102
144
                res->insert_default();
103
144
                continue;
104
144
            }
105
144
            int fixed_pos = start_value - 1;
106
144
            if (fixed_pos < 0) {
107
48
                fixed_pos = binary_size + fixed_pos + 1;
108
48
            }
109
144
            int fixed_len = std::min(binary_size - fixed_pos, len_value);
110
111
144
            res->insert_data(binary.data() + fixed_pos, fixed_len);
112
144
        }
113
288
    }
_ZN5doris13SubBinaryUtil7vectorsILb0ELb1ELb0EEEvPKNS_15ColumnVarbinaryEPKNS_12ColumnVectorILNS_13PrimitiveTypeE5EEES9_PS2_m
Line
Count
Source
87
288
                        const ColumnInt32* len, ColumnVarbinary* res, size_t size) {
88
288
        res->get_data().reserve(size);
89
90
576
        for (size_t i = 0; i < size; ++i) {
91
288
            doris::StringView binary = binarys->get_data()[index_check_const<binary_const>(i)];
92
288
            int binary_size = static_cast<int>(binary.size());
93
94
288
            int start_value = start->get_data()[index_check_const<start_const>(i)];
95
288
            int len_value = len->get_data()[index_check_const<len_const>(i)];
96
97
288
            bool start_out_of_range = (start_value > binary_size) || (start_value < -binary_size);
98
288
            bool len_non_positive = len_value <= 0;
99
288
            bool input_empty = binary_size == 0;
100
101
288
            if (start_out_of_range || len_non_positive || input_empty) {
102
144
                res->insert_default();
103
144
                continue;
104
144
            }
105
144
            int fixed_pos = start_value - 1;
106
144
            if (fixed_pos < 0) {
107
48
                fixed_pos = binary_size + fixed_pos + 1;
108
48
            }
109
144
            int fixed_len = std::min(binary_size - fixed_pos, len_value);
110
111
144
            res->insert_data(binary.data() + fixed_pos, fixed_len);
112
144
        }
113
288
    }
_ZN5doris13SubBinaryUtil7vectorsILb0ELb0ELb1EEEvPKNS_15ColumnVarbinaryEPKNS_12ColumnVectorILNS_13PrimitiveTypeE5EEES9_PS2_m
Line
Count
Source
87
288
                        const ColumnInt32* len, ColumnVarbinary* res, size_t size) {
88
288
        res->get_data().reserve(size);
89
90
576
        for (size_t i = 0; i < size; ++i) {
91
288
            doris::StringView binary = binarys->get_data()[index_check_const<binary_const>(i)];
92
288
            int binary_size = static_cast<int>(binary.size());
93
94
288
            int start_value = start->get_data()[index_check_const<start_const>(i)];
95
288
            int len_value = len->get_data()[index_check_const<len_const>(i)];
96
97
288
            bool start_out_of_range = (start_value > binary_size) || (start_value < -binary_size);
98
288
            bool len_non_positive = len_value <= 0;
99
288
            bool input_empty = binary_size == 0;
100
101
288
            if (start_out_of_range || len_non_positive || input_empty) {
102
144
                res->insert_default();
103
144
                continue;
104
144
            }
105
144
            int fixed_pos = start_value - 1;
106
144
            if (fixed_pos < 0) {
107
48
                fixed_pos = binary_size + fixed_pos + 1;
108
48
            }
109
144
            int fixed_len = std::min(binary_size - fixed_pos, len_value);
110
111
144
            res->insert_data(binary.data() + fixed_pos, fixed_len);
112
144
        }
113
288
    }
114
};
115
116
} // namespace doris