1
0
Fork 0
mirror of https://github.com/ton-blockchain/ton synced 2025-02-13 19:52:18 +00:00
ton/tdutils/td/utils/tl_parsers.cpp

72 lines
2.3 KiB
C++
Raw Normal View History

2019-09-07 10:03:22 +00:00
/*
This file is part of TON Blockchain Library.
TON Blockchain Library is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 2 of the License, or
(at your option) any later version.
TON Blockchain Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with TON Blockchain Library. If not, see <http://www.gnu.org/licenses/>.
2020-04-10 19:06:01 +00:00
Copyright 2017-2020 Telegram Systems LLP
2019-09-07 10:03:22 +00:00
*/
#include "td/utils/tl_parsers.h"
2020-07-06 14:07:20 +00:00
#include "td/utils/misc.h"
2019-09-07 10:03:22 +00:00
namespace td {
alignas(4) const unsigned char TlParser::empty_data[sizeof(UInt256)] = {}; // static zero-initialized
2020-07-06 14:07:20 +00:00
TlParser::TlParser(Slice slice) {
data_len = left_len = slice.size();
if (is_aligned_pointer<4>(slice.begin())) {
data = slice.ubegin();
} else {
int32 *buf;
if (data_len <= small_data_array.size() * sizeof(int32)) {
buf = &small_data_array[0];
} else {
LOG(ERROR) << "Unexpected big unaligned data pointer of length " << slice.size() << " at " << slice.begin();
data_buf = std::make_unique<int32[]>(1 + data_len / sizeof(int32));
buf = data_buf.get();
}
std::memcpy(buf, slice.begin(), slice.size());
data = reinterpret_cast<unsigned char *>(buf);
}
}
2019-09-07 10:03:22 +00:00
void TlParser::set_error(const string &error_message) {
if (error.empty()) {
CHECK(!error_message.empty());
error = error_message;
error_pos = data_len - left_len;
data = empty_data;
left_len = 0;
data_len = 0;
} else {
2020-07-06 14:07:20 +00:00
LOG_CHECK(error_pos != std::numeric_limits<size_t>::max() && data_len == 0 && left_len == 0)
<< data_len << " " << left_len << " " << data << " " << &empty_data[0] << " " << error_pos << " " << error
<< " " << data << " " << &empty_data;
2019-09-07 10:03:22 +00:00
data = empty_data;
}
}
2020-07-06 14:07:20 +00:00
BufferSlice TlBufferParser::as_buffer_slice(Slice slice) {
if (slice.empty()) {
return BufferSlice();
}
if (is_aligned_pointer<4>(slice.data())) {
return parent_->from_slice(slice);
}
return BufferSlice(slice);
}
2019-09-07 10:03:22 +00:00
} // namespace td