Coverage Report

Created: 2026-06-24 16:28

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
be/src/cloud/pb_convert.cpp
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
#include "cloud/pb_convert.h"
19
20
#include <gen_cpp/olap_file.pb.h>
21
22
#include <utility>
23
24
#include "common/logging.h"
25
26
namespace doris::cloud {
27
28
0
RowsetMetaCloudPB doris_rowset_meta_to_cloud(const RowsetMetaPB& in) {
29
0
    RowsetMetaCloudPB out;
30
0
    doris_rowset_meta_to_cloud(&out, in);
31
0
    return out;
32
0
}
33
34
63.8k
RowsetMetaCloudPB doris_rowset_meta_to_cloud(RowsetMetaPB&& in) {
35
63.8k
    RowsetMetaCloudPB out;
36
63.8k
    doris_rowset_meta_to_cloud(&out, std::move(in));
37
63.8k
    return out;
38
63.8k
}
39
40
5
void doris_rowset_meta_to_cloud(RowsetMetaCloudPB* out, const RowsetMetaPB& in) {
41
    // ATTN: please keep the set order aligned with the definition of proto `TabletSchemaCloudPB`.
42
5
    out->set_rowset_id(in.rowset_id());
43
5
    out->set_partition_id(in.partition_id());
44
5
    out->set_tablet_id(in.tablet_id());
45
5
    out->set_txn_id(in.txn_id());
46
5
    out->set_tablet_schema_hash(in.tablet_schema_hash());
47
5
    out->set_rowset_type(in.rowset_type());
48
5
    out->set_rowset_state(in.rowset_state());
49
5
    out->set_start_version(in.start_version());
50
5
    out->set_end_version(in.end_version());
51
5
    out->set_version_hash(in.version_hash());
52
5
    out->set_num_rows(in.num_rows());
53
5
    out->set_total_disk_size(in.total_disk_size());
54
5
    out->set_data_disk_size(in.data_disk_size());
55
5
    out->set_index_disk_size(in.index_disk_size());
56
5
    out->mutable_zone_maps()->CopyFrom(in.zone_maps());
57
5
    if (in.has_delete_predicate()) {
58
1
        out->mutable_delete_predicate()->CopyFrom(in.delete_predicate());
59
1
    }
60
5
    out->set_empty(in.empty());
61
5
    if (in.has_load_id()) {
62
1
        out->mutable_load_id()->CopyFrom(in.load_id());
63
1
    }
64
5
    out->set_delete_flag(in.delete_flag());
65
5
    out->set_creation_time(in.creation_time());
66
5
    if (in.has_tablet_uid()) {
67
1
        out->mutable_tablet_uid()->CopyFrom(in.tablet_uid());
68
1
    }
69
5
    out->set_num_segments(in.num_segments());
70
5
    out->set_rowset_id_v2(in.rowset_id_v2());
71
5
    out->set_resource_id(in.resource_id());
72
5
    out->set_newest_write_timestamp(in.newest_write_timestamp());
73
5
    out->mutable_segments_key_bounds()->CopyFrom(in.segments_key_bounds());
74
5
    if (in.has_tablet_schema()) {
75
1
        doris_tablet_schema_to_cloud(out->mutable_tablet_schema(), in.tablet_schema());
76
1
    }
77
5
    if (in.has_schema_dict_key_list()) {
78
1
        out->mutable_schema_dict_key_list()->CopyFrom(in.schema_dict_key_list());
79
1
    }
80
5
    out->set_txn_expiration(in.txn_expiration());
81
5
    out->set_segments_overlap_pb(in.segments_overlap_pb());
82
5
    if (in.has_segments_key_bounds_truncated()) {
83
1
        out->set_segments_key_bounds_truncated(in.segments_key_bounds_truncated());
84
1
    }
85
5
    if (in.has_segments_key_bounds_aggregated()) {
86
1
        out->set_segments_key_bounds_aggregated(in.segments_key_bounds_aggregated());
87
1
    }
88
5
    out->mutable_num_segment_rows()->CopyFrom(in.num_segment_rows());
89
5
    out->mutable_segments_file_size()->CopyFrom(in.segments_file_size());
90
5
    out->set_index_id(in.index_id());
91
5
    if (in.has_schema_version()) {
92
        // See cloud/src/meta-service/meta_service_schema.cpp for details.
93
1
        out->set_schema_version(in.schema_version());
94
1
    }
95
5
    out->set_enable_segments_file_size(in.enable_segments_file_size());
96
5
    out->set_has_variant_type_in_schema(in.has_variant_type_in_schema());
97
5
    out->set_enable_inverted_index_file_info(in.enable_inverted_index_file_info());
98
5
    out->set_compaction_level(in.compaction_level());
99
5
    out->mutable_inverted_index_file_info()->CopyFrom(in.inverted_index_file_info());
100
5
    out->set_source_rowset_id(in.source_rowset_id());
101
5
    out->set_source_tablet_id(in.source_tablet_id());
102
5
    if (in.has___split_schema()) {
103
1
        out->mutable___split_schema()->CopyFrom(in.__split_schema());
104
1
    }
105
5
    if (in.has_visible_ts_ms()) {
106
1
        out->set_visible_ts_ms(in.visible_ts_ms());
107
1
    }
108
5
    if (in.has_reference_instance_id()) {
109
1
        out->set_reference_instance_id(in.reference_instance_id());
110
1
    }
111
5
    auto* slice_locations = out->mutable_packed_slice_locations();
112
5
    slice_locations->clear();
113
5
    slice_locations->insert(in.packed_slice_locations().begin(), in.packed_slice_locations().end());
114
5
    if (in.has_is_recycled()) {
115
1
        out->set_is_recycled(in.is_recycled());
116
1
    }
117
5
    if (in.has_job_id()) {
118
1
        out->set_job_id(in.job_id());
119
1
    }
120
5
    if (in.has_commit_tso()) {
121
1
        out->mutable_commit_tso()->CopyFrom(in.commit_tso());
122
1
    }
123
5
    if (in.has_is_row_binlog()) {
124
1
        out->set_is_row_binlog(in.is_row_binlog());
125
1
    }
126
5
    if (in.has_db_id()) {
127
1
        out->set_db_id(in.db_id());
128
1
    }
129
5
    if (in.has_table_id()) {
130
1
        out->set_table_id(in.table_id());
131
1
    }
132
5
}
133
134
451k
void doris_rowset_meta_to_cloud(RowsetMetaCloudPB* out, RowsetMetaPB&& in) {
135
    // ATTN: please keep the set order aligned with the definition of proto `TabletSchemaCloudPB`.
136
451k
    out->set_rowset_id(in.rowset_id());
137
451k
    out->set_partition_id(in.partition_id());
138
451k
    out->set_tablet_id(in.tablet_id());
139
451k
    out->set_txn_id(in.txn_id());
140
451k
    out->set_tablet_schema_hash(in.tablet_schema_hash());
141
451k
    out->set_rowset_type(in.rowset_type());
142
451k
    out->set_rowset_state(in.rowset_state());
143
451k
    out->set_start_version(in.start_version());
144
451k
    out->set_end_version(in.end_version());
145
451k
    out->set_version_hash(in.version_hash());
146
451k
    out->set_num_rows(in.num_rows());
147
451k
    out->set_total_disk_size(in.total_disk_size());
148
451k
    out->set_data_disk_size(in.data_disk_size());
149
451k
    out->set_index_disk_size(in.index_disk_size());
150
451k
    out->mutable_zone_maps()->Swap(in.mutable_zone_maps());
151
451k
    if (in.has_delete_predicate()) {
152
6.51k
        out->mutable_delete_predicate()->Swap(in.mutable_delete_predicate());
153
6.51k
    }
154
451k
    out->set_empty(in.empty());
155
451k
    if (in.has_load_id()) {
156
406k
        out->mutable_load_id()->CopyFrom(in.load_id());
157
406k
    }
158
451k
    out->set_delete_flag(in.delete_flag());
159
451k
    out->set_creation_time(in.creation_time());
160
451k
    if (in.has_tablet_uid()) {
161
1.35k
        out->mutable_tablet_uid()->CopyFrom(in.tablet_uid());
162
1.35k
    }
163
451k
    out->set_num_segments(in.num_segments());
164
451k
    out->set_rowset_id_v2(in.rowset_id_v2());
165
451k
    out->set_resource_id(in.resource_id());
166
451k
    out->set_newest_write_timestamp(in.newest_write_timestamp());
167
451k
    out->mutable_segments_key_bounds()->Swap(in.mutable_segments_key_bounds());
168
451k
    if (in.has_tablet_schema()) {
169
192k
        doris_tablet_schema_to_cloud(out->mutable_tablet_schema(),
170
192k
                                     std::move(*in.mutable_tablet_schema()));
171
192k
    }
172
451k
    if (in.has_schema_dict_key_list()) {
173
48
        out->mutable_schema_dict_key_list()->Swap(in.mutable_schema_dict_key_list());
174
48
    }
175
451k
    out->set_txn_expiration(in.txn_expiration());
176
451k
    out->set_segments_overlap_pb(in.segments_overlap_pb());
177
451k
    if (in.has_segments_key_bounds_truncated()) {
178
254k
        out->set_segments_key_bounds_truncated(in.segments_key_bounds_truncated());
179
254k
    }
180
451k
    if (in.has_segments_key_bounds_aggregated()) {
181
254k
        out->set_segments_key_bounds_aggregated(in.segments_key_bounds_aggregated());
182
254k
    }
183
451k
    out->mutable_num_segment_rows()->Swap(in.mutable_num_segment_rows());
184
451k
    out->mutable_segments_file_size()->Swap(in.mutable_segments_file_size());
185
451k
    out->set_index_id(in.index_id());
186
451k
    if (in.has_schema_version()) {
187
        // See cloud/src/meta-service/meta_service_schema.cpp for details.
188
447k
        out->set_schema_version(in.schema_version());
189
447k
    }
190
451k
    out->set_enable_segments_file_size(in.enable_segments_file_size());
191
451k
    out->set_has_variant_type_in_schema(in.has_variant_type_in_schema());
192
451k
    out->set_enable_inverted_index_file_info(in.enable_inverted_index_file_info());
193
451k
    out->set_compaction_level(in.compaction_level());
194
451k
    out->mutable_inverted_index_file_info()->Swap(in.mutable_inverted_index_file_info());
195
451k
    out->set_source_rowset_id(in.source_rowset_id());
196
451k
    out->set_source_tablet_id(in.source_tablet_id());
197
198
451k
    if (in.has___split_schema()) {
199
2
        out->mutable___split_schema()->Swap(in.mutable___split_schema());
200
2
    }
201
451k
    if (in.has_visible_ts_ms()) {
202
54.0k
        out->set_visible_ts_ms(in.visible_ts_ms());
203
54.0k
    }
204
451k
    if (in.has_reference_instance_id()) {
205
2
        out->set_reference_instance_id(in.reference_instance_id());
206
2
    }
207
451k
    auto* slice_locations = out->mutable_packed_slice_locations();
208
451k
    slice_locations->clear();
209
451k
    slice_locations->insert(in.packed_slice_locations().begin(), in.packed_slice_locations().end());
210
451k
    if (in.has_is_recycled()) {
211
2
        out->set_is_recycled(in.is_recycled());
212
2
    }
213
451k
    if (in.has_job_id()) {
214
445k
        out->set_job_id(in.job_id());
215
445k
    }
216
451k
    if (in.has_commit_tso()) {
217
12.7k
        out->mutable_commit_tso()->CopyFrom(in.commit_tso());
218
12.7k
    }
219
451k
    if (in.has_is_row_binlog()) {
220
2
        out->set_is_row_binlog(in.is_row_binlog());
221
2
    }
222
451k
    if (in.has_db_id()) {
223
446k
        out->set_db_id(in.db_id());
224
446k
    }
225
451k
    if (in.has_table_id()) {
226
446k
        out->set_table_id(in.table_id());
227
446k
    }
228
451k
}
229
230
133k
RowsetMetaPB cloud_rowset_meta_to_doris(const RowsetMetaCloudPB& in) {
231
133k
    RowsetMetaPB out;
232
133k
    cloud_rowset_meta_to_doris(&out, in);
233
133k
    return out;
234
133k
}
235
236
5
RowsetMetaPB cloud_rowset_meta_to_doris(RowsetMetaCloudPB&& in) {
237
5
    RowsetMetaPB out;
238
5
    cloud_rowset_meta_to_doris(&out, std::move(in));
239
5
    return out;
240
5
}
241
242
134k
void cloud_rowset_meta_to_doris(RowsetMetaPB* out, const RowsetMetaCloudPB& in) {
243
    // ATTN: please keep the set order aligned with the definition of proto `TabletSchemaCloudPB`.
244
134k
    out->set_rowset_id(in.rowset_id());
245
134k
    out->set_partition_id(in.partition_id());
246
134k
    out->set_tablet_id(in.tablet_id());
247
134k
    out->set_txn_id(in.txn_id());
248
134k
    out->set_tablet_schema_hash(in.tablet_schema_hash());
249
134k
    out->set_rowset_type(in.rowset_type());
250
134k
    out->set_rowset_state(in.rowset_state());
251
134k
    out->set_start_version(in.start_version());
252
134k
    out->set_end_version(in.end_version());
253
134k
    out->set_version_hash(in.version_hash());
254
134k
    out->set_num_rows(in.num_rows());
255
134k
    out->set_total_disk_size(in.total_disk_size());
256
134k
    out->set_data_disk_size(in.data_disk_size());
257
134k
    out->set_index_disk_size(in.index_disk_size());
258
134k
    out->mutable_zone_maps()->CopyFrom(in.zone_maps());
259
134k
    if (in.has_delete_predicate()) {
260
58
        out->mutable_delete_predicate()->CopyFrom(in.delete_predicate());
261
58
    }
262
134k
    out->set_empty(in.empty());
263
134k
    if (in.has_load_id()) {
264
12.4k
        out->mutable_load_id()->CopyFrom(in.load_id());
265
12.4k
    }
266
134k
    out->set_delete_flag(in.delete_flag());
267
134k
    out->set_creation_time(in.creation_time());
268
134k
    if (in.has_tablet_uid()) {
269
1
        out->mutable_tablet_uid()->CopyFrom(in.tablet_uid());
270
1
    }
271
134k
    out->set_num_segments(in.num_segments());
272
134k
    out->set_rowset_id_v2(in.rowset_id_v2());
273
134k
    out->set_resource_id(in.resource_id());
274
134k
    out->set_newest_write_timestamp(in.newest_write_timestamp());
275
134k
    out->mutable_segments_key_bounds()->CopyFrom(in.segments_key_bounds());
276
134k
    if (in.has_tablet_schema()) {
277
133k
        cloud_tablet_schema_to_doris(out->mutable_tablet_schema(), in.tablet_schema());
278
133k
    }
279
134k
    if (in.has_schema_dict_key_list()) {
280
1.33k
        out->mutable_schema_dict_key_list()->CopyFrom(in.schema_dict_key_list());
281
1.33k
    }
282
134k
    out->set_txn_expiration(in.txn_expiration());
283
134k
    out->set_segments_overlap_pb(in.segments_overlap_pb());
284
134k
    if (in.has_segments_key_bounds_truncated()) {
285
13.2k
        out->set_segments_key_bounds_truncated(in.segments_key_bounds_truncated());
286
13.2k
    }
287
134k
    if (in.has_segments_key_bounds_aggregated()) {
288
13.2k
        out->set_segments_key_bounds_aggregated(in.segments_key_bounds_aggregated());
289
13.2k
    }
290
134k
    out->mutable_num_segment_rows()->CopyFrom(in.num_segment_rows());
291
134k
    out->mutable_segments_file_size()->CopyFrom(in.segments_file_size());
292
134k
    out->set_index_id(in.index_id());
293
134k
    if (in.has_schema_version()) {
294
        // See cloud/src/meta-service/meta_service_schema.cpp for details.
295
133k
        out->set_schema_version(in.schema_version());
296
133k
    }
297
134k
    out->set_enable_segments_file_size(in.enable_segments_file_size());
298
134k
    out->set_has_variant_type_in_schema(in.has_variant_type_in_schema());
299
134k
    out->set_enable_inverted_index_file_info(in.enable_inverted_index_file_info());
300
134k
    out->set_compaction_level(in.compaction_level());
301
134k
    out->mutable_inverted_index_file_info()->CopyFrom(in.inverted_index_file_info());
302
134k
    out->set_source_rowset_id(in.source_rowset_id());
303
134k
    out->set_source_tablet_id(in.source_tablet_id());
304
134k
    if (in.has___split_schema()) {
305
1
        out->mutable___split_schema()->CopyFrom(in.__split_schema());
306
1
    }
307
134k
    if (in.has_visible_ts_ms()) {
308
13.2k
        out->set_visible_ts_ms(in.visible_ts_ms());
309
13.2k
    }
310
134k
    if (in.has_reference_instance_id()) {
311
1
        out->set_reference_instance_id(in.reference_instance_id());
312
1
    }
313
134k
    auto* slice_locations = out->mutable_packed_slice_locations();
314
134k
    slice_locations->clear();
315
134k
    slice_locations->insert(in.packed_slice_locations().begin(), in.packed_slice_locations().end());
316
134k
    if (in.has_is_recycled()) {
317
1
        out->set_is_recycled(in.is_recycled());
318
1
    }
319
134k
    if (in.has_job_id()) {
320
13.2k
        out->set_job_id(in.job_id());
321
13.2k
    }
322
134k
    if (in.has_commit_tso()) {
323
713
        out->mutable_commit_tso()->CopyFrom(in.commit_tso());
324
713
    }
325
134k
    if (in.has_is_row_binlog()) {
326
1
        out->set_is_row_binlog(in.is_row_binlog());
327
1
    }
328
134k
    if (in.has_db_id()) {
329
13.2k
        out->set_db_id(in.db_id());
330
13.2k
    }
331
134k
    if (in.has_table_id()) {
332
13.2k
        out->set_table_id(in.table_id());
333
13.2k
    }
334
134k
}
335
336
9
void cloud_rowset_meta_to_doris(RowsetMetaPB* out, RowsetMetaCloudPB&& in) {
337
    // ATTN: please keep the set order aligned with the definition of proto `TabletSchemaCloudPB`.
338
9
    out->set_rowset_id(in.rowset_id());
339
9
    out->set_partition_id(in.partition_id());
340
9
    out->set_tablet_id(in.tablet_id());
341
9
    out->set_txn_id(in.txn_id());
342
9
    out->set_tablet_schema_hash(in.tablet_schema_hash());
343
9
    out->set_rowset_type(in.rowset_type());
344
9
    out->set_rowset_state(in.rowset_state());
345
9
    out->set_start_version(in.start_version());
346
9
    out->set_end_version(in.end_version());
347
9
    out->set_version_hash(in.version_hash());
348
9
    out->set_num_rows(in.num_rows());
349
9
    out->set_total_disk_size(in.total_disk_size());
350
9
    out->set_data_disk_size(in.data_disk_size());
351
9
    out->set_index_disk_size(in.index_disk_size());
352
9
    out->mutable_zone_maps()->Swap(in.mutable_zone_maps());
353
9
    if (in.has_delete_predicate()) {
354
2
        out->mutable_delete_predicate()->Swap(in.mutable_delete_predicate());
355
2
    }
356
9
    out->set_empty(in.empty());
357
9
    if (in.has_load_id()) {
358
2
        out->mutable_load_id()->CopyFrom(in.load_id());
359
2
    }
360
9
    out->set_delete_flag(in.delete_flag());
361
9
    out->set_creation_time(in.creation_time());
362
9
    if (in.has_tablet_uid()) {
363
2
        out->mutable_tablet_uid()->CopyFrom(in.tablet_uid());
364
2
    }
365
9
    out->set_num_segments(in.num_segments());
366
9
    out->set_rowset_id_v2(in.rowset_id_v2());
367
9
    out->set_resource_id(in.resource_id());
368
9
    out->set_newest_write_timestamp(in.newest_write_timestamp());
369
9
    out->mutable_segments_key_bounds()->Swap(in.mutable_segments_key_bounds());
370
9
    if (in.has_tablet_schema()) {
371
5
        cloud_tablet_schema_to_doris(out->mutable_tablet_schema(),
372
5
                                     std::move(*in.mutable_tablet_schema()));
373
5
    }
374
9
    if (in.has_schema_dict_key_list()) {
375
2
        out->mutable_schema_dict_key_list()->Swap(in.mutable_schema_dict_key_list());
376
2
    }
377
9
    out->set_txn_expiration(in.txn_expiration());
378
9
    out->set_segments_overlap_pb(in.segments_overlap_pb());
379
9
    if (in.has_segments_key_bounds_truncated()) {
380
5
        out->set_segments_key_bounds_truncated(in.segments_key_bounds_truncated());
381
5
    }
382
9
    if (in.has_segments_key_bounds_aggregated()) {
383
5
        out->set_segments_key_bounds_aggregated(in.segments_key_bounds_aggregated());
384
5
    }
385
9
    out->mutable_num_segment_rows()->Swap(in.mutable_num_segment_rows());
386
9
    out->mutable_segments_file_size()->Swap(in.mutable_segments_file_size());
387
9
    out->set_index_id(in.index_id());
388
9
    if (in.has_schema_version()) {
389
        // See cloud/src/meta-service/meta_service_schema.cpp for details.
390
5
        out->set_schema_version(in.schema_version());
391
5
    }
392
9
    out->set_enable_segments_file_size(in.enable_segments_file_size());
393
9
    out->set_has_variant_type_in_schema(in.has_variant_type_in_schema());
394
9
    out->set_enable_inverted_index_file_info(in.enable_inverted_index_file_info());
395
9
    out->set_compaction_level(in.compaction_level());
396
9
    out->mutable_inverted_index_file_info()->Swap(in.mutable_inverted_index_file_info());
397
9
    out->set_source_rowset_id(in.source_rowset_id());
398
9
    out->set_source_tablet_id(in.source_tablet_id());
399
9
    if (in.has___split_schema()) {
400
2
        out->mutable___split_schema()->Swap(in.mutable___split_schema());
401
2
    }
402
9
    if (in.has_visible_ts_ms()) {
403
2
        out->set_visible_ts_ms(in.visible_ts_ms());
404
2
    }
405
9
    if (in.has_reference_instance_id()) {
406
2
        out->set_reference_instance_id(in.reference_instance_id());
407
2
    }
408
9
    auto* slice_locations = out->mutable_packed_slice_locations();
409
9
    slice_locations->clear();
410
9
    slice_locations->insert(in.packed_slice_locations().begin(), in.packed_slice_locations().end());
411
9
    if (in.has_is_recycled()) {
412
2
        out->set_is_recycled(in.is_recycled());
413
2
    }
414
9
    if (in.has_job_id()) {
415
5
        out->set_job_id(in.job_id());
416
5
    }
417
9
    if (in.has_commit_tso()) {
418
2
        out->mutable_commit_tso()->CopyFrom(in.commit_tso());
419
2
    }
420
9
    if (in.has_is_row_binlog()) {
421
2
        out->set_is_row_binlog(in.is_row_binlog());
422
2
    }
423
9
    if (in.has_db_id()) {
424
5
        out->set_db_id(in.db_id());
425
5
    }
426
9
    if (in.has_table_id()) {
427
5
        out->set_table_id(in.table_id());
428
5
    }
429
9
}
430
431
0
TabletSchemaCloudPB doris_tablet_schema_to_cloud(const TabletSchemaPB& in) {
432
0
    TabletSchemaCloudPB out;
433
0
    doris_tablet_schema_to_cloud(&out, in);
434
0
    return out;
435
0
}
436
437
2
TabletSchemaCloudPB doris_tablet_schema_to_cloud(TabletSchemaPB&& in) {
438
    // ATTN: please keep the set order aligned with the definition of proto.
439
2
    TabletSchemaCloudPB out;
440
2
    doris_tablet_schema_to_cloud(&out, std::move(in));
441
2
    return out;
442
2
}
443
444
4
void doris_tablet_schema_to_cloud(TabletSchemaCloudPB* out, const TabletSchemaPB& in) {
445
    // ATTN: please keep the set order aligned with the definition of proto.
446
4
    out->set_keys_type(in.keys_type());
447
4
    out->mutable_column()->CopyFrom(in.column());
448
4
    out->set_num_short_key_columns(in.num_short_key_columns());
449
4
    out->set_num_rows_per_row_block(in.num_rows_per_row_block());
450
4
    out->set_compress_kind(in.compress_kind());
451
4
    out->set_bf_fpp(in.bf_fpp());
452
4
    out->set_next_column_unique_id(in.next_column_unique_id());
453
4
    out->set_delete_sign_idx(in.delete_sign_idx());
454
4
    out->set_sequence_col_idx(in.sequence_col_idx());
455
4
    out->set_sort_type(in.sort_type());
456
4
    out->set_sort_col_num(in.sort_col_num());
457
4
    out->set_compression_type(in.compression_type());
458
4
    out->set_schema_version(in.schema_version());
459
4
    out->set_disable_auto_compaction(in.disable_auto_compaction());
460
4
    out->mutable_index()->CopyFrom(in.index());
461
4
    out->set_version_col_idx(in.version_col_idx());
462
4
    out->set_store_row_column(in.store_row_column());
463
4
    out->set_skip_write_index_on_load(in.skip_write_index_on_load());
464
4
    out->mutable_cluster_key_uids()->CopyFrom(in.cluster_key_uids());
465
4
    out->set_is_dynamic_schema(in.is_dynamic_schema());
466
4
    out->set_is_external_segment_column_meta_used(in.is_external_segment_column_meta_used());
467
4
    out->mutable_row_store_column_unique_ids()->CopyFrom(in.row_store_column_unique_ids());
468
4
    out->set_inverted_index_storage_format(in.inverted_index_storage_format());
469
4
    out->set_enable_variant_flatten_nested(in.enable_variant_flatten_nested());
470
4
    out->set_skip_bitmap_col_idx(in.skip_bitmap_col_idx());
471
4
    out->set_storage_page_size(in.storage_page_size());
472
4
    out->set_storage_dict_page_size(in.storage_dict_page_size());
473
4
    out->set_is_in_memory(in.is_in_memory());
474
4
    out->set_row_store_page_size(in.row_store_page_size());
475
4
    if (in.has_integer_type_default_use_plain_encoding()) {
476
4
        out->set_integer_type_default_use_plain_encoding(
477
4
                in.integer_type_default_use_plain_encoding());
478
4
    }
479
4
    if (in.has_binary_plain_encoding_default_impl()) {
480
4
        out->set_binary_plain_encoding_default_impl(in.binary_plain_encoding_default_impl());
481
4
    }
482
4
    if (in.has_storage_format()) {
483
4
        out->set_storage_format(in.storage_format());
484
4
    }
485
4
    if (in.has_seq_map()) {
486
4
        out->mutable_seq_map()->CopyFrom(in.seq_map());
487
4
    }
488
4
    if (in.has_binlog_lsn_col_idx()) {
489
4
        out->set_binlog_lsn_col_idx(in.binlog_lsn_col_idx());
490
4
    }
491
4
    if (in.has_binlog_op_col_idx()) {
492
4
        out->set_binlog_op_col_idx(in.binlog_op_col_idx());
493
4
    }
494
4
    if (in.has_binlog_tso_col_idx()) {
495
4
        out->set_binlog_tso_col_idx(in.binlog_tso_col_idx());
496
4
    }
497
498
4
    if (in.has___split_schema()) {
499
4
        out->mutable___split_schema()->CopyFrom(in.__split_schema());
500
4
    }
501
4
}
502
503
192k
void doris_tablet_schema_to_cloud(TabletSchemaCloudPB* out, TabletSchemaPB&& in) {
504
192k
    out->set_keys_type(in.keys_type());
505
192k
    out->mutable_column()->Swap(in.mutable_column());
506
192k
    out->set_num_short_key_columns(in.num_short_key_columns());
507
192k
    out->set_num_rows_per_row_block(in.num_rows_per_row_block());
508
192k
    out->set_compress_kind(in.compress_kind());
509
192k
    out->set_bf_fpp(in.bf_fpp());
510
192k
    out->set_next_column_unique_id(in.next_column_unique_id());
511
192k
    out->set_delete_sign_idx(in.delete_sign_idx());
512
192k
    out->set_sequence_col_idx(in.sequence_col_idx());
513
192k
    out->set_sort_type(in.sort_type());
514
192k
    out->set_sort_col_num(in.sort_col_num());
515
192k
    out->set_compression_type(in.compression_type());
516
192k
    out->set_schema_version(in.schema_version());
517
192k
    out->set_disable_auto_compaction(in.disable_auto_compaction());
518
192k
    out->mutable_index()->Swap(in.mutable_index());
519
192k
    out->set_version_col_idx(in.version_col_idx());
520
192k
    out->set_store_row_column(in.store_row_column());
521
192k
    out->set_skip_write_index_on_load(in.skip_write_index_on_load());
522
192k
    out->mutable_cluster_key_uids()->Swap(in.mutable_cluster_key_uids());
523
192k
    out->set_is_dynamic_schema(in.is_dynamic_schema());
524
192k
    out->set_is_external_segment_column_meta_used(in.is_external_segment_column_meta_used());
525
192k
    out->mutable_row_store_column_unique_ids()->Swap(in.mutable_row_store_column_unique_ids());
526
192k
    out->set_inverted_index_storage_format(in.inverted_index_storage_format());
527
192k
    out->set_enable_variant_flatten_nested(in.enable_variant_flatten_nested());
528
192k
    out->set_skip_bitmap_col_idx(in.skip_bitmap_col_idx());
529
192k
    out->set_storage_page_size(in.storage_page_size());
530
192k
    out->set_storage_dict_page_size(in.storage_dict_page_size());
531
192k
    out->set_is_in_memory(in.is_in_memory());
532
192k
    out->set_row_store_page_size(in.row_store_page_size());
533
192k
    if (in.has_integer_type_default_use_plain_encoding()) {
534
82.7k
        out->set_integer_type_default_use_plain_encoding(
535
82.7k
                in.integer_type_default_use_plain_encoding());
536
82.7k
    }
537
192k
    if (in.has_binary_plain_encoding_default_impl()) {
538
83.0k
        out->set_binary_plain_encoding_default_impl(in.binary_plain_encoding_default_impl());
539
83.0k
    }
540
192k
    if (in.has_storage_format()) {
541
190k
        out->set_storage_format(in.storage_format());
542
190k
    }
543
192k
    if (in.has_seq_map()) {
544
188k
        out->mutable_seq_map()->CopyFrom(in.seq_map());
545
188k
    }
546
192k
    if (in.has_binlog_lsn_col_idx()) {
547
190k
        out->set_binlog_lsn_col_idx(in.binlog_lsn_col_idx());
548
190k
    }
549
192k
    if (in.has_binlog_op_col_idx()) {
550
190k
        out->set_binlog_op_col_idx(in.binlog_op_col_idx());
551
190k
    }
552
192k
    if (in.has_binlog_tso_col_idx()) {
553
191k
        out->set_binlog_tso_col_idx(in.binlog_tso_col_idx());
554
191k
    }
555
556
192k
    if (in.has___split_schema()) {
557
6
        out->mutable___split_schema()->CopyFrom(in.__split_schema());
558
6
    }
559
192k
}
560
561
0
TabletSchemaPB cloud_tablet_schema_to_doris(const TabletSchemaCloudPB& in) {
562
0
    TabletSchemaPB out;
563
0
    cloud_tablet_schema_to_doris(&out, in);
564
0
    return out;
565
0
}
566
567
2
TabletSchemaPB cloud_tablet_schema_to_doris(TabletSchemaCloudPB&& in) {
568
2
    TabletSchemaPB out;
569
2
    cloud_tablet_schema_to_doris(&out, std::move(in));
570
2
    return out;
571
2
}
572
573
133k
void cloud_tablet_schema_to_doris(TabletSchemaPB* out, const TabletSchemaCloudPB& in) {
574
    // ATTN: please keep the set order aligned with the definition of proto.
575
133k
    out->set_keys_type(in.keys_type());
576
133k
    out->mutable_column()->CopyFrom(in.column());
577
133k
    out->set_num_short_key_columns(in.num_short_key_columns());
578
133k
    out->set_num_rows_per_row_block(in.num_rows_per_row_block());
579
133k
    out->set_compress_kind(in.compress_kind());
580
133k
    out->set_bf_fpp(in.bf_fpp());
581
133k
    out->set_next_column_unique_id(in.next_column_unique_id());
582
133k
    out->set_delete_sign_idx(in.delete_sign_idx());
583
133k
    out->set_sequence_col_idx(in.sequence_col_idx());
584
133k
    out->set_sort_type(in.sort_type());
585
133k
    out->set_sort_col_num(in.sort_col_num());
586
133k
    out->set_compression_type(in.compression_type());
587
133k
    out->set_schema_version(in.schema_version());
588
133k
    out->set_disable_auto_compaction(in.disable_auto_compaction());
589
133k
    out->mutable_index()->CopyFrom(in.index());
590
133k
    out->set_version_col_idx(in.version_col_idx());
591
133k
    out->set_store_row_column(in.store_row_column());
592
133k
    out->set_skip_write_index_on_load(in.skip_write_index_on_load());
593
133k
    out->mutable_cluster_key_uids()->CopyFrom(in.cluster_key_uids());
594
133k
    out->set_is_dynamic_schema(in.is_dynamic_schema());
595
133k
    out->set_is_external_segment_column_meta_used(in.is_external_segment_column_meta_used());
596
133k
    out->mutable_row_store_column_unique_ids()->CopyFrom(in.row_store_column_unique_ids());
597
133k
    out->set_inverted_index_storage_format(in.inverted_index_storage_format());
598
133k
    out->set_enable_variant_flatten_nested(in.enable_variant_flatten_nested());
599
133k
    out->set_skip_bitmap_col_idx(in.skip_bitmap_col_idx());
600
133k
    out->set_storage_page_size(in.storage_page_size());
601
133k
    out->set_storage_dict_page_size(in.storage_dict_page_size());
602
133k
    out->set_is_in_memory(in.is_in_memory());
603
133k
    out->set_row_store_page_size(in.row_store_page_size());
604
133k
    if (in.has_integer_type_default_use_plain_encoding()) {
605
58.1k
        out->set_integer_type_default_use_plain_encoding(
606
58.1k
                in.integer_type_default_use_plain_encoding());
607
58.1k
    }
608
133k
    if (in.has_binary_plain_encoding_default_impl()) {
609
58.2k
        out->set_binary_plain_encoding_default_impl(in.binary_plain_encoding_default_impl());
610
58.2k
    }
611
133k
    if (in.has_storage_format()) {
612
133k
        out->set_storage_format(in.storage_format());
613
133k
    }
614
133k
    if (in.has_seq_map()) {
615
133k
        out->mutable_seq_map()->CopyFrom(in.seq_map());
616
133k
    }
617
133k
    if (in.has_binlog_lsn_col_idx()) {
618
285
        out->set_binlog_lsn_col_idx(in.binlog_lsn_col_idx());
619
285
    }
620
133k
    if (in.has_binlog_op_col_idx()) {
621
285
        out->set_binlog_op_col_idx(in.binlog_op_col_idx());
622
285
    }
623
133k
    if (in.has_binlog_tso_col_idx()) {
624
285
        out->set_binlog_tso_col_idx(in.binlog_tso_col_idx());
625
285
    }
626
627
133k
    if (in.has___split_schema()) {
628
4
        out->mutable___split_schema()->CopyFrom(in.__split_schema());
629
4
    }
630
133k
}
631
632
465k
void cloud_tablet_schema_to_doris(TabletSchemaPB* out, TabletSchemaCloudPB&& in) {
633
    // ATTN: please keep the set order aligned with the definition of proto.
634
465k
    out->set_keys_type(in.keys_type());
635
465k
    out->mutable_column()->Swap(in.mutable_column());
636
465k
    out->set_num_short_key_columns(in.num_short_key_columns());
637
465k
    out->set_num_rows_per_row_block(in.num_rows_per_row_block());
638
465k
    out->set_compress_kind(in.compress_kind());
639
465k
    out->set_bf_fpp(in.bf_fpp());
640
465k
    out->set_next_column_unique_id(in.next_column_unique_id());
641
465k
    out->set_delete_sign_idx(in.delete_sign_idx());
642
465k
    out->set_sequence_col_idx(in.sequence_col_idx());
643
465k
    out->set_sort_type(in.sort_type());
644
465k
    out->set_sort_col_num(in.sort_col_num());
645
465k
    out->set_compression_type(in.compression_type());
646
465k
    out->set_schema_version(in.schema_version());
647
465k
    out->set_disable_auto_compaction(in.disable_auto_compaction());
648
465k
    out->mutable_index()->Swap(in.mutable_index());
649
465k
    out->set_version_col_idx(in.version_col_idx());
650
465k
    out->set_store_row_column(in.store_row_column());
651
465k
    out->set_skip_write_index_on_load(in.skip_write_index_on_load());
652
465k
    out->mutable_cluster_key_uids()->Swap(in.mutable_cluster_key_uids());
653
465k
    out->set_is_dynamic_schema(in.is_dynamic_schema());
654
465k
    out->set_is_external_segment_column_meta_used(in.is_external_segment_column_meta_used());
655
465k
    out->mutable_row_store_column_unique_ids()->Swap(in.mutable_row_store_column_unique_ids());
656
465k
    out->set_inverted_index_storage_format(in.inverted_index_storage_format());
657
465k
    out->set_enable_variant_flatten_nested(in.enable_variant_flatten_nested());
658
465k
    out->set_skip_bitmap_col_idx(in.skip_bitmap_col_idx());
659
465k
    out->set_storage_page_size(in.storage_page_size());
660
465k
    out->set_storage_dict_page_size(in.storage_dict_page_size());
661
465k
    out->set_is_in_memory(in.is_in_memory());
662
465k
    out->set_row_store_page_size(in.row_store_page_size());
663
465k
    if (in.has_integer_type_default_use_plain_encoding()) {
664
197k
        out->set_integer_type_default_use_plain_encoding(
665
197k
                in.integer_type_default_use_plain_encoding());
666
197k
    }
667
465k
    if (in.has_binary_plain_encoding_default_impl()) {
668
197k
        out->set_binary_plain_encoding_default_impl(in.binary_plain_encoding_default_impl());
669
197k
    }
670
465k
    if (in.has_storage_format()) {
671
464k
        out->set_storage_format(in.storage_format());
672
464k
    }
673
465k
    if (in.has_seq_map()) {
674
464k
        out->mutable_seq_map()->CopyFrom(in.seq_map());
675
464k
    }
676
465k
    if (in.has_binlog_lsn_col_idx()) {
677
38
        out->set_binlog_lsn_col_idx(in.binlog_lsn_col_idx());
678
38
    }
679
465k
    if (in.has_binlog_op_col_idx()) {
680
38
        out->set_binlog_op_col_idx(in.binlog_op_col_idx());
681
38
    }
682
465k
    if (in.has_binlog_tso_col_idx()) {
683
38
        out->set_binlog_tso_col_idx(in.binlog_tso_col_idx());
684
38
    }
685
686
465k
    if (in.has___split_schema()) {
687
6
        out->mutable___split_schema()->CopyFrom(in.__split_schema());
688
6
    }
689
465k
}
690
691
0
TabletMetaCloudPB doris_tablet_meta_to_cloud(const TabletMetaPB& in) {
692
0
    TabletMetaCloudPB out;
693
0
    doris_tablet_meta_to_cloud(&out, in);
694
0
    return out;
695
0
}
696
697
1
TabletMetaCloudPB doris_tablet_meta_to_cloud(TabletMetaPB&& in) {
698
1
    TabletMetaCloudPB out;
699
1
    doris_tablet_meta_to_cloud(&out, std::move(in));
700
1
    return out;
701
1
}
702
703
1
void doris_tablet_meta_to_cloud(TabletMetaCloudPB* out, const TabletMetaPB& in) {
704
    // ATTN: please keep the set order aligned with the definition of proto.
705
1
    out->set_table_id(in.table_id());
706
1
    out->set_partition_id(in.partition_id());
707
1
    out->set_tablet_id(in.tablet_id());
708
1
    out->set_schema_hash(in.schema_hash());
709
1
    out->set_shard_id(in.shard_id());
710
1
    out->set_creation_time(in.creation_time());
711
1
    out->set_cumulative_layer_point(in.cumulative_layer_point());
712
1
    out->set_tablet_state(in.tablet_state());
713
1
    if (in.has_schema()) {
714
1
        doris_tablet_schema_to_cloud(out->mutable_schema(), in.schema());
715
1
    }
716
1
    if (in.rs_metas_size()) {
717
1
        out->mutable_rs_metas()->Reserve(in.rs_metas_size());
718
1
        for (const auto& rs_meta : in.rs_metas()) {
719
1
            doris_rowset_meta_to_cloud(out->add_rs_metas(), rs_meta);
720
1
        }
721
1
    }
722
    // ATTN: inc_rs_metas are deprecated, here is for conversion check
723
1
    if (in.inc_rs_metas_size()) {
724
1
        out->mutable_inc_rs_metas()->Reserve(in.inc_rs_metas_size());
725
1
        for (const auto& rs_meta : in.inc_rs_metas()) {
726
1
            doris_rowset_meta_to_cloud(out->add_inc_rs_metas(), rs_meta);
727
1
        }
728
1
    }
729
1
    if (in.has_alter_task()) {
730
1
        out->mutable_alter_task()->CopyFrom(in.alter_task());
731
1
    }
732
1
    out->set_in_restore_mode(in.in_restore_mode());
733
1
    out->mutable_tablet_uid()->CopyFrom(in.tablet_uid());
734
1
    out->set_end_rowset_id(in.end_rowset_id());
735
1
    out->set_preferred_rowset_type(in.preferred_rowset_type());
736
1
    out->set_tablet_type(in.tablet_type());
737
1
    if (in.stale_rs_metas_size()) {
738
1
        out->mutable_stale_rs_metas()->Reserve(in.stale_rs_metas_size());
739
1
        for (const auto& rs_meta : in.stale_rs_metas()) {
740
1
            doris_rowset_meta_to_cloud(out->add_stale_rs_metas(), rs_meta);
741
1
        }
742
1
    }
743
1
    out->set_replica_id(in.replica_id());
744
1
    if (in.has_delete_bitmap()) {
745
1
        out->mutable_delete_bitmap()->CopyFrom(in.delete_bitmap());
746
1
    }
747
1
    out->set_enable_unique_key_merge_on_write(in.enable_unique_key_merge_on_write());
748
1
    out->set_storage_policy_id(in.storage_policy_id());
749
1
    out->mutable_cooldown_meta_id()->CopyFrom(in.cooldown_meta_id());
750
1
    if (in.has_binlog_config()) {
751
1
        out->mutable_binlog_config()->CopyFrom(in.binlog_config());
752
1
    }
753
1
    if (in.has_row_binlog_schema()) {
754
1
        doris_tablet_schema_to_cloud(out->mutable_row_binlog_schema(), in.row_binlog_schema());
755
1
    }
756
1
    if (in.row_binlog_rs_metas_size()) {
757
1
        out->mutable_row_binlog_rs_metas()->Reserve(in.row_binlog_rs_metas_size());
758
1
        for (const auto& rs_meta : in.row_binlog_rs_metas()) {
759
1
            doris_rowset_meta_to_cloud(out->add_row_binlog_rs_metas(), rs_meta);
760
1
        }
761
1
    }
762
1
    if (in.has_row_binlog_schema_hash()) {
763
1
        out->set_row_binlog_schema_hash(in.row_binlog_schema_hash());
764
1
    }
765
1
    out->set_compaction_policy(in.compaction_policy());
766
1
    out->set_time_series_compaction_goal_size_mbytes(in.time_series_compaction_goal_size_mbytes());
767
1
    out->set_time_series_compaction_file_count_threshold(
768
1
            in.time_series_compaction_file_count_threshold());
769
1
    out->set_time_series_compaction_time_threshold_seconds(
770
1
            in.time_series_compaction_time_threshold_seconds());
771
1
    out->set_time_series_compaction_empty_rowsets_threshold(
772
1
            in.time_series_compaction_empty_rowsets_threshold());
773
1
    out->set_time_series_compaction_level_threshold(in.time_series_compaction_level_threshold());
774
1
    out->set_vertical_compaction_num_columns_per_group(
775
1
            in.vertical_compaction_num_columns_per_group());
776
1
    out->set_index_id(in.index_id());
777
1
    out->set_is_in_memory(in.is_in_memory());
778
1
    out->set_is_persistent(in.is_persistent());
779
1
    out->set_table_name(in.table_name());
780
1
    out->set_ttl_seconds(in.ttl_seconds());
781
1
    if (in.has_schema_version()) {
782
1
        out->set_schema_version(in.schema_version());
783
1
    }
784
1
    if (in.has_encryption_algorithm()) {
785
1
        out->set_encryption_algorithm(in.encryption_algorithm());
786
1
    }
787
1
}
788
789
1
void doris_tablet_meta_to_cloud(TabletMetaCloudPB* out, TabletMetaPB&& in) {
790
    // ATTN: please keep the set order aligned with the definition of proto.
791
1
    out->set_table_id(in.table_id());
792
1
    out->set_partition_id(in.partition_id());
793
1
    out->set_tablet_id(in.tablet_id());
794
1
    out->set_schema_hash(in.schema_hash());
795
1
    out->set_shard_id(in.shard_id());
796
1
    out->set_creation_time(in.creation_time());
797
1
    out->set_cumulative_layer_point(in.cumulative_layer_point());
798
1
    out->set_tablet_state(in.tablet_state());
799
1
    if (in.has_schema()) {
800
1
        doris_tablet_schema_to_cloud(out->mutable_schema(), std::move(*in.mutable_schema()));
801
1
    }
802
1
    if (in.rs_metas_size()) {
803
1
        int32_t rs_metas_size = in.rs_metas_size();
804
1
        out->mutable_rs_metas()->Reserve(rs_metas_size);
805
2
        for (int i = 0; i < rs_metas_size; ++i) {
806
1
            doris_rowset_meta_to_cloud(out->add_rs_metas(), std::move(*in.mutable_rs_metas(i)));
807
1
        }
808
1
    }
809
    // ATTN: inc_rs_metas are deprecated, here is for conversion check
810
1
    if (in.inc_rs_metas_size()) {
811
1
        int rs_metas_size = in.inc_rs_metas_size();
812
1
        out->mutable_inc_rs_metas()->Reserve(rs_metas_size);
813
2
        for (int i = 0; i < rs_metas_size; ++i) {
814
1
            doris_rowset_meta_to_cloud(out->add_inc_rs_metas(),
815
1
                                       std::move(*in.mutable_inc_rs_metas(i)));
816
1
        }
817
1
    }
818
1
    if (in.has_alter_task()) {
819
1
        out->mutable_alter_task()->Swap(in.mutable_alter_task());
820
1
    }
821
1
    out->set_in_restore_mode(in.in_restore_mode());
822
1
    out->mutable_tablet_uid()->CopyFrom(in.tablet_uid());
823
1
    out->set_end_rowset_id(in.end_rowset_id());
824
1
    out->set_preferred_rowset_type(in.preferred_rowset_type());
825
1
    out->set_tablet_type(in.tablet_type());
826
1
    if (in.stale_rs_metas_size()) {
827
1
        int rs_metas_size = in.stale_rs_metas_size();
828
1
        out->mutable_stale_rs_metas()->Reserve(rs_metas_size);
829
2
        for (int i = 0; i < rs_metas_size; i++) {
830
1
            doris_rowset_meta_to_cloud(out->add_stale_rs_metas(),
831
1
                                       std::move(*in.mutable_stale_rs_metas(i)));
832
1
        }
833
1
    }
834
1
    out->set_replica_id(in.replica_id());
835
1
    if (in.has_delete_bitmap()) {
836
1
        out->mutable_delete_bitmap()->Swap(in.mutable_delete_bitmap());
837
1
    }
838
1
    out->set_enable_unique_key_merge_on_write(in.enable_unique_key_merge_on_write());
839
1
    out->set_storage_policy_id(in.storage_policy_id());
840
1
    out->mutable_cooldown_meta_id()->CopyFrom(in.cooldown_meta_id());
841
1
    if (in.has_binlog_config()) {
842
1
        out->mutable_binlog_config()->Swap(in.mutable_binlog_config());
843
1
    }
844
1
    if (in.has_row_binlog_schema()) {
845
1
        doris_tablet_schema_to_cloud(out->mutable_row_binlog_schema(),
846
1
                                     std::move(*in.mutable_row_binlog_schema()));
847
1
    }
848
1
    if (in.row_binlog_rs_metas_size()) {
849
1
        int row_binlog_rs_metas_size = in.row_binlog_rs_metas_size();
850
1
        out->mutable_row_binlog_rs_metas()->Reserve(row_binlog_rs_metas_size);
851
2
        for (int i = 0; i < row_binlog_rs_metas_size; ++i) {
852
1
            doris_rowset_meta_to_cloud(out->add_row_binlog_rs_metas(),
853
1
                                       std::move(*in.mutable_row_binlog_rs_metas(i)));
854
1
        }
855
1
    }
856
1
    if (in.has_row_binlog_schema_hash()) {
857
1
        out->set_row_binlog_schema_hash(in.row_binlog_schema_hash());
858
1
    }
859
1
    out->set_compaction_policy(in.compaction_policy());
860
1
    out->set_time_series_compaction_goal_size_mbytes(in.time_series_compaction_goal_size_mbytes());
861
1
    out->set_time_series_compaction_file_count_threshold(
862
1
            in.time_series_compaction_file_count_threshold());
863
1
    out->set_time_series_compaction_time_threshold_seconds(
864
1
            in.time_series_compaction_time_threshold_seconds());
865
1
    out->set_time_series_compaction_empty_rowsets_threshold(
866
1
            in.time_series_compaction_empty_rowsets_threshold());
867
1
    out->set_time_series_compaction_level_threshold(in.time_series_compaction_level_threshold());
868
1
    out->set_vertical_compaction_num_columns_per_group(
869
1
            in.vertical_compaction_num_columns_per_group());
870
1
    out->set_index_id(in.index_id());
871
1
    out->set_is_in_memory(in.is_in_memory());
872
1
    out->set_is_persistent(in.is_persistent());
873
1
    out->set_table_name(in.table_name());
874
1
    out->set_ttl_seconds(in.ttl_seconds());
875
1
    if (in.has_schema_version()) {
876
1
        out->set_schema_version(in.schema_version());
877
1
    }
878
1
    if (in.has_encryption_algorithm()) {
879
1
        out->set_encryption_algorithm(in.encryption_algorithm());
880
1
    }
881
1
}
882
883
0
TabletMetaPB cloud_tablet_meta_to_doris(const TabletMetaCloudPB& in) {
884
0
    TabletMetaPB out;
885
0
    cloud_tablet_meta_to_doris(&out, in);
886
0
    return out;
887
0
}
888
889
465k
TabletMetaPB cloud_tablet_meta_to_doris(TabletMetaCloudPB&& in) {
890
465k
    TabletMetaPB out;
891
465k
    cloud_tablet_meta_to_doris(&out, std::move(in));
892
465k
    return out;
893
465k
}
894
895
1
void cloud_tablet_meta_to_doris(TabletMetaPB* out, const TabletMetaCloudPB& in) {
896
    // ATTN: please keep the set order aligned with the definition of proto.
897
1
    out->set_table_id(in.table_id());
898
1
    out->set_partition_id(in.partition_id());
899
1
    out->set_tablet_id(in.tablet_id());
900
1
    out->set_schema_hash(in.schema_hash());
901
1
    out->set_shard_id(in.shard_id());
902
1
    out->set_creation_time(in.creation_time());
903
1
    out->set_cumulative_layer_point(in.cumulative_layer_point());
904
1
    out->set_tablet_state(in.tablet_state());
905
1
    if (in.has_schema()) {
906
1
        cloud_tablet_schema_to_doris(out->mutable_schema(), in.schema());
907
1
    }
908
1
    if (in.rs_metas_size()) {
909
1
        out->mutable_rs_metas()->Reserve(in.rs_metas_size());
910
1
        for (const auto& rs_meta : in.rs_metas()) {
911
1
            cloud_rowset_meta_to_doris(out->add_rs_metas(), rs_meta);
912
1
        }
913
1
    }
914
    // ATTN: inc_rs_metas are deprecated, here is for conversion check
915
1
    if (in.inc_rs_metas_size()) {
916
1
        out->mutable_inc_rs_metas()->Reserve(in.inc_rs_metas_size());
917
1
        for (const auto& rs_meta : in.inc_rs_metas()) {
918
1
            cloud_rowset_meta_to_doris(out->add_inc_rs_metas(), rs_meta);
919
1
        }
920
1
    }
921
1
    if (in.has_alter_task()) {
922
1
        out->mutable_alter_task()->CopyFrom(in.alter_task());
923
1
    }
924
1
    out->set_in_restore_mode(in.in_restore_mode());
925
1
    out->mutable_tablet_uid()->CopyFrom(in.tablet_uid());
926
1
    out->set_end_rowset_id(in.end_rowset_id());
927
1
    out->set_preferred_rowset_type(in.preferred_rowset_type());
928
1
    out->set_tablet_type(in.tablet_type());
929
1
    if (in.stale_rs_metas_size()) {
930
1
        out->mutable_stale_rs_metas()->Reserve(in.stale_rs_metas_size());
931
1
        for (const auto& rs_meta : in.stale_rs_metas()) {
932
1
            cloud_rowset_meta_to_doris(out->add_stale_rs_metas(), rs_meta);
933
1
        }
934
1
    }
935
1
    out->set_replica_id(in.replica_id());
936
1
    if (in.has_delete_bitmap()) {
937
1
        out->mutable_delete_bitmap()->CopyFrom(in.delete_bitmap());
938
1
    }
939
1
    out->set_enable_unique_key_merge_on_write(in.enable_unique_key_merge_on_write());
940
1
    out->set_storage_policy_id(in.storage_policy_id());
941
1
    out->mutable_cooldown_meta_id()->CopyFrom(in.cooldown_meta_id());
942
1
    if (in.has_binlog_config()) {
943
1
        out->mutable_binlog_config()->CopyFrom(in.binlog_config());
944
1
    }
945
1
    if (in.has_row_binlog_schema()) {
946
1
        cloud_tablet_schema_to_doris(out->mutable_row_binlog_schema(), in.row_binlog_schema());
947
1
    }
948
1
    if (in.row_binlog_rs_metas_size()) {
949
1
        out->mutable_row_binlog_rs_metas()->Reserve(in.row_binlog_rs_metas_size());
950
1
        for (const auto& rs_meta : in.row_binlog_rs_metas()) {
951
1
            cloud_rowset_meta_to_doris(out->add_row_binlog_rs_metas(), rs_meta);
952
1
        }
953
1
    }
954
1
    if (in.has_row_binlog_schema_hash()) {
955
1
        out->set_row_binlog_schema_hash(in.row_binlog_schema_hash());
956
1
    }
957
1
    out->set_compaction_policy(in.compaction_policy());
958
1
    out->set_time_series_compaction_goal_size_mbytes(in.time_series_compaction_goal_size_mbytes());
959
1
    out->set_time_series_compaction_file_count_threshold(
960
1
            in.time_series_compaction_file_count_threshold());
961
1
    out->set_time_series_compaction_time_threshold_seconds(
962
1
            in.time_series_compaction_time_threshold_seconds());
963
1
    out->set_time_series_compaction_empty_rowsets_threshold(
964
1
            in.time_series_compaction_empty_rowsets_threshold());
965
1
    out->set_time_series_compaction_level_threshold(in.time_series_compaction_level_threshold());
966
1
    out->set_vertical_compaction_num_columns_per_group(
967
1
            in.vertical_compaction_num_columns_per_group());
968
1
    out->set_index_id(in.index_id());
969
1
    out->set_is_in_memory(in.is_in_memory());
970
1
    out->set_is_persistent(in.is_persistent());
971
1
    out->set_table_name(in.table_name());
972
1
    out->set_ttl_seconds(in.ttl_seconds());
973
1
    if (in.has_schema_version()) {
974
1
        out->set_schema_version(in.schema_version());
975
1
    }
976
1
    if (in.has_encryption_algorithm()) {
977
1
        out->set_encryption_algorithm(in.encryption_algorithm());
978
1
    }
979
1
}
980
981
465k
void cloud_tablet_meta_to_doris(TabletMetaPB* out, TabletMetaCloudPB&& in) {
982
    // ATTN: please keep the set order aligned with the definition of proto.
983
465k
    out->set_table_id(in.table_id());
984
465k
    out->set_partition_id(in.partition_id());
985
465k
    out->set_tablet_id(in.tablet_id());
986
465k
    out->set_schema_hash(in.schema_hash());
987
465k
    out->set_shard_id(in.shard_id());
988
465k
    out->set_creation_time(in.creation_time());
989
465k
    out->set_cumulative_layer_point(in.cumulative_layer_point());
990
465k
    out->set_tablet_state(in.tablet_state());
991
465k
    if (in.has_schema()) {
992
464k
        cloud_tablet_schema_to_doris(out->mutable_schema(), std::move(*in.mutable_schema()));
993
464k
    }
994
465k
    if (in.rs_metas_size()) {
995
1
        int rs_metas_size = in.rs_metas_size();
996
1
        out->mutable_rs_metas()->Reserve(rs_metas_size);
997
2
        for (int i = 0; i < rs_metas_size; ++i) {
998
1
            cloud_rowset_meta_to_doris(out->add_rs_metas(), std::move(*in.mutable_rs_metas(i)));
999
1
        }
1000
1
    }
1001
    // ATTN: inc_rs_metas are deprecated, here is for conversion check
1002
465k
    if (in.inc_rs_metas_size()) {
1003
1
        int rs_metas_size = in.inc_rs_metas_size();
1004
1
        out->mutable_inc_rs_metas()->Reserve(rs_metas_size);
1005
2
        for (int i = 0; i < rs_metas_size; i++) {
1006
1
            cloud_rowset_meta_to_doris(out->add_inc_rs_metas(),
1007
1
                                       std::move(*in.mutable_inc_rs_metas(i)));
1008
1
        }
1009
1
    }
1010
465k
    if (in.has_alter_task()) {
1011
1
        out->mutable_alter_task()->Swap(in.mutable_alter_task());
1012
1
    }
1013
465k
    out->set_in_restore_mode(in.in_restore_mode());
1014
465k
    out->mutable_tablet_uid()->CopyFrom(in.tablet_uid());
1015
465k
    out->set_end_rowset_id(in.end_rowset_id());
1016
465k
    out->set_preferred_rowset_type(in.preferred_rowset_type());
1017
465k
    out->set_tablet_type(in.tablet_type());
1018
465k
    if (in.stale_rs_metas_size()) {
1019
1
        int rs_metas_size = in.stale_rs_metas_size();
1020
1
        out->mutable_stale_rs_metas()->Reserve(rs_metas_size);
1021
2
        for (int i = 0; i < rs_metas_size; i++) {
1022
1
            cloud_rowset_meta_to_doris(out->add_stale_rs_metas(),
1023
1
                                       std::move(*in.mutable_stale_rs_metas(i)));
1024
1
        }
1025
1
    }
1026
465k
    out->set_replica_id(in.replica_id());
1027
465k
    if (in.has_delete_bitmap()) {
1028
1
        out->mutable_delete_bitmap()->Swap(in.mutable_delete_bitmap());
1029
1
    }
1030
465k
    out->set_enable_unique_key_merge_on_write(in.enable_unique_key_merge_on_write());
1031
465k
    out->set_storage_policy_id(in.storage_policy_id());
1032
465k
    out->mutable_cooldown_meta_id()->CopyFrom(in.cooldown_meta_id());
1033
465k
    if (in.has_binlog_config()) {
1034
1
        out->mutable_binlog_config()->Swap(in.mutable_binlog_config());
1035
1
    }
1036
465k
    if (in.has_row_binlog_schema()) {
1037
1
        cloud_tablet_schema_to_doris(out->mutable_row_binlog_schema(),
1038
1
                                     std::move(*in.mutable_row_binlog_schema()));
1039
1
    }
1040
465k
    if (in.row_binlog_rs_metas_size()) {
1041
1
        int row_binlog_rs_metas_size = in.row_binlog_rs_metas_size();
1042
1
        out->mutable_row_binlog_rs_metas()->Reserve(row_binlog_rs_metas_size);
1043
2
        for (int i = 0; i < row_binlog_rs_metas_size; ++i) {
1044
1
            cloud_rowset_meta_to_doris(out->add_row_binlog_rs_metas(),
1045
1
                                       std::move(*in.mutable_row_binlog_rs_metas(i)));
1046
1
        }
1047
1
    }
1048
465k
    if (in.has_row_binlog_schema_hash()) {
1049
1
        out->set_row_binlog_schema_hash(in.row_binlog_schema_hash());
1050
1
    }
1051
465k
    out->set_compaction_policy(in.compaction_policy());
1052
465k
    out->set_time_series_compaction_goal_size_mbytes(in.time_series_compaction_goal_size_mbytes());
1053
465k
    out->set_time_series_compaction_file_count_threshold(
1054
465k
            in.time_series_compaction_file_count_threshold());
1055
465k
    out->set_time_series_compaction_time_threshold_seconds(
1056
465k
            in.time_series_compaction_time_threshold_seconds());
1057
465k
    out->set_time_series_compaction_empty_rowsets_threshold(
1058
465k
            in.time_series_compaction_empty_rowsets_threshold());
1059
465k
    out->set_time_series_compaction_level_threshold(in.time_series_compaction_level_threshold());
1060
465k
    out->set_vertical_compaction_num_columns_per_group(
1061
465k
            in.vertical_compaction_num_columns_per_group());
1062
465k
    out->set_index_id(in.index_id());
1063
465k
    out->set_is_in_memory(in.is_in_memory());
1064
465k
    out->set_is_persistent(in.is_persistent());
1065
465k
    out->set_table_name(in.table_name());
1066
465k
    out->set_ttl_seconds(in.ttl_seconds());
1067
465k
    if (in.has_schema_version()) {
1068
465k
        out->set_schema_version(in.schema_version());
1069
465k
    }
1070
465k
    if (in.has_encryption_algorithm()) {
1071
465k
        out->set_encryption_algorithm(in.encryption_algorithm());
1072
465k
    }
1073
465k
}
1074
1075
} // namespace doris::cloud