Fix repeated message serialization in cpp yunq.
This commit is contained in:
parent
c4dfa624fa
commit
00f2424987
|
@ -3,7 +3,7 @@
|
|||
namespace yunq {
|
||||
namespace {
|
||||
|
||||
const uint64_t kIdentByte = 0x33441122;
|
||||
const uint32_t kIdentByte = 0x33441122;
|
||||
|
||||
} // namespace
|
||||
|
||||
|
|
|
@ -100,7 +100,7 @@ template <typename T>
|
|||
void Serializer::WriteRepeatedMessage(uint64_t field_index,
|
||||
const glcr::Vector<T>& value) {
|
||||
uint64_t next_offset = next_extension_;
|
||||
uint64_t length = 0;
|
||||
uint64_t length = value.size();
|
||||
|
||||
for (T& message : value) {
|
||||
uint64_t msg_length = 0;
|
||||
|
@ -110,7 +110,6 @@ void Serializer::WriteRepeatedMessage(uint64_t field_index,
|
|||
} else {
|
||||
msg_length = message.SerializeToBytes(buffer_, offset_ + next_offset);
|
||||
}
|
||||
length += msg_length;
|
||||
next_offset += msg_length;
|
||||
}
|
||||
|
||||
|
@ -119,7 +118,7 @@ void Serializer::WriteRepeatedMessage(uint64_t field_index,
|
|||
.length = (uint32_t)length,
|
||||
};
|
||||
|
||||
next_extension_ += length;
|
||||
next_extension_ = next_offset;
|
||||
|
||||
buffer_.WriteAt<ExtensionPointer>(field_offset(field_index), ptr);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue