Coverage Report

Created: 2026-05-22 02:36

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/storage/key_coder.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 <glog/logging.h>
21
#include <limits.h>
22
#include <stdint.h>
23
#include <string.h>
24
25
#include <algorithm>
26
#include <ostream>
27
#include <string>
28
#include <type_traits>
29
30
#include "absl/strings/substitute.h"
31
#include "common/status.h"
32
#include "core/data_type/primitive_type.h"
33
#include "core/decimal12.h"
34
#include "core/extended_types.h"
35
#include "core/field.h"
36
#include "core/types.h"
37
#include "exec/common/endian.h"
38
#include "storage/olap_common.h"
39
#include "storage/types.h"
40
#include "util/slice.h"
41
42
namespace doris {
43
44
using FullEncodeAscendingFunc = void (*)(const void* value, std::string* buf);
45
using EncodeAscendingFunc = void (*)(const void* value, size_t index_size, std::string* buf);
46
using DecodeAscendingFunc = Status (*)(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr);
47
48
// Order-preserving binary encoding for values of a particular type so that
49
// those values can be compared by memcpy their encoded bytes.
50
//
51
// To obtain instance of this class, use the `get_key_coder(FieldType)` method.
52
class KeyCoder {
53
public:
54
    template <typename TraitsType>
55
    KeyCoder(TraitsType traits);
56
57
    // encode the provided `value` into `buf`.
58
58.8M
    void full_encode_ascending(const void* value, std::string* buf) const {
59
58.8M
        _full_encode_ascending(value, buf);
60
58.8M
    }
61
62
    // similar to `full_encode_ascending`, but only encode part (the first `index_size` bytes) of the value.
63
    // only applicable to string type
64
152k
    void encode_ascending(const void* value, size_t index_size, std::string* buf) const {
65
152k
        _encode_ascending(value, index_size, buf);
66
152k
    }
67
68
    // Only used for test, should delete it in the future
69
223k
    Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) const {
70
223k
        return _decode_ascending(encoded_key, index_size, cell_ptr);
71
223k
    }
72
73
private:
74
    FullEncodeAscendingFunc _full_encode_ascending;
75
    EncodeAscendingFunc _encode_ascending;
76
    DecodeAscendingFunc _decode_ascending;
77
};
78
79
extern const KeyCoder* get_key_coder(FieldType type);
80
81
template <FieldType field_type, typename Enable = void>
82
class KeyCoderTraits {};
83
84
template <FieldType field_type>
85
class KeyCoderTraits<field_type,
86
                     typename std::enable_if<
87
                             IsIntegral<typename CppTypeTraits<field_type>::CppType>::value ||
88
                             IsDecimalNumber<typename CppTypeTraits<field_type>::CppType>>::type> {
89
public:
90
    using CppType = typename CppTypeTraits<field_type>::CppType;
91
    using UnsignedCppType = typename CppTypeTraits<field_type>::UnsignedCppType;
92
93
40.7M
    static void full_encode_ascending(const void* value, std::string* buf) {
94
40.7M
        UnsignedCppType unsigned_val;
95
40.7M
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
40.7M
        if (IsSigned<CppType>::value) {
98
37.0M
            unsigned_val ^=
99
37.0M
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
37.0M
        }
101
        // make it bigendian
102
40.7M
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
40.7M
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
40.7M
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE7EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
11.3M
    static void full_encode_ascending(const void* value, std::string* buf) {
94
11.3M
        UnsignedCppType unsigned_val;
95
11.3M
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
11.3M
        if (IsSigned<CppType>::value) {
98
11.3M
            unsigned_val ^=
99
11.3M
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
11.3M
        }
101
        // make it bigendian
102
11.3M
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
11.3M
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
11.3M
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE5EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
21.8M
    static void full_encode_ascending(const void* value, std::string* buf) {
94
21.8M
        UnsignedCppType unsigned_val;
95
21.8M
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
21.9M
        if (IsSigned<CppType>::value) {
98
21.9M
            unsigned_val ^=
99
21.9M
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
21.9M
        }
101
        // make it bigendian
102
21.8M
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
21.8M
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
21.8M
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE1EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
678k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
678k
        UnsignedCppType unsigned_val;
95
678k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
679k
        if (IsSigned<CppType>::value) {
98
679k
            unsigned_val ^=
99
679k
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
679k
        }
101
        // make it bigendian
102
678k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
678k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
678k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE3EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
614k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
614k
        UnsignedCppType unsigned_val;
95
614k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
614k
        if (IsSigned<CppType>::value) {
98
614k
            unsigned_val ^=
99
614k
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
614k
        }
101
        // make it bigendian
102
614k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
614k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
614k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE6EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
1.21M
    static void full_encode_ascending(const void* value, std::string* buf) {
94
1.21M
        UnsignedCppType unsigned_val;
95
1.21M
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
1.21M
        if (IsSigned<CppType>::value) {
98
0
            unsigned_val ^=
99
0
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
0
        }
101
        // make it bigendian
102
1.21M
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
1.21M
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
1.21M
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE8EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
1.86M
    static void full_encode_ascending(const void* value, std::string* buf) {
94
1.86M
        UnsignedCppType unsigned_val;
95
1.86M
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
1.86M
        if (IsSigned<CppType>::value) {
98
0
            unsigned_val ^=
99
0
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
0
        }
101
        // make it bigendian
102
1.86M
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
1.86M
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
1.86M
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE9EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
519k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
519k
        UnsignedCppType unsigned_val;
95
519k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
519k
        if (IsSigned<CppType>::value) {
98
519k
            unsigned_val ^=
99
519k
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
519k
        }
101
        // make it bigendian
102
519k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
519k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
519k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE15EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
400k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
400k
        UnsignedCppType unsigned_val;
95
400k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
400k
        if (IsSigned<CppType>::value) {
98
400k
            unsigned_val ^=
99
400k
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
400k
        }
101
        // make it bigendian
102
400k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
400k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
400k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE24EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
538k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
538k
        UnsignedCppType unsigned_val;
95
538k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
538k
        if (IsSigned<CppType>::value) {
98
0
            unsigned_val ^=
99
0
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
0
        }
101
        // make it bigendian
102
538k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
538k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
538k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE31EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
9.66k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
9.66k
        UnsignedCppType unsigned_val;
95
9.66k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
9.66k
        if (IsSigned<CppType>::value) {
98
9.66k
            unsigned_val ^=
99
9.66k
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
9.66k
        }
101
        // make it bigendian
102
9.66k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
9.66k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
9.66k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE32EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
5.45k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
5.45k
        UnsignedCppType unsigned_val;
95
5.45k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
5.45k
        if (IsSigned<CppType>::value) {
98
5.45k
            unsigned_val ^=
99
5.45k
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
5.45k
        }
101
        // make it bigendian
102
5.45k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
5.45k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
5.45k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE33EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
1.60M
    static void full_encode_ascending(const void* value, std::string* buf) {
94
1.60M
        UnsignedCppType unsigned_val;
95
1.60M
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
1.60M
        if (IsSigned<CppType>::value) {
98
1.60M
            unsigned_val ^=
99
1.60M
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
1.60M
        }
101
        // make it bigendian
102
1.60M
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
1.60M
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
1.60M
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE37EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
2.01k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
2.01k
        UnsignedCppType unsigned_val;
95
2.01k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
2.01k
        if (IsSigned<CppType>::value) {
98
2.01k
            unsigned_val ^=
99
2.01k
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
2.01k
        }
101
        // make it bigendian
102
2.01k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
2.01k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
2.01k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE38EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
61.7k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
61.7k
        UnsignedCppType unsigned_val;
95
61.7k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
61.7k
        if (IsSigned<CppType>::value) {
98
0
            unsigned_val ^=
99
0
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
0
        }
101
        // make it bigendian
102
61.7k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
61.7k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
61.7k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE39EvE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
93
56.9k
    static void full_encode_ascending(const void* value, std::string* buf) {
94
56.9k
        UnsignedCppType unsigned_val;
95
56.9k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
96
        // swap MSB to encode integer
97
56.9k
        if (IsSigned<CppType>::value) {
98
0
            unsigned_val ^=
99
0
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
100
0
        }
101
        // make it bigendian
102
56.9k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
103
104
56.9k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
105
56.9k
    }
106
107
117k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
117k
        full_encode_ascending(value, buf);
109
117k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE1EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
2.11k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
2.11k
        full_encode_ascending(value, buf);
109
2.11k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE3EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
2.17k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
2.17k
        full_encode_ascending(value, buf);
109
2.17k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE5EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
85.1k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
85.1k
        full_encode_ascending(value, buf);
109
85.1k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE6EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
202
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
202
        full_encode_ascending(value, buf);
109
202
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE7EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
17.3k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
17.3k
        full_encode_ascending(value, buf);
109
17.3k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE8EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
202
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
202
        full_encode_ascending(value, buf);
109
202
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE9EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
6.46k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
6.46k
        full_encode_ascending(value, buf);
109
6.46k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE15EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
227
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
227
        full_encode_ascending(value, buf);
109
227
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE24EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
761
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
761
        full_encode_ascending(value, buf);
109
761
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE31EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
157
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
157
        full_encode_ascending(value, buf);
109
157
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE32EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
271
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
271
        full_encode_ascending(value, buf);
109
271
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE33EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
1.74k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
1.74k
        full_encode_ascending(value, buf);
109
1.74k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE37EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
128
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
128
        full_encode_ascending(value, buf);
109
128
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE38EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
77
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
77
        full_encode_ascending(value, buf);
109
77
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE39EvE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
107
74
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
108
74
        full_encode_ascending(value, buf);
109
74
    }
110
111
482k
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
482k
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
482k
        UnsignedCppType unsigned_val;
119
482k
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
482k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
482k
        if (IsSigned<CppType>::value) {
122
80.6k
            unsigned_val ^=
123
80.6k
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
80.6k
        }
125
482k
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
482k
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
482k
        return Status::OK();
128
482k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE7EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
80.0k
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
80.0k
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
80.0k
        UnsignedCppType unsigned_val;
119
80.0k
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
80.0k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
80.0k
        if (IsSigned<CppType>::value) {
122
80.0k
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
80.0k
        }
125
80.0k
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
80.0k
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
80.0k
        return Status::OK();
128
80.0k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE5EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
117
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
117
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
117
        UnsignedCppType unsigned_val;
119
117
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
117
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
117
        if (IsSigned<CppType>::value) {
122
117
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
117
        }
125
117
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
117
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
117
        return Status::OK();
128
117
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE1EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
53
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
53
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
53
        UnsignedCppType unsigned_val;
119
53
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
53
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
53
        if (IsSigned<CppType>::value) {
122
53
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
53
        }
125
53
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
53
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
53
        return Status::OK();
128
53
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE3EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
53
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
53
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
53
        UnsignedCppType unsigned_val;
119
53
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
53
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
53
        if (IsSigned<CppType>::value) {
122
53
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
53
        }
125
53
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
53
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
53
        return Status::OK();
128
53
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE6EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
142k
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
142k
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
142k
        UnsignedCppType unsigned_val;
119
142k
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
142k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
142k
        if (IsSigned<CppType>::value) {
122
0
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
0
        }
125
142k
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
142k
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
142k
        return Status::OK();
128
142k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE8EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
258k
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
258k
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
258k
        UnsignedCppType unsigned_val;
119
258k
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
258k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
258k
        if (IsSigned<CppType>::value) {
122
0
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
0
        }
125
258k
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
258k
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
258k
        return Status::OK();
128
258k
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE9EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
53
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
53
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
53
        UnsignedCppType unsigned_val;
119
53
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
53
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
53
        if (IsSigned<CppType>::value) {
122
53
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
53
        }
125
53
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
53
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
53
        return Status::OK();
128
53
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE15EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
53
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
53
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
53
        UnsignedCppType unsigned_val;
119
53
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
53
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
53
        if (IsSigned<CppType>::value) {
122
53
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
53
        }
125
53
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
53
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
53
        return Status::OK();
128
53
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE24EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
51
        UnsignedCppType unsigned_val;
119
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
51
        if (IsSigned<CppType>::value) {
122
0
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
0
        }
125
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
51
        return Status::OK();
128
51
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE31EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
51
        UnsignedCppType unsigned_val;
119
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
51
        if (IsSigned<CppType>::value) {
122
51
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
51
        }
125
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
51
        return Status::OK();
128
51
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE32EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
51
        UnsignedCppType unsigned_val;
119
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
51
        if (IsSigned<CppType>::value) {
122
51
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
51
        }
125
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
51
        return Status::OK();
128
51
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE33EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
51
        UnsignedCppType unsigned_val;
119
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
51
        if (IsSigned<CppType>::value) {
122
51
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
51
        }
125
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
51
        return Status::OK();
128
51
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE37EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
51
        UnsignedCppType unsigned_val;
119
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
51
        if (IsSigned<CppType>::value) {
122
51
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
51
        }
125
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
51
        return Status::OK();
128
51
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE38EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
51
        UnsignedCppType unsigned_val;
119
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
51
        if (IsSigned<CppType>::value) {
122
0
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
0
        }
125
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
51
        return Status::OK();
128
51
    }
_ZN5doris14KeyCoderTraitsILNS_9FieldTypeE39EvE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
111
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
112
        // decode_ascending only used in orinal index page, maybe should remove it in the future.
113
        // currently, we reduce the usage of this method.
114
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
115
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
116
0
                                           sizeof(UnsignedCppType), encoded_key->size);
117
0
        }
118
51
        UnsignedCppType unsigned_val;
119
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
120
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
121
51
        if (IsSigned<CppType>::value) {
122
0
            unsigned_val ^=
123
                    (static_cast<UnsignedCppType>(1) << (sizeof(UnsignedCppType) * CHAR_BIT - 1));
124
0
        }
125
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
126
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
127
51
        return Status::OK();
128
51
    }
129
};
130
131
template <>
132
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_DATE> {
133
public:
134
    using CppType = typename CppTypeTraits<FieldType::OLAP_FIELD_TYPE_DATE>::CppType;
135
    using UnsignedCppType =
136
            typename CppTypeTraits<FieldType::OLAP_FIELD_TYPE_DATE>::UnsignedCppType;
137
138
public:
139
403k
    static void full_encode_ascending(const void* value, std::string* buf) {
140
403k
        UnsignedCppType unsigned_val;
141
403k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
142
        // make it bigendian
143
403k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
144
403k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
145
403k
    }
146
147
227
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
148
227
        full_encode_ascending(value, buf);
149
227
    }
150
151
53
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
152
53
        if (encoded_key->size < sizeof(UnsignedCppType)) {
153
0
            return Status::InvalidArgument("Key too short, need={} vs real={}",
154
0
                                           sizeof(UnsignedCppType), encoded_key->size);
155
0
        }
156
53
        UnsignedCppType unsigned_val;
157
53
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
158
53
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
159
53
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
160
53
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
161
53
        return Status::OK();
162
53
    }
163
};
164
165
template <>
166
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_DATEV2> {
167
public:
168
    using CppType = typename CppTypeTraits<FieldType::OLAP_FIELD_TYPE_DATEV2>::CppType;
169
    using UnsignedCppType =
170
            typename CppTypeTraits<FieldType::OLAP_FIELD_TYPE_DATEV2>::UnsignedCppType;
171
172
public:
173
923k
    static void full_encode_ascending(const void* value, std::string* buf) {
174
923k
        UnsignedCppType unsigned_val;
175
923k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
176
        // make it bigendian
177
923k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
178
923k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
179
923k
    }
180
181
6.17k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
182
6.17k
        full_encode_ascending(value, buf);
183
6.17k
    }
184
185
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
186
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
187
0
            return Status::InvalidArgument(absl::Substitute("Key too short, need=$0 vs real=$1",
188
0
                                                            sizeof(UnsignedCppType),
189
0
                                                            encoded_key->size));
190
0
        }
191
51
        UnsignedCppType unsigned_val;
192
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
193
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
194
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
195
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
196
51
        return Status::OK();
197
51
    }
198
};
199
200
template <>
201
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_DATETIMEV2> {
202
public:
203
    using CppType = typename CppTypeTraits<FieldType::OLAP_FIELD_TYPE_DATETIMEV2>::CppType;
204
    using UnsignedCppType =
205
            typename CppTypeTraits<FieldType::OLAP_FIELD_TYPE_DATETIMEV2>::UnsignedCppType;
206
207
public:
208
1.16M
    static void full_encode_ascending(const void* value, std::string* buf) {
209
1.16M
        UnsignedCppType unsigned_val;
210
1.16M
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
211
        // make it bigendian
212
1.16M
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
213
1.16M
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
214
1.16M
    }
215
216
2.15k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
217
2.15k
        full_encode_ascending(value, buf);
218
2.15k
    }
219
220
51
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
221
51
        if (encoded_key->size < sizeof(UnsignedCppType)) {
222
0
            return Status::InvalidArgument(absl::Substitute("Key too short, need=$0 vs real=$1",
223
0
                                                            sizeof(UnsignedCppType),
224
0
                                                            encoded_key->size));
225
0
        }
226
51
        UnsignedCppType unsigned_val;
227
51
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
228
51
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
229
51
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
230
51
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
231
51
        return Status::OK();
232
51
    }
233
};
234
235
template <>
236
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_TIMESTAMPTZ> {
237
public:
238
    using CppType = typename CppTypeTraits<FieldType::OLAP_FIELD_TYPE_TIMESTAMPTZ>::CppType;
239
    using UnsignedCppType =
240
            typename CppTypeTraits<FieldType::OLAP_FIELD_TYPE_TIMESTAMPTZ>::UnsignedCppType;
241
242
public:
243
13.7k
    static void full_encode_ascending(const void* value, std::string* buf) {
244
13.7k
        UnsignedCppType unsigned_val;
245
13.7k
        memcpy(&unsigned_val, value, sizeof(unsigned_val));
246
        // make it bigendian
247
13.7k
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
248
13.7k
        buf->append((char*)&unsigned_val, sizeof(unsigned_val));
249
13.7k
    }
250
251
1.32k
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
252
1.32k
        full_encode_ascending(value, buf);
253
1.32k
    }
254
255
0
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
256
0
        if (encoded_key->size < sizeof(UnsignedCppType)) {
257
0
            return Status::InvalidArgument(absl::Substitute("Key too short, need=$0 vs real=$1",
258
0
                                                            sizeof(UnsignedCppType),
259
0
                                                            encoded_key->size));
260
0
        }
261
0
        UnsignedCppType unsigned_val;
262
0
        memcpy(&unsigned_val, encoded_key->data, sizeof(UnsignedCppType));
263
0
        unsigned_val = to_endian<std::endian::big>(unsigned_val);
264
0
        memcpy(cell_ptr, &unsigned_val, sizeof(UnsignedCppType));
265
0
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
266
0
        return Status::OK();
267
0
    }
268
};
269
270
template <>
271
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_DECIMAL> {
272
public:
273
284
    static void full_encode_ascending(const void* value, std::string* buf) {
274
284
        decimal12_t decimal_val;
275
284
        memcpy(&decimal_val, value, sizeof(decimal12_t));
276
284
        KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_BIGINT>::full_encode_ascending(
277
284
                &decimal_val.integer, buf);
278
284
        KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_INT>::full_encode_ascending(&decimal_val.fraction,
279
284
                                                                              buf);
280
284
    } // namespace doris
281
282
51
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
283
51
        full_encode_ascending(value, buf);
284
51
    }
285
286
64
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
287
64
        decimal12_t decimal_val = {0, 0};
288
64
        RETURN_IF_ERROR(KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_BIGINT>::decode_ascending(
289
64
                encoded_key, sizeof(decimal_val.integer), (uint8_t*)&decimal_val.integer));
290
64
        RETURN_IF_ERROR(KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_INT>::decode_ascending(
291
64
                encoded_key, sizeof(decimal_val.fraction), (uint8_t*)&decimal_val.fraction));
292
64
        memcpy(cell_ptr, &decimal_val, sizeof(decimal12_t));
293
64
        return Status::OK();
294
64
    }
295
};
296
297
template <>
298
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_CHAR> {
299
public:
300
2.45k
    NO_SANITIZE_UNDEFINED static void full_encode_ascending(const void* value, std::string* buf) {
301
2.45k
        auto slice = reinterpret_cast<const Slice*>(value);
302
2.45k
        buf->append(slice->get_data(), slice->get_size());
303
2.45k
    }
304
305
    NO_SANITIZE_UNDEFINED static void encode_ascending(const void* value, size_t index_size,
306
1.14k
                                                       std::string* buf) {
307
1.14k
        const Slice* slice = (const Slice*)value;
308
1.14k
        CHECK(index_size <= slice->size)
309
0
                << "index size is larger than char size, index=" << index_size
310
0
                << ", char=" << slice->size;
311
1.14k
        buf->append(slice->data, index_size);
312
1.14k
    }
313
314
0
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
315
0
        throw Exception(Status::FatalError("decode_ascending is not implemented"));
316
0
    }
317
};
318
319
template <>
320
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_VARCHAR> {
321
public:
322
17.8M
    NO_SANITIZE_UNDEFINED static void full_encode_ascending(const void* value, std::string* buf) {
323
17.8M
        auto slice = reinterpret_cast<const Slice*>(value);
324
17.8M
        buf->append(slice->get_data(), slice->get_size());
325
17.8M
    }
326
327
    NO_SANITIZE_UNDEFINED static void encode_ascending(const void* value, size_t index_size,
328
23.8k
                                                       std::string* buf) {
329
23.8k
        const Slice* slice = (const Slice*)value;
330
23.8k
        size_t copy_size = std::min(index_size, slice->size);
331
23.8k
        buf->append(slice->data, copy_size);
332
23.8k
    }
333
334
0
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
335
0
        throw Exception(Status::FatalError("decode_ascending is not implemented"));
336
0
    }
337
};
338
339
template <>
340
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_STRING> {
341
public:
342
889
    NO_SANITIZE_UNDEFINED static void full_encode_ascending(const void* value, std::string* buf) {
343
889
        auto slice = reinterpret_cast<const Slice*>(value);
344
889
        buf->append(slice->get_data(), slice->get_size());
345
889
    }
346
347
    NO_SANITIZE_UNDEFINED static void encode_ascending(const void* value, size_t index_size,
348
49
                                                       std::string* buf) {
349
49
        const Slice* slice = (const Slice*)value;
350
49
        size_t copy_size = std::min(index_size, slice->size);
351
49
        buf->append(slice->data, copy_size);
352
49
    }
353
354
0
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
355
0
        throw Exception(Status::FatalError("decode_ascending is not implemented"));
356
0
    }
357
};
358
359
template <FieldType field_type>
360
class KeyCoderTraitsForFloat {
361
public:
362
    using CppType = typename CppTypeTraits<field_type>::CppType;
363
    using UnsignedCppType = typename CppTypeTraits<field_type>::UnsignedCppType;
364
365
635
    static UnsignedCppType encode_float(CppType value) {
366
635
        return sortable_float_bits(float_to_int_bits(value));
367
635
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE12encode_floatEf
Line
Count
Source
365
297
    static UnsignedCppType encode_float(CppType value) {
366
297
        return sortable_float_bits(float_to_int_bits(value));
367
297
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE12encode_floatEd
Line
Count
Source
365
338
    static UnsignedCppType encode_float(CppType value) {
366
338
        return sortable_float_bits(float_to_int_bits(value));
367
338
    }
368
369
128
    static CppType decode_float(UnsignedCppType sortable_bits) {
370
128
        return int_bits_to_float(unsortable_float_bits(sortable_bits));
371
128
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE12decode_floatEj
Line
Count
Source
369
64
    static CppType decode_float(UnsignedCppType sortable_bits) {
370
64
        return int_bits_to_float(unsortable_float_bits(sortable_bits));
371
64
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE12decode_floatEm
Line
Count
Source
369
64
    static CppType decode_float(UnsignedCppType sortable_bits) {
370
64
        return int_bits_to_float(unsortable_float_bits(sortable_bits));
371
64
    }
372
373
    // -infinity < -100.0 < -1.0 < -0.0 < 0.0 < 1.0 < 100.0 < infinity < NaN
374
635
    static void full_encode_ascending(const void* value, std::string* buf) {
375
635
        CppType val;
376
635
        std::memcpy(&val, value, sizeof(CppType));
377
635
        UnsignedCppType sortable_val = encode_float(val);
378
635
        constexpr UnsignedCppType sign_bit = UnsignedCppType(1)
379
635
                                             << (sizeof(UnsignedCppType) * 8 - 1);
380
635
        sortable_val ^= sign_bit;
381
635
        sortable_val = to_endian<std::endian::big>(sortable_val);
382
635
        buf->append(reinterpret_cast<const char*>(&sortable_val), sizeof(UnsignedCppType));
383
635
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
374
297
    static void full_encode_ascending(const void* value, std::string* buf) {
375
297
        CppType val;
376
297
        std::memcpy(&val, value, sizeof(CppType));
377
297
        UnsignedCppType sortable_val = encode_float(val);
378
297
        constexpr UnsignedCppType sign_bit = UnsignedCppType(1)
379
297
                                             << (sizeof(UnsignedCppType) * 8 - 1);
380
297
        sortable_val ^= sign_bit;
381
297
        sortable_val = to_endian<std::endian::big>(sortable_val);
382
297
        buf->append(reinterpret_cast<const char*>(&sortable_val), sizeof(UnsignedCppType));
383
297
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE21full_encode_ascendingEPKvPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
374
338
    static void full_encode_ascending(const void* value, std::string* buf) {
375
338
        CppType val;
376
338
        std::memcpy(&val, value, sizeof(CppType));
377
338
        UnsignedCppType sortable_val = encode_float(val);
378
338
        constexpr UnsignedCppType sign_bit = UnsignedCppType(1)
379
338
                                             << (sizeof(UnsignedCppType) * 8 - 1);
380
338
        sortable_val ^= sign_bit;
381
338
        sortable_val = to_endian<std::endian::big>(sortable_val);
382
338
        buf->append(reinterpret_cast<const char*>(&sortable_val), sizeof(UnsignedCppType));
383
338
    }
384
385
0
    static void encode_ascending(const void* value, size_t index_size, std::string* buf) {
386
0
        full_encode_ascending(value, buf);
387
0
    }
Unexecuted instantiation: _ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Unexecuted instantiation: _ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE16encode_ascendingEPKvmPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
388
389
128
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
390
128
        if (encoded_key->size < sizeof(UnsignedCppType)) {
391
0
            return Status::InvalidArgument(absl::Substitute("Key too short, need=$0 vs real=$1",
392
0
                                                            sizeof(UnsignedCppType),
393
0
                                                            encoded_key->size));
394
0
        }
395
128
        UnsignedCppType sortable_val;
396
128
        std::memcpy(&sortable_val, encoded_key->data, sizeof(UnsignedCppType));
397
128
        sortable_val = to_endian<std::endian::big>(sortable_val);
398
128
        constexpr UnsignedCppType sign_bit = UnsignedCppType(1)
399
128
                                             << (sizeof(UnsignedCppType) * 8 - 1);
400
128
        sortable_val ^= sign_bit;
401
128
        CppType val = decode_float(sortable_val);
402
128
        std::memcpy(cell_ptr, &val, sizeof(CppType));
403
128
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
404
128
        return Status::OK();
405
128
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
389
64
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
390
64
        if (encoded_key->size < sizeof(UnsignedCppType)) {
391
0
            return Status::InvalidArgument(absl::Substitute("Key too short, need=$0 vs real=$1",
392
0
                                                            sizeof(UnsignedCppType),
393
0
                                                            encoded_key->size));
394
0
        }
395
64
        UnsignedCppType sortable_val;
396
64
        std::memcpy(&sortable_val, encoded_key->data, sizeof(UnsignedCppType));
397
64
        sortable_val = to_endian<std::endian::big>(sortable_val);
398
64
        constexpr UnsignedCppType sign_bit = UnsignedCppType(1)
399
64
                                             << (sizeof(UnsignedCppType) * 8 - 1);
400
64
        sortable_val ^= sign_bit;
401
64
        CppType val = decode_float(sortable_val);
402
64
        std::memcpy(cell_ptr, &val, sizeof(CppType));
403
64
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
404
64
        return Status::OK();
405
64
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE16decode_ascendingEPNS_5SliceEmPh
Line
Count
Source
389
64
    static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
390
64
        if (encoded_key->size < sizeof(UnsignedCppType)) {
391
0
            return Status::InvalidArgument(absl::Substitute("Key too short, need=$0 vs real=$1",
392
0
                                                            sizeof(UnsignedCppType),
393
0
                                                            encoded_key->size));
394
0
        }
395
64
        UnsignedCppType sortable_val;
396
64
        std::memcpy(&sortable_val, encoded_key->data, sizeof(UnsignedCppType));
397
64
        sortable_val = to_endian<std::endian::big>(sortable_val);
398
64
        constexpr UnsignedCppType sign_bit = UnsignedCppType(1)
399
64
                                             << (sizeof(UnsignedCppType) * 8 - 1);
400
64
        sortable_val ^= sign_bit;
401
64
        CppType val = decode_float(sortable_val);
402
64
        std::memcpy(cell_ptr, &val, sizeof(CppType));
403
64
        encoded_key->remove_prefix(sizeof(UnsignedCppType));
404
64
        return Status::OK();
405
64
    }
406
407
private:
408
635
    static UnsignedCppType float_to_int_bits(CppType value) {
409
635
        if (std::isnan(value)) {
410
49
            if constexpr (std::is_same_v<CppType, float>) {
411
24
                return 0x7FC00000U;
412
25
            } else {
413
25
                return 0x7FF8000000000000ULL;
414
25
            }
415
49
        }
416
417
0
        UnsignedCppType result;
418
635
        std::memcpy(&result, &value, sizeof(CppType));
419
635
        return result;
420
635
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE17float_to_int_bitsEf
Line
Count
Source
408
297
    static UnsignedCppType float_to_int_bits(CppType value) {
409
297
        if (std::isnan(value)) {
410
24
            if constexpr (std::is_same_v<CppType, float>) {
411
24
                return 0x7FC00000U;
412
            } else {
413
                return 0x7FF8000000000000ULL;
414
            }
415
24
        }
416
417
0
        UnsignedCppType result;
418
297
        std::memcpy(&result, &value, sizeof(CppType));
419
297
        return result;
420
297
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE17float_to_int_bitsEd
Line
Count
Source
408
338
    static UnsignedCppType float_to_int_bits(CppType value) {
409
338
        if (std::isnan(value)) {
410
            if constexpr (std::is_same_v<CppType, float>) {
411
                return 0x7FC00000U;
412
25
            } else {
413
25
                return 0x7FF8000000000000ULL;
414
25
            }
415
25
        }
416
417
0
        UnsignedCppType result;
418
338
        std::memcpy(&result, &value, sizeof(CppType));
419
338
        return result;
420
338
    }
421
422
763
    static UnsignedCppType sortable_float_bits(UnsignedCppType bits) {
423
763
        constexpr int32_t shift = sizeof(UnsignedCppType) * 8 - 1;
424
763
        constexpr UnsignedCppType sign_bit = static_cast<UnsignedCppType>(1) << shift;
425
763
        if ((bits & sign_bit) != 0) {
426
212
            return bits ^ (sign_bit - 1);
427
551
        } else {
428
551
            return bits;
429
551
        }
430
763
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE19sortable_float_bitsEj
Line
Count
Source
422
361
    static UnsignedCppType sortable_float_bits(UnsignedCppType bits) {
423
361
        constexpr int32_t shift = sizeof(UnsignedCppType) * 8 - 1;
424
361
        constexpr UnsignedCppType sign_bit = static_cast<UnsignedCppType>(1) << shift;
425
361
        if ((bits & sign_bit) != 0) {
426
106
            return bits ^ (sign_bit - 1);
427
255
        } else {
428
255
            return bits;
429
255
        }
430
361
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE19sortable_float_bitsEm
Line
Count
Source
422
402
    static UnsignedCppType sortable_float_bits(UnsignedCppType bits) {
423
402
        constexpr int32_t shift = sizeof(UnsignedCppType) * 8 - 1;
424
402
        constexpr UnsignedCppType sign_bit = static_cast<UnsignedCppType>(1) << shift;
425
402
        if ((bits & sign_bit) != 0) {
426
106
            return bits ^ (sign_bit - 1);
427
296
        } else {
428
296
            return bits;
429
296
        }
430
402
    }
431
432
128
    static CppType int_bits_to_float(UnsignedCppType bits) {
433
128
        CppType result;
434
128
        std::memcpy(&result, &bits, sizeof(CppType));
435
128
        return result;
436
128
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE17int_bits_to_floatEj
Line
Count
Source
432
64
    static CppType int_bits_to_float(UnsignedCppType bits) {
433
64
        CppType result;
434
64
        std::memcpy(&result, &bits, sizeof(CppType));
435
64
        return result;
436
64
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE17int_bits_to_floatEm
Line
Count
Source
432
64
    static CppType int_bits_to_float(UnsignedCppType bits) {
433
64
        CppType result;
434
64
        std::memcpy(&result, &bits, sizeof(CppType));
435
64
        return result;
436
64
    }
437
438
128
    static UnsignedCppType unsortable_float_bits(UnsignedCppType sortable_bits) {
439
128
        return sortable_float_bits(sortable_bits);
440
128
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE10EE21unsortable_float_bitsEj
Line
Count
Source
438
64
    static UnsignedCppType unsortable_float_bits(UnsignedCppType sortable_bits) {
439
64
        return sortable_float_bits(sortable_bits);
440
64
    }
_ZN5doris22KeyCoderTraitsForFloatILNS_9FieldTypeE11EE21unsortable_float_bitsEm
Line
Count
Source
438
64
    static UnsignedCppType unsortable_float_bits(UnsignedCppType sortable_bits) {
439
64
        return sortable_float_bits(sortable_bits);
440
64
    }
441
};
442
443
template <>
444
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_FLOAT>
445
        : public KeyCoderTraitsForFloat<FieldType::OLAP_FIELD_TYPE_FLOAT> {};
446
447
template <>
448
class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_DOUBLE>
449
        : public KeyCoderTraitsForFloat<FieldType::OLAP_FIELD_TYPE_DOUBLE> {};
450
451
// X-macro listing every (FieldType, PrimitiveType) pair that goes through KeyCoder
452
// as a non-string scalar key. Strings are handled separately because they need
453
// length / padding logic outside KeyCoder. Each entry: M(FT_suffix, PT_suffix).
454
#define DORIS_APPLY_FOR_KEY_ENCODABLE_NON_STRING_TYPES(M) \
455
2.69k
    M(OLAP_FIELD_TYPE_BOOL, TYPE_BOOLEAN)                 \
456
152k
    M(OLAP_FIELD_TYPE_TINYINT, TYPE_TINYINT)              \
457
152k
    M(OLAP_FIELD_TYPE_SMALLINT, TYPE_SMALLINT)            \
458
652k
    M(OLAP_FIELD_TYPE_INT, TYPE_INT)                      \
459
652k
    M(OLAP_FIELD_TYPE_BIGINT, TYPE_BIGINT)                \
460
31.0k
    M(OLAP_FIELD_TYPE_LARGEINT, TYPE_LARGEINT)            \
461
13.3k
    M(OLAP_FIELD_TYPE_FLOAT, TYPE_FLOAT)                  \
462
23
    M(OLAP_FIELD_TYPE_DOUBLE, TYPE_DOUBLE)                \
463
55
    M(OLAP_FIELD_TYPE_DECIMAL, TYPE_DECIMALV2)            \
464
450
    M(OLAP_FIELD_TYPE_DECIMAL32, TYPE_DECIMAL32)          \
465
450
    M(OLAP_FIELD_TYPE_DECIMAL64, TYPE_DECIMAL64)          \
466
1.33k
    M(OLAP_FIELD_TYPE_DECIMAL128I, TYPE_DECIMAL128I)      \
467
1.33k
    M(OLAP_FIELD_TYPE_DECIMAL256, TYPE_DECIMAL256)        \
468
3.88k
    M(OLAP_FIELD_TYPE_DATE, TYPE_DATE)                    \
469
3.88k
    M(OLAP_FIELD_TYPE_DATETIME, TYPE_DATETIME)            \
470
290k
    M(OLAP_FIELD_TYPE_DATEV2, TYPE_DATEV2)                \
471
290k
    M(OLAP_FIELD_TYPE_DATETIMEV2, TYPE_DATETIMEV2)        \
472
8.22k
    M(OLAP_FIELD_TYPE_TIMESTAMPTZ, TYPE_TIMESTAMPTZ)      \
473
8.22k
    M(OLAP_FIELD_TYPE_IPV4, TYPE_IPV4)                    \
474
267
    M(OLAP_FIELD_TYPE_IPV6, TYPE_IPV6)
475
476
// True for exactly the PrimitiveTypes listed in
477
// DORIS_APPLY_FOR_KEY_ENCODABLE_NON_STRING_TYPES. Strings (CHAR/VARCHAR/STRING/
478
// VARBINARY) have their own short-key code path in row_cursor.cpp that calls
479
// storage_field->full_encode_ascending directly, and nested/aggregate types
480
// (ARRAY/MAP/STRUCT/VARIANT/HLL/BITMAP/JSONB/QUANTILE_STATE/AGG_STATE) are not
481
// key-encodable at all -- both groups must never reach the helpers below.
482
0
constexpr bool is_key_encodable_non_string_type(PrimitiveType pt) {
483
0
    switch (pt) {
484
0
#define DORIS_KEY_ENCODABLE_CASE(FT, PT) \
485
0
    case PrimitiveType::PT:              \
486
0
        return true;
487
0
        DORIS_APPLY_FOR_KEY_ENCODABLE_NON_STRING_TYPES(DORIS_KEY_ENCODABLE_CASE)
488
0
#undef DORIS_KEY_ENCODABLE_CASE
489
0
    default:
490
0
        return false;
491
0
    }
492
0
}
493
494
// Convert a Field value to its storage representation (via PrimitiveTypeConvertor)
495
// and full-encode it as a byte-comparable ascending key via KeyCoder.
496
template <PrimitiveType PT>
497
1.17M
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
1.17M
    static_assert(is_key_encodable_non_string_type(PT),
499
1.17M
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
1.17M
                  "strings have their own path in RowCursor that calls "
501
1.17M
                  "storage_field->full_encode_ascending directly, and nested / "
502
1.17M
                  "aggregate types are not key-encodable");
503
1.17M
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
1.17M
    coder->full_encode_ascending(&v, buf);
505
1.17M
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE2EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
2.70k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
2.70k
    static_assert(is_key_encodable_non_string_type(PT),
499
2.70k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
2.70k
                  "strings have their own path in RowCursor that calls "
501
2.70k
                  "storage_field->full_encode_ascending directly, and nested / "
502
2.70k
                  "aggregate types are not key-encodable");
503
2.70k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
2.70k
    coder->full_encode_ascending(&v, buf);
505
2.70k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE3EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
152k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
152k
    static_assert(is_key_encodable_non_string_type(PT),
499
152k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
152k
                  "strings have their own path in RowCursor that calls "
501
152k
                  "storage_field->full_encode_ascending directly, and nested / "
502
152k
                  "aggregate types are not key-encodable");
503
152k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
152k
    coder->full_encode_ascending(&v, buf);
505
152k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE4EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
10.1k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
10.1k
    static_assert(is_key_encodable_non_string_type(PT),
499
10.1k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
10.1k
                  "strings have their own path in RowCursor that calls "
501
10.1k
                  "storage_field->full_encode_ascending directly, and nested / "
502
10.1k
                  "aggregate types are not key-encodable");
503
10.1k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
10.1k
    coder->full_encode_ascending(&v, buf);
505
10.1k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE5EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
651k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
651k
    static_assert(is_key_encodable_non_string_type(PT),
499
651k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
651k
                  "strings have their own path in RowCursor that calls "
501
651k
                  "storage_field->full_encode_ascending directly, and nested / "
502
651k
                  "aggregate types are not key-encodable");
503
651k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
651k
    coder->full_encode_ascending(&v, buf);
505
651k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE6EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
31.1k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
31.1k
    static_assert(is_key_encodable_non_string_type(PT),
499
31.1k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
31.1k
                  "strings have their own path in RowCursor that calls "
501
31.1k
                  "storage_field->full_encode_ascending directly, and nested / "
502
31.1k
                  "aggregate types are not key-encodable");
503
31.1k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
31.1k
    coder->full_encode_ascending(&v, buf);
505
31.1k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE7EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
13.3k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
13.3k
    static_assert(is_key_encodable_non_string_type(PT),
499
13.3k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
13.3k
                  "strings have their own path in RowCursor that calls "
501
13.3k
                  "storage_field->full_encode_ascending directly, and nested / "
502
13.3k
                  "aggregate types are not key-encodable");
503
13.3k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
13.3k
    coder->full_encode_ascending(&v, buf);
505
13.3k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE8EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
28
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
28
    static_assert(is_key_encodable_non_string_type(PT),
499
28
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
28
                  "strings have their own path in RowCursor that calls "
501
28
                  "storage_field->full_encode_ascending directly, and nested / "
502
28
                  "aggregate types are not key-encodable");
503
28
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
28
    coder->full_encode_ascending(&v, buf);
505
28
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE9EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
23
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
23
    static_assert(is_key_encodable_non_string_type(PT),
499
23
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
23
                  "strings have their own path in RowCursor that calls "
501
23
                  "storage_field->full_encode_ascending directly, and nested / "
502
23
                  "aggregate types are not key-encodable");
503
23
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
23
    coder->full_encode_ascending(&v, buf);
505
23
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE20EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
58
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
58
    static_assert(is_key_encodable_non_string_type(PT),
499
58
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
58
                  "strings have their own path in RowCursor that calls "
501
58
                  "storage_field->full_encode_ascending directly, and nested / "
502
58
                  "aggregate types are not key-encodable");
503
58
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
58
    coder->full_encode_ascending(&v, buf);
505
58
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE28EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
465
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
465
    static_assert(is_key_encodable_non_string_type(PT),
499
465
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
465
                  "strings have their own path in RowCursor that calls "
501
465
                  "storage_field->full_encode_ascending directly, and nested / "
502
465
                  "aggregate types are not key-encodable");
503
465
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
465
    coder->full_encode_ascending(&v, buf);
505
465
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE29EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
392
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
392
    static_assert(is_key_encodable_non_string_type(PT),
499
392
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
392
                  "strings have their own path in RowCursor that calls "
501
392
                  "storage_field->full_encode_ascending directly, and nested / "
502
392
                  "aggregate types are not key-encodable");
503
392
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
392
    coder->full_encode_ascending(&v, buf);
505
392
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE30EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
1.34k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
1.34k
    static_assert(is_key_encodable_non_string_type(PT),
499
1.34k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
1.34k
                  "strings have their own path in RowCursor that calls "
501
1.34k
                  "storage_field->full_encode_ascending directly, and nested / "
502
1.34k
                  "aggregate types are not key-encodable");
503
1.34k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
1.34k
    coder->full_encode_ascending(&v, buf);
505
1.34k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE35EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
785
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
785
    static_assert(is_key_encodable_non_string_type(PT),
499
785
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
785
                  "strings have their own path in RowCursor that calls "
501
785
                  "storage_field->full_encode_ascending directly, and nested / "
502
785
                  "aggregate types are not key-encodable");
503
785
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
785
    coder->full_encode_ascending(&v, buf);
505
785
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE11EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
3.88k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
3.88k
    static_assert(is_key_encodable_non_string_type(PT),
499
3.88k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
3.88k
                  "strings have their own path in RowCursor that calls "
501
3.88k
                  "storage_field->full_encode_ascending directly, and nested / "
502
3.88k
                  "aggregate types are not key-encodable");
503
3.88k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
3.88k
    coder->full_encode_ascending(&v, buf);
505
3.88k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE12EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
636
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
636
    static_assert(is_key_encodable_non_string_type(PT),
499
636
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
636
                  "strings have their own path in RowCursor that calls "
501
636
                  "storage_field->full_encode_ascending directly, and nested / "
502
636
                  "aggregate types are not key-encodable");
503
636
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
636
    coder->full_encode_ascending(&v, buf);
505
636
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE25EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
290k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
290k
    static_assert(is_key_encodable_non_string_type(PT),
499
290k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
290k
                  "strings have their own path in RowCursor that calls "
501
290k
                  "storage_field->full_encode_ascending directly, and nested / "
502
290k
                  "aggregate types are not key-encodable");
503
290k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
290k
    coder->full_encode_ascending(&v, buf);
505
290k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE26EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
6.99k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
6.99k
    static_assert(is_key_encodable_non_string_type(PT),
499
6.99k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
6.99k
                  "strings have their own path in RowCursor that calls "
501
6.99k
                  "storage_field->full_encode_ascending directly, and nested / "
502
6.99k
                  "aggregate types are not key-encodable");
503
6.99k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
6.99k
    coder->full_encode_ascending(&v, buf);
505
6.99k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE42EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
8.19k
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
8.19k
    static_assert(is_key_encodable_non_string_type(PT),
499
8.19k
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
8.19k
                  "strings have their own path in RowCursor that calls "
501
8.19k
                  "storage_field->full_encode_ascending directly, and nested / "
502
8.19k
                  "aggregate types are not key-encodable");
503
8.19k
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
8.19k
    coder->full_encode_ascending(&v, buf);
505
8.19k
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE36EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
258
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
258
    static_assert(is_key_encodable_non_string_type(PT),
499
258
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
258
                  "strings have their own path in RowCursor that calls "
501
258
                  "storage_field->full_encode_ascending directly, and nested / "
502
258
                  "aggregate types are not key-encodable");
503
258
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
258
    coder->full_encode_ascending(&v, buf);
505
258
}
_ZN5doris24full_encode_field_as_keyILNS_13PrimitiveTypeE37EEEvRKNS_5FieldEPKNS_8KeyCoderEPNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
Line
Count
Source
497
165
inline void full_encode_field_as_key(const Field& f, const KeyCoder* coder, std::string* buf) {
498
165
    static_assert(is_key_encodable_non_string_type(PT),
499
165
                  "full_encode_field_as_key is for non-string scalar keys only; "
500
165
                  "strings have their own path in RowCursor that calls "
501
165
                  "storage_field->full_encode_ascending directly, and nested / "
502
165
                  "aggregate types are not key-encodable");
503
165
    auto v = PrimitiveTypeConvertor<PT>::to_storage_field_type(f.get<PT>());
504
165
    coder->full_encode_ascending(&v, buf);
505
165
}
506
507
} // namespace doris