Coverage Report

Created: 2026-05-11 06:17

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/util/thrift_util.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 <gen_cpp/DataSinks_types.h>
21
#include <gen_cpp/Types_types.h>
22
#include <thrift/TApplicationException.h>
23
#include <thrift/transport/TBufferTransports.h>
24
25
#include <cstdint>
26
#include <cstring>
27
#include <exception>
28
#include <memory>
29
#include <string>
30
#include <vector>
31
32
#include "common/status.h"
33
34
namespace apache::thrift::protocol {
35
class TProtocol;
36
class TProtocolFactory;
37
} // namespace apache::thrift::protocol
38
39
namespace doris {
40
41
class TNetworkAddress;
42
class ThriftServer;
43
44
// Utility class to serialize thrift objects to a binary format.  This object
45
// should be reused if possible to reuse the underlying memory.
46
// Note: thrift will encode NULLs into the serialized buffer so it is not valid
47
// to treat it as a string.
48
class ThriftSerializer {
49
public:
50
    // If compact, the objects will be serialized using the Compact Protocol.  Otherwise,
51
    // we'll use the binary protocol.
52
    // Note: the deserializer must be matching.
53
    ThriftSerializer(bool compact, int initial_buffer_size);
54
55
    // Serializes obj into result.  Result will contain a copy of the memory.
56
    template <class T>
57
    Status serialize(T* obj, std::vector<uint8_t>* result) {
58
        uint32_t len = 0;
59
        uint8_t* buffer = nullptr;
60
        RETURN_IF_ERROR(serialize<T>(obj, &len, &buffer));
61
        result->resize(len);
62
        memcpy(result->data(), buffer, len);
63
        return Status::OK();
64
    }
65
66
    // serialize obj into a memory buffer.  The result is returned in buffer/len.  The
67
    // memory returned is owned by this object and will be invalid when another object
68
    // is serialized.
69
    template <class T>
70
168k
    Status serialize(T* obj, uint32_t* len, uint8_t** buffer) {
71
168k
        try {
72
168k
            _mem_buffer->resetBuffer();
73
168k
            obj->write(_protocol.get());
74
168k
        } catch (std::exception& e) {
75
0
            return Status::InternalError("Couldn't serialize thrift object:\n{}", e.what());
76
0
        }
77
78
168k
        _mem_buffer->getBuffer(buffer, len);
79
168k
        return Status::OK();
80
168k
    }
_ZN5doris16ThriftSerializer9serializeINS_26TJavaUdfExecutorCtorParamsEEENS_6StatusEPT_PjPPh
Line
Count
Source
70
5.62k
    Status serialize(T* obj, uint32_t* len, uint8_t** buffer) {
71
5.62k
        try {
72
5.62k
            _mem_buffer->resetBuffer();
73
5.62k
            obj->write(_protocol.get());
74
5.62k
        } catch (std::exception& e) {
75
0
            return Status::InternalError("Couldn't serialize thrift object:\n{}", e.what());
76
0
        }
77
78
5.63k
        _mem_buffer->getBuffer(buffer, len);
79
5.63k
        return Status::OK();
80
5.62k
    }
_ZN5doris16ThriftSerializer9serializeINS_12TResultBatchEEENS_6StatusEPT_PjPPh
Line
Count
Source
70
163k
    Status serialize(T* obj, uint32_t* len, uint8_t** buffer) {
71
163k
        try {
72
163k
            _mem_buffer->resetBuffer();
73
163k
            obj->write(_protocol.get());
74
163k
        } catch (std::exception& e) {
75
0
            return Status::InternalError("Couldn't serialize thrift object:\n{}", e.what());
76
0
        }
77
78
163k
        _mem_buffer->getBuffer(buffer, len);
79
163k
        return Status::OK();
80
163k
    }
_ZN5doris16ThriftSerializer9serializeINS_19TRuntimeProfileTreeEEENS_6StatusEPT_PjPPh
Line
Count
Source
70
4
    Status serialize(T* obj, uint32_t* len, uint8_t** buffer) {
71
4
        try {
72
4
            _mem_buffer->resetBuffer();
73
4
            obj->write(_protocol.get());
74
4
        } catch (std::exception& e) {
75
0
            return Status::InternalError("Couldn't serialize thrift object:\n{}", e.what());
76
0
        }
77
78
4
        _mem_buffer->getBuffer(buffer, len);
79
4
        return Status::OK();
80
4
    }
81
82
    template <class T>
83
1.22k
    Status serialize(T* obj, std::string* result) {
84
1.22k
        try {
85
1.22k
            _mem_buffer->resetBuffer();
86
1.22k
            obj->write(_protocol.get());
87
1.22k
        } catch (apache::thrift::TApplicationException& e) {
88
0
            return Status::InternalError("Couldn't serialize thrift object:\n{}", e.what());
89
0
        }
90
91
1.24k
        *result = _mem_buffer->getBufferAsString();
92
1.24k
        return Status::OK();
93
1.22k
    }
94
95
    template <class T>
96
    Status serialize(T* obj) {
97
        try {
98
            _mem_buffer->resetBuffer();
99
            obj->write(_protocol.get());
100
        } catch (apache::thrift::TApplicationException& e) {
101
            return Status::InternalError("Couldn't serialize thrift object:\n{}", e.what());
102
        }
103
104
        return Status::OK();
105
    }
106
107
0
    void get_buffer(uint8_t** buffer, uint32_t* length) { _mem_buffer->getBuffer(buffer, length); }
108
109
private:
110
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> _mem_buffer;
111
    std::shared_ptr<apache::thrift::protocol::TProtocol> _protocol;
112
};
113
114
class ThriftDeserializer {
115
public:
116
    ThriftDeserializer(bool compact);
117
118
private:
119
    std::shared_ptr<apache::thrift::protocol::TProtocolFactory> _factory;
120
    std::shared_ptr<apache::thrift::protocol::TProtocol> _tproto;
121
};
122
123
// Utility to create a protocol (deserialization) object for 'mem'.
124
std::shared_ptr<apache::thrift::protocol::TProtocol> create_deserialize_protocol(
125
        std::shared_ptr<apache::thrift::transport::TMemoryBuffer> mem, bool compact);
126
127
// Deserialize a thrift message from buf/len.  buf/len must at least contain
128
// all the bytes needed to store the thrift message.  On return, len will be
129
// set to the actual length of the header.
130
template <class T>
131
Status deserialize_thrift_msg(const uint8_t* buf, uint32_t* len, bool compact,
132
1.62M
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
1.62M
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
1.62M
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
1.62M
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
1.62M
            new apache::thrift::transport::TMemoryBuffer(
142
1.62M
                    const_cast<uint8_t*>(buf), *len,
143
1.62M
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
1.62M
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
1.62M
            create_deserialize_protocol(tmem_transport, compact);
146
147
1.62M
    try {
148
1.62M
        deserialized_msg->read(tproto.get());
149
1.62M
    } catch (std::exception& e) {
150
350
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
350
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
1.62M
    uint32_t bytes_left = tmem_transport->available_read();
157
1.62M
    *len = *len - bytes_left;
158
1.62M
    return Status::OK();
159
1.62M
}
_ZN5doris22deserialize_thrift_msgIN8tparquet17BloomFilterHeaderEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
22
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
22
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
22
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
22
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
22
            new apache::thrift::transport::TMemoryBuffer(
142
22
                    const_cast<uint8_t*>(buf), *len,
143
22
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
22
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
22
            create_deserialize_protocol(tmem_transport, compact);
146
147
22
    try {
148
22
        deserialized_msg->read(tproto.get());
149
22
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
22
    uint32_t bytes_left = tmem_transport->available_read();
157
22
    *len = *len - bytes_left;
158
22
    return Status::OK();
159
22
}
_ZN5doris22deserialize_thrift_msgINS_19TRuntimeProfileTreeEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
4
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
4
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
4
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
4
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
4
            new apache::thrift::transport::TMemoryBuffer(
142
4
                    const_cast<uint8_t*>(buf), *len,
143
4
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
4
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
4
            create_deserialize_protocol(tmem_transport, compact);
146
147
4
    try {
148
4
        deserialized_msg->read(tproto.get());
149
4
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
4
    uint32_t bytes_left = tmem_transport->available_read();
157
4
    *len = *len - bytes_left;
158
4
    return Status::OK();
159
4
}
_ZN5doris22deserialize_thrift_msgIN8tparquet12FileMetaDataEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
11.4k
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
11.4k
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
11.4k
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
11.4k
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
11.4k
            new apache::thrift::transport::TMemoryBuffer(
142
11.4k
                    const_cast<uint8_t*>(buf), *len,
143
11.4k
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
11.4k
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
11.4k
            create_deserialize_protocol(tmem_transport, compact);
146
147
11.4k
    try {
148
11.4k
        deserialized_msg->read(tproto.get());
149
11.4k
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
11.4k
    uint32_t bytes_left = tmem_transport->available_read();
157
11.4k
    *len = *len - bytes_left;
158
11.4k
    return Status::OK();
159
11.4k
}
_ZN5doris22deserialize_thrift_msgIN8tparquet10PageHeaderEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
1.25M
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
1.25M
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
1.25M
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
1.25M
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
1.25M
            new apache::thrift::transport::TMemoryBuffer(
142
1.25M
                    const_cast<uint8_t*>(buf), *len,
143
1.25M
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
1.25M
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
1.25M
            create_deserialize_protocol(tmem_transport, compact);
146
147
1.25M
    try {
148
1.25M
        deserialized_msg->read(tproto.get());
149
1.25M
    } catch (std::exception& e) {
150
350
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
350
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
1.25M
    uint32_t bytes_left = tmem_transport->available_read();
157
1.25M
    *len = *len - bytes_left;
158
1.25M
    return Status::OK();
159
1.25M
}
_ZN5doris22deserialize_thrift_msgIN8tparquet11ColumnIndexEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
2.58k
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
2.58k
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
2.58k
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
2.58k
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
2.58k
            new apache::thrift::transport::TMemoryBuffer(
142
2.58k
                    const_cast<uint8_t*>(buf), *len,
143
2.58k
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
2.58k
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
2.58k
            create_deserialize_protocol(tmem_transport, compact);
146
147
2.58k
    try {
148
2.58k
        deserialized_msg->read(tproto.get());
149
2.58k
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
2.60k
    uint32_t bytes_left = tmem_transport->available_read();
157
2.60k
    *len = *len - bytes_left;
158
2.60k
    return Status::OK();
159
2.58k
}
_ZN5doris22deserialize_thrift_msgIN8tparquet11OffsetIndexEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
57.0k
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
57.0k
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
57.0k
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
57.0k
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
57.0k
            new apache::thrift::transport::TMemoryBuffer(
142
57.0k
                    const_cast<uint8_t*>(buf), *len,
143
57.0k
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
57.0k
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
57.0k
            create_deserialize_protocol(tmem_transport, compact);
146
147
57.0k
    try {
148
57.0k
        deserialized_msg->read(tproto.get());
149
57.0k
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
57.1k
    uint32_t bytes_left = tmem_transport->available_read();
157
57.1k
    *len = *len - bytes_left;
158
57.1k
    return Status::OK();
159
57.0k
}
_ZN5doris22deserialize_thrift_msgINS_14TQueryPlanInfoEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
3
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
3
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
3
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
3
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
3
            new apache::thrift::transport::TMemoryBuffer(
142
3
                    const_cast<uint8_t*>(buf), *len,
143
3
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
3
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
3
            create_deserialize_protocol(tmem_transport, compact);
146
147
3
    try {
148
3
        deserialized_msg->read(tproto.get());
149
3
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
3
    uint32_t bytes_left = tmem_transport->available_read();
157
3
    *len = *len - bytes_left;
158
3
    return Status::OK();
159
3
}
_ZN5doris22deserialize_thrift_msgINS_27TPipelineFragmentParamsListEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
284k
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
284k
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
284k
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
284k
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
284k
            new apache::thrift::transport::TMemoryBuffer(
142
284k
                    const_cast<uint8_t*>(buf), *len,
143
284k
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
284k
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
284k
            create_deserialize_protocol(tmem_transport, compact);
146
147
284k
    try {
148
284k
        deserialized_msg->read(tproto.get());
149
284k
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
284k
    uint32_t bytes_left = tmem_transport->available_read();
157
284k
    *len = *len - bytes_left;
158
284k
    return Status::OK();
159
284k
}
_ZN5doris22deserialize_thrift_msgINS_15TResultFileSinkEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
4
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
4
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
4
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
4
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
4
            new apache::thrift::transport::TMemoryBuffer(
142
4
                    const_cast<uint8_t*>(buf), *len,
143
4
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
4
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
4
            create_deserialize_protocol(tmem_transport, compact);
146
147
4
    try {
148
4
        deserialized_msg->read(tproto.get());
149
4
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
4
    uint32_t bytes_left = tmem_transport->available_read();
157
4
    *len = *len - bytes_left;
158
4
    return Status::OK();
159
4
}
_ZN5doris22deserialize_thrift_msgINS_14TFileScanRangeEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
4.03k
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
4.03k
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
4.03k
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
4.03k
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
4.03k
            new apache::thrift::transport::TMemoryBuffer(
142
4.03k
                    const_cast<uint8_t*>(buf), *len,
143
4.03k
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
4.03k
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
4.03k
            create_deserialize_protocol(tmem_transport, compact);
146
147
4.03k
    try {
148
4.03k
        deserialized_msg->read(tproto.get());
149
4.03k
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
4.03k
    uint32_t bytes_left = tmem_transport->available_read();
157
4.03k
    *len = *len - bytes_left;
158
4.03k
    return Status::OK();
159
4.03k
}
_ZN5doris22deserialize_thrift_msgINS_16TTableDescriptorEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
315
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
315
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
315
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
315
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
315
            new apache::thrift::transport::TMemoryBuffer(
142
315
                    const_cast<uint8_t*>(buf), *len,
143
315
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
315
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
315
            create_deserialize_protocol(tmem_transport, compact);
146
147
315
    try {
148
315
        deserialized_msg->read(tproto.get());
149
315
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
315
    uint32_t bytes_left = tmem_transport->available_read();
157
315
    *len = *len - bytes_left;
158
315
    return Status::OK();
159
315
}
_ZN5doris22deserialize_thrift_msgINS_19TFoldConstantParamsEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
570
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
570
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
570
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
570
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
570
            new apache::thrift::transport::TMemoryBuffer(
142
570
                    const_cast<uint8_t*>(buf), *len,
143
570
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
570
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
570
            create_deserialize_protocol(tmem_transport, compact);
146
147
570
    try {
148
570
        deserialized_msg->read(tproto.get());
149
570
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
570
    uint32_t bytes_left = tmem_transport->available_read();
157
570
    *len = *len - bytes_left;
158
570
    return Status::OK();
159
570
}
_ZN5doris22deserialize_thrift_msgINS_16TDescriptorTableEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
156
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
156
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
156
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
156
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
156
            new apache::thrift::transport::TMemoryBuffer(
142
156
                    const_cast<uint8_t*>(buf), *len,
143
156
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
156
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
156
            create_deserialize_protocol(tmem_transport, compact);
146
147
156
    try {
148
156
        deserialized_msg->read(tproto.get());
149
156
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
156
    uint32_t bytes_left = tmem_transport->available_read();
157
156
    *len = *len - bytes_left;
158
156
    return Status::OK();
159
156
}
_ZN5doris22deserialize_thrift_msgINS_9TExprListEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
156
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
156
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
156
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
156
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
156
            new apache::thrift::transport::TMemoryBuffer(
142
156
                    const_cast<uint8_t*>(buf), *len,
143
156
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
156
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
156
            create_deserialize_protocol(tmem_transport, compact);
146
147
156
    try {
148
156
        deserialized_msg->read(tproto.get());
149
156
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
156
    uint32_t bytes_left = tmem_transport->available_read();
157
156
    *len = *len - bytes_left;
158
156
    return Status::OK();
159
156
}
_ZN5doris22deserialize_thrift_msgINS_13TQueryOptionsEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
156
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
156
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
156
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
156
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
156
            new apache::thrift::transport::TMemoryBuffer(
142
156
                    const_cast<uint8_t*>(buf), *len,
143
156
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
156
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
156
            create_deserialize_protocol(tmem_transport, compact);
146
147
156
    try {
148
156
        deserialized_msg->read(tproto.get());
149
156
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
156
    uint32_t bytes_left = tmem_transport->available_read();
157
156
    *len = *len - bytes_left;
158
156
    return Status::OK();
159
156
}
_ZN5doris22deserialize_thrift_msgINS_9TExprNodeEEENS_6StatusEPKhPjbPT_
Line
Count
Source
132
958
                              T* deserialized_msg) {
133
    // Deserialize msg bytes into c++ thrift msg using memory
134
    // transport. TMemoryBuffer is not const-safe, although we use it in
135
    // a const-safe way, so we have to explicitly cast away the const.
136
958
    auto conf = std::make_shared<apache::thrift::TConfiguration>();
137
    // On Thrift 0.14.0+, need use TConfiguration to raise the max message size.
138
    // max message size is 100MB default, so make it unlimited.
139
958
    conf->setMaxMessageSize(std::numeric_limits<int>::max());
140
958
    std::shared_ptr<apache::thrift::transport::TMemoryBuffer> tmem_transport(
141
958
            new apache::thrift::transport::TMemoryBuffer(
142
958
                    const_cast<uint8_t*>(buf), *len,
143
958
                    apache::thrift::transport::TMemoryBuffer::OBSERVE, conf));
144
958
    std::shared_ptr<apache::thrift::protocol::TProtocol> tproto =
145
958
            create_deserialize_protocol(tmem_transport, compact);
146
147
958
    try {
148
958
        deserialized_msg->read(tproto.get());
149
958
    } catch (std::exception& e) {
150
0
        return Status::InternalError<false>("Couldn't deserialize thrift msg:\n{}", e.what());
151
0
    } catch (...) {
152
        // TODO: Find the right exception for 0 bytes
153
0
        return Status::InternalError("Unknown exception");
154
0
    }
155
156
958
    uint32_t bytes_left = tmem_transport->available_read();
157
958
    *len = *len - bytes_left;
158
958
    return Status::OK();
159
958
}
160
161
// Redirects all Thrift logging to VLOG_CRITICAL
162
void init_thrift_logging();
163
164
// Wait for a server that is running locally to start accepting
165
// connections, up to a maximum timeout
166
Status wait_for_local_server(const ThriftServer& server, int num_retries, int retry_interval_ms);
167
168
// Wait for a server to start accepting connections, up to a maximum timeout
169
Status wait_for_server(const std::string& host, int port, int num_retries, int retry_interval_ms);
170
171
// Utility method to print address as address:port
172
void t_network_address_to_string(const TNetworkAddress& address, std::string* out);
173
174
// Compares two TNetworkAddresses alphanumerically by their host:port
175
// string representation
176
bool t_network_address_comparator(const TNetworkAddress& a, const TNetworkAddress& b);
177
178
PURE std::string to_string(const TUniqueId& id);
179
180
PURE bool _has_inverted_index_v1_or_partial_update(TOlapTableSink sink);
181
182
} // namespace doris