mirror of
https://github.com/tiennm99/zfoo.git
synced 2026-05-24 19:35:29 +00:00
ref[cpp]: rename writeBoolean/readBoolean/writeOffset/readOffset to writeBool/readBool/getWriteOffset/getReadOffset
This commit is contained in:
@@ -298,7 +298,7 @@ public class CodeGenerateCpp implements ICodeGenerate {
|
||||
var fieldRegistrations = registration.getFieldRegistrations();
|
||||
var cppBuilder = new StringBuilder();
|
||||
if (registration.isCompatible()) {
|
||||
cppBuilder.append("auto beforeWriteIndex = buffer.writerIndex();").append(LS);
|
||||
cppBuilder.append("auto beforeWriteIndex = buffer.getWriterOffset();").append(LS);
|
||||
cppBuilder.append(StringUtils.format("buffer.writeInt({});", registration.getPredictionLength())).append(LS);
|
||||
} else {
|
||||
cppBuilder.append("buffer.writeInt(-1);").append(LS);
|
||||
|
||||
@@ -11,7 +11,6 @@
|
||||
|
||||
// 网络传输默认使用大端传输
|
||||
namespace zfoo {
|
||||
|
||||
using std::string;
|
||||
using std::vector;
|
||||
using std::list;
|
||||
@@ -58,8 +57,8 @@ namespace zfoo {
|
||||
private:
|
||||
int8_t *m_buffer;
|
||||
int32_t m_max_capacity;
|
||||
int32_t m_writerIndex;
|
||||
int32_t m_readerIndex;
|
||||
int32_t m_writerOffset;
|
||||
int32_t m_readerOffset;
|
||||
|
||||
public:
|
||||
ByteBuffer(int32_t capacity = DEFAULT_BUFFER_SIZE) : m_max_capacity(capacity) {
|
||||
@@ -78,19 +77,19 @@ namespace zfoo {
|
||||
ByteBuffer &operator=(const ByteBuffer &buffer) = delete;
|
||||
|
||||
void adjustPadding(int32_t predictionLength, int32_t beforeWriteIndex) {
|
||||
int32_t currentWriteIndex = writerIndex();
|
||||
int32_t currentWriteIndex = getWriterOffset();
|
||||
int32_t predictionCount = writeIntCount(predictionLength);
|
||||
int32_t length = currentWriteIndex - beforeWriteIndex - predictionCount;
|
||||
int32_t lengthCount = writeIntCount(length);
|
||||
int32_t padding = lengthCount - predictionCount;
|
||||
if (padding == 0) {
|
||||
writerIndex(beforeWriteIndex);
|
||||
setWriterOffset(beforeWriteIndex);
|
||||
writeInt(length);
|
||||
writerIndex(currentWriteIndex);
|
||||
setWriterOffset(currentWriteIndex);
|
||||
} else {
|
||||
int8_t *targetPtr = (int8_t *) calloc(length, sizeof(int8_t));
|
||||
memcpy(targetPtr, &m_buffer[currentWriteIndex - length], length);
|
||||
writerIndex(beforeWriteIndex);
|
||||
memcpy(targetPtr, &m_buffer[currentWriteIndex - length], length);
|
||||
setWriterOffset(beforeWriteIndex);
|
||||
writeInt(length);
|
||||
writeBytes(targetPtr, length);
|
||||
free(targetPtr);
|
||||
@@ -98,48 +97,52 @@ namespace zfoo {
|
||||
}
|
||||
|
||||
bool compatibleRead(int32_t beforeReadIndex, int32_t length) {
|
||||
return length != -1 && readerIndex() < length + beforeReadIndex;
|
||||
return length != -1 && getReaderOffset() < length + beforeReadIndex;
|
||||
}
|
||||
|
||||
void clear() {
|
||||
m_writerIndex = 0;
|
||||
m_readerIndex = 0;
|
||||
m_writerOffset = 0;
|
||||
m_readerOffset = 0;
|
||||
}
|
||||
|
||||
int32_t writerIndex() const {
|
||||
return m_writerIndex;
|
||||
int8_t *getBuffer() {
|
||||
return m_buffer;
|
||||
}
|
||||
|
||||
int32_t readerIndex() const {
|
||||
return m_readerIndex;
|
||||
int32_t getWriterOffset() const {
|
||||
return m_writerOffset;
|
||||
}
|
||||
|
||||
void writerIndex(int32_t writeIndex) {
|
||||
int32_t getReaderOffset() const {
|
||||
return m_readerOffset;
|
||||
}
|
||||
|
||||
void setWriterOffset(int32_t writeIndex) {
|
||||
if (writeIndex > m_max_capacity) {
|
||||
string errorMessage =
|
||||
"writeIndex[" + std::to_string(writeIndex) + "] out of bounds exception: readerIndex: " +
|
||||
std::to_string(m_readerIndex) +
|
||||
", writerIndex: " + std::to_string(m_writerIndex) +
|
||||
std::to_string(m_readerOffset) +
|
||||
", writerIndex: " + std::to_string(m_writerOffset) +
|
||||
"(expected: 0 <= readerIndex <= writerIndex <= capacity:" + std::to_string(m_max_capacity);
|
||||
throw errorMessage;
|
||||
}
|
||||
m_writerIndex = writeIndex;
|
||||
m_writerOffset = writeIndex;
|
||||
}
|
||||
|
||||
void readerIndex(int32_t readerIndex) {
|
||||
if (readerIndex > m_writerIndex) {
|
||||
void setReaderOffset(int32_t readerIndex) {
|
||||
if (readerIndex > m_writerOffset) {
|
||||
string errorMessage =
|
||||
"readIndex[" + std::to_string(readerIndex) + "] out of bounds exception: readerIndex: " +
|
||||
std::to_string(m_readerIndex) +
|
||||
", writerIndex: " + std::to_string(m_writerIndex) +
|
||||
std::to_string(m_readerOffset) +
|
||||
", writerIndex: " + std::to_string(m_writerOffset) +
|
||||
"(expected: 0 <= readerIndex <= writerIndex <= capacity:" + std::to_string(m_max_capacity);
|
||||
throw errorMessage;
|
||||
}
|
||||
m_readerIndex = readerIndex;
|
||||
m_readerOffset = readerIndex;
|
||||
}
|
||||
|
||||
inline int32_t getCapacity() const {
|
||||
return m_max_capacity - m_writerIndex;
|
||||
return m_max_capacity - m_writerOffset;
|
||||
}
|
||||
|
||||
inline void ensureCapacity(const int32_t &capacity) {
|
||||
@@ -156,27 +159,27 @@ namespace zfoo {
|
||||
}
|
||||
|
||||
inline bool isReadable() {
|
||||
return m_writerIndex > m_readerIndex;
|
||||
return m_writerOffset > m_readerOffset;
|
||||
}
|
||||
|
||||
inline void writeBool(const bool &value) {
|
||||
ensureCapacity(1);
|
||||
int8_t v = value ? 1 : 0;
|
||||
m_buffer[m_writerIndex++] = v;
|
||||
m_buffer[m_writerOffset++] = v;
|
||||
}
|
||||
|
||||
inline bool readBool() {
|
||||
int8_t value = m_buffer[m_readerIndex++];
|
||||
int8_t value = m_buffer[m_readerOffset++];
|
||||
return value == 1;
|
||||
}
|
||||
|
||||
inline void writeByte(const int8_t &value) {
|
||||
ensureCapacity(1);
|
||||
m_buffer[m_writerIndex++] = value;
|
||||
m_buffer[m_writerOffset++] = value;
|
||||
}
|
||||
|
||||
inline int8_t readByte() {
|
||||
return m_buffer[m_readerIndex++];
|
||||
return m_buffer[m_readerOffset++];
|
||||
}
|
||||
|
||||
inline void setByte(const int32_t &index, const int8_t &value) {
|
||||
@@ -189,13 +192,13 @@ namespace zfoo {
|
||||
|
||||
inline void writeBytes(const int8_t *buffer, const int32_t &length) {
|
||||
ensureCapacity(length);
|
||||
memcpy(&m_buffer[m_writerIndex], buffer, length);
|
||||
m_writerIndex += length;
|
||||
memcpy(&m_buffer[m_writerOffset], buffer, length);
|
||||
m_writerOffset += length;
|
||||
}
|
||||
|
||||
inline int8_t *readBytes(const int32_t &length) {
|
||||
int8_t *bytes = &m_buffer[m_readerIndex];
|
||||
m_readerIndex += length;
|
||||
int8_t *bytes = &m_buffer[m_readerOffset];
|
||||
m_readerOffset += length;
|
||||
return bytes;
|
||||
}
|
||||
|
||||
@@ -219,14 +222,14 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
|
||||
int32_t writeIndex = m_writerIndex;
|
||||
int32_t writeIndex = m_writerOffset;
|
||||
ensureCapacity(5);
|
||||
|
||||
setByte(writeIndex++, (int8_t) (value | 0x80));
|
||||
uint32_t b = value >> 14;
|
||||
if (b == 0) {
|
||||
setByte(writeIndex++, (int8_t) a);
|
||||
writerIndex(writeIndex);
|
||||
setWriterOffset(writeIndex);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -234,7 +237,7 @@ namespace zfoo {
|
||||
a = value >> 21;
|
||||
if (a == 0) {
|
||||
setByte(writeIndex++, (int8_t) b);
|
||||
writerIndex(writeIndex);
|
||||
setWriterOffset(writeIndex);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -242,13 +245,13 @@ namespace zfoo {
|
||||
b = value >> 28;
|
||||
if (b == 0) {
|
||||
setByte(writeIndex++, (int8_t) a);
|
||||
writerIndex(writeIndex);
|
||||
setWriterOffset(writeIndex);
|
||||
return;
|
||||
}
|
||||
|
||||
setByte(writeIndex++, (int8_t) (a | 0x80));
|
||||
setByte(writeIndex++, (int8_t) b);
|
||||
writerIndex(writeIndex);
|
||||
setWriterOffset(writeIndex);
|
||||
}
|
||||
|
||||
inline int32_t writeIntCount(const int32_t &intValue) {
|
||||
@@ -269,7 +272,7 @@ namespace zfoo {
|
||||
}
|
||||
|
||||
inline int32_t readInt() {
|
||||
int32_t readIndex = m_readerIndex;
|
||||
int32_t readIndex = m_readerOffset;
|
||||
|
||||
int32_t b = getByte(readIndex++);
|
||||
uint32_t value = b;
|
||||
@@ -288,7 +291,7 @@ namespace zfoo {
|
||||
}
|
||||
}
|
||||
}
|
||||
readerIndex(readIndex);
|
||||
setReaderOffset(readIndex);
|
||||
value = ((value >> 1) ^ -((int32_t) value & 1));
|
||||
return (int32_t) value;
|
||||
}
|
||||
@@ -345,7 +348,7 @@ namespace zfoo {
|
||||
}
|
||||
|
||||
inline int64_t readLong() {
|
||||
int32_t readIndex = m_readerIndex;
|
||||
int32_t readIndex = m_readerOffset;
|
||||
|
||||
int64_t b = getByte(readIndex++);
|
||||
uint64_t value = b;
|
||||
@@ -382,7 +385,7 @@ namespace zfoo {
|
||||
}
|
||||
}
|
||||
|
||||
readerIndex(readIndex);
|
||||
setReaderOffset(readIndex);
|
||||
value = ((value >> 1) ^ -((int64_t) value & 1));
|
||||
return (int64_t) value;
|
||||
}
|
||||
@@ -437,19 +440,19 @@ namespace zfoo {
|
||||
|
||||
|
||||
//---------------------------------boolean--------------------------------------
|
||||
inline void writeBooleanArray(const vector<bool> &array) {
|
||||
inline void writeBoolArray(const vector<bool> &array) {
|
||||
if (array.empty()) {
|
||||
writeByte(0);
|
||||
return;
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeBool(value);
|
||||
}
|
||||
}
|
||||
|
||||
inline vector<bool> readBooleanArray() {
|
||||
inline vector<bool> readBoolArray() {
|
||||
int32_t length = readInt();
|
||||
int8_t *bytes = readBytes(length);
|
||||
vector<bool> array;
|
||||
@@ -459,19 +462,20 @@ namespace zfoo {
|
||||
return array;
|
||||
}
|
||||
|
||||
inline void writeBooleanList(const list<bool> &list) {
|
||||
inline void writeBoolList(const list<bool> &list) {
|
||||
if (list.empty()) {
|
||||
writeByte(0);
|
||||
return;
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeBool(value);
|
||||
}
|
||||
}
|
||||
|
||||
inline list<bool> readBooleanList() {
|
||||
inline list<bool> readBoolList() {
|
||||
|
||||
int32_t length = readInt();
|
||||
list<bool> list;
|
||||
for (auto i = 0; i < length; i++) {
|
||||
@@ -480,19 +484,19 @@ namespace zfoo {
|
||||
return list;
|
||||
}
|
||||
|
||||
inline void writeBooleanSet(const set<bool> &set) {
|
||||
inline void writeBoolSet(const set<bool> &set) {
|
||||
if (set.empty()) {
|
||||
writeByte(0);
|
||||
return;
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeBool(value);
|
||||
}
|
||||
}
|
||||
|
||||
inline set<bool> readBooleanSet() {
|
||||
inline set<bool> readBoolSet() {
|
||||
int32_t length = readInt();
|
||||
set<bool> set;
|
||||
for (auto i = 0; i < length; i++) {
|
||||
@@ -509,7 +513,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeByte(value);
|
||||
}
|
||||
}
|
||||
@@ -531,7 +535,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeByte(value);
|
||||
}
|
||||
}
|
||||
@@ -552,7 +556,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeByte(value);
|
||||
}
|
||||
}
|
||||
@@ -574,7 +578,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeShort(value);
|
||||
}
|
||||
}
|
||||
@@ -595,7 +599,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeShort(value);
|
||||
}
|
||||
}
|
||||
@@ -616,7 +620,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeShort(value);
|
||||
}
|
||||
}
|
||||
@@ -638,7 +642,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeInt(value);
|
||||
}
|
||||
}
|
||||
@@ -659,7 +663,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeInt(value);
|
||||
}
|
||||
}
|
||||
@@ -680,7 +684,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeInt(value);
|
||||
}
|
||||
}
|
||||
@@ -702,7 +706,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeLong(value);
|
||||
}
|
||||
}
|
||||
@@ -723,7 +727,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeLong(value);
|
||||
}
|
||||
}
|
||||
@@ -744,7 +748,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeLong(value);
|
||||
}
|
||||
}
|
||||
@@ -766,7 +770,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeFloat(value);
|
||||
}
|
||||
}
|
||||
@@ -787,7 +791,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeFloat(value);
|
||||
}
|
||||
}
|
||||
@@ -808,7 +812,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeFloat(value);
|
||||
}
|
||||
}
|
||||
@@ -830,7 +834,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeDouble(value);
|
||||
}
|
||||
}
|
||||
@@ -851,7 +855,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeDouble(value);
|
||||
}
|
||||
}
|
||||
@@ -872,7 +876,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeDouble(value);
|
||||
}
|
||||
}
|
||||
@@ -894,7 +898,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeString(value);
|
||||
}
|
||||
}
|
||||
@@ -915,7 +919,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeString(value);
|
||||
}
|
||||
}
|
||||
@@ -936,7 +940,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeString(value);
|
||||
}
|
||||
}
|
||||
@@ -956,7 +960,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeInt(key);
|
||||
writeInt(value);
|
||||
}
|
||||
@@ -979,7 +983,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeInt(key);
|
||||
writeLong(value);
|
||||
}
|
||||
@@ -1002,7 +1006,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeInt(key);
|
||||
writeString(value);
|
||||
}
|
||||
@@ -1026,7 +1030,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeInt(key);
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
@@ -1051,7 +1055,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeLong(key);
|
||||
writeInt(value);
|
||||
}
|
||||
@@ -1074,7 +1078,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeLong(key);
|
||||
writeLong(value);
|
||||
}
|
||||
@@ -1097,7 +1101,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeLong(key);
|
||||
writeString(value);
|
||||
}
|
||||
@@ -1121,7 +1125,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeLong(key);
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
@@ -1146,7 +1150,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeString(key);
|
||||
writeInt(value);
|
||||
}
|
||||
@@ -1169,7 +1173,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeString(key);
|
||||
writeLong(value);
|
||||
}
|
||||
@@ -1192,7 +1196,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeString(key);
|
||||
writeString(value);
|
||||
}
|
||||
@@ -1216,7 +1220,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeString(key);
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
@@ -1245,7 +1249,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
}
|
||||
@@ -1270,7 +1274,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
}
|
||||
@@ -1295,7 +1299,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
}
|
||||
@@ -1321,17 +1325,17 @@ namespace zfoo {
|
||||
if (IS_LITTLE_ENDIAN) {
|
||||
swap_bytes<sizeof(T)>(reinterpret_cast<int8_t *>(&value));
|
||||
}
|
||||
memcpy(&m_buffer[m_writerIndex], (int8_t *) &value, sizeof(T));
|
||||
m_writerIndex += sizeof(T);
|
||||
memcpy(&m_buffer[m_writerOffset], (int8_t *) &value, sizeof(T));
|
||||
m_writerOffset += sizeof(T);
|
||||
}
|
||||
|
||||
template<class T>
|
||||
inline T read() {
|
||||
T value = *((T *) &m_buffer[m_readerIndex]);
|
||||
T value = *((T *) &m_buffer[m_readerOffset]);
|
||||
if (IS_LITTLE_ENDIAN) {
|
||||
swap_bytes<sizeof(T)>(reinterpret_cast<int8_t *>(&value));
|
||||
}
|
||||
m_readerIndex += sizeof(T);
|
||||
m_readerOffset += sizeof(T);
|
||||
return value;
|
||||
}
|
||||
|
||||
@@ -1343,7 +1347,6 @@ namespace zfoo {
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
@@ -19,10 +19,10 @@ public:
|
||||
if (length == 0) {
|
||||
return packet;
|
||||
}
|
||||
auto beforeReadIndex = buffer.readerIndex();
|
||||
auto beforeReadIndex = buffer.getReaderOffset();
|
||||
${protocol_read_deserialization}
|
||||
if (length > 0) {
|
||||
buffer.readerIndex(beforeReadIndex + length);
|
||||
buffer.setReaderOffset(beforeReadIndex + length);
|
||||
}
|
||||
return packet;
|
||||
}
|
||||
|
||||
@@ -11,7 +11,6 @@
|
||||
|
||||
// 网络传输默认使用大端传输
|
||||
namespace zfoo {
|
||||
|
||||
using std::string;
|
||||
using std::vector;
|
||||
using std::list;
|
||||
@@ -58,8 +57,8 @@ namespace zfoo {
|
||||
private:
|
||||
int8_t *m_buffer;
|
||||
int32_t m_max_capacity;
|
||||
int32_t m_writerIndex;
|
||||
int32_t m_readerIndex;
|
||||
int32_t m_writerOffset;
|
||||
int32_t m_readerOffset;
|
||||
|
||||
public:
|
||||
ByteBuffer(int32_t capacity = DEFAULT_BUFFER_SIZE) : m_max_capacity(capacity) {
|
||||
@@ -78,19 +77,19 @@ namespace zfoo {
|
||||
ByteBuffer &operator=(const ByteBuffer &buffer) = delete;
|
||||
|
||||
void adjustPadding(int32_t predictionLength, int32_t beforeWriteIndex) {
|
||||
int32_t currentWriteIndex = writerIndex();
|
||||
int32_t currentWriteIndex = getWriterOffset();
|
||||
int32_t predictionCount = writeIntCount(predictionLength);
|
||||
int32_t length = currentWriteIndex - beforeWriteIndex - predictionCount;
|
||||
int32_t lengthCount = writeIntCount(length);
|
||||
int32_t padding = lengthCount - predictionCount;
|
||||
if (padding == 0) {
|
||||
writerIndex(beforeWriteIndex);
|
||||
setWriterOffset(beforeWriteIndex);
|
||||
writeInt(length);
|
||||
writerIndex(currentWriteIndex);
|
||||
setWriterOffset(currentWriteIndex);
|
||||
} else {
|
||||
int8_t *targetPtr = (int8_t *) calloc(length, sizeof(int8_t));
|
||||
memcpy(targetPtr, &m_buffer[currentWriteIndex - length], length);
|
||||
writerIndex(beforeWriteIndex);
|
||||
memcpy(targetPtr, &m_buffer[currentWriteIndex - length], length);
|
||||
setWriterOffset(beforeWriteIndex);
|
||||
writeInt(length);
|
||||
writeBytes(targetPtr, length);
|
||||
free(targetPtr);
|
||||
@@ -98,48 +97,52 @@ namespace zfoo {
|
||||
}
|
||||
|
||||
bool compatibleRead(int32_t beforeReadIndex, int32_t length) {
|
||||
return length != -1 && readerIndex() < length + beforeReadIndex;
|
||||
return length != -1 && getReaderOffset() < length + beforeReadIndex;
|
||||
}
|
||||
|
||||
void clear() {
|
||||
m_writerIndex = 0;
|
||||
m_readerIndex = 0;
|
||||
m_writerOffset = 0;
|
||||
m_readerOffset = 0;
|
||||
}
|
||||
|
||||
int32_t writerIndex() const {
|
||||
return m_writerIndex;
|
||||
int8_t *getBuffer() {
|
||||
return m_buffer;
|
||||
}
|
||||
|
||||
int32_t readerIndex() const {
|
||||
return m_readerIndex;
|
||||
int32_t getWriterOffset() const {
|
||||
return m_writerOffset;
|
||||
}
|
||||
|
||||
void writerIndex(int32_t writeIndex) {
|
||||
int32_t getReaderOffset() const {
|
||||
return m_readerOffset;
|
||||
}
|
||||
|
||||
void setWriterOffset(int32_t writeIndex) {
|
||||
if (writeIndex > m_max_capacity) {
|
||||
string errorMessage =
|
||||
"writeIndex[" + std::to_string(writeIndex) + "] out of bounds exception: readerIndex: " +
|
||||
std::to_string(m_readerIndex) +
|
||||
", writerIndex: " + std::to_string(m_writerIndex) +
|
||||
std::to_string(m_readerOffset) +
|
||||
", writerIndex: " + std::to_string(m_writerOffset) +
|
||||
"(expected: 0 <= readerIndex <= writerIndex <= capacity:" + std::to_string(m_max_capacity);
|
||||
throw errorMessage;
|
||||
}
|
||||
m_writerIndex = writeIndex;
|
||||
m_writerOffset = writeIndex;
|
||||
}
|
||||
|
||||
void readerIndex(int32_t readerIndex) {
|
||||
if (readerIndex > m_writerIndex) {
|
||||
void setReaderOffset(int32_t readerIndex) {
|
||||
if (readerIndex > m_writerOffset) {
|
||||
string errorMessage =
|
||||
"readIndex[" + std::to_string(readerIndex) + "] out of bounds exception: readerIndex: " +
|
||||
std::to_string(m_readerIndex) +
|
||||
", writerIndex: " + std::to_string(m_writerIndex) +
|
||||
std::to_string(m_readerOffset) +
|
||||
", writerIndex: " + std::to_string(m_writerOffset) +
|
||||
"(expected: 0 <= readerIndex <= writerIndex <= capacity:" + std::to_string(m_max_capacity);
|
||||
throw errorMessage;
|
||||
}
|
||||
m_readerIndex = readerIndex;
|
||||
m_readerOffset = readerIndex;
|
||||
}
|
||||
|
||||
inline int32_t getCapacity() const {
|
||||
return m_max_capacity - m_writerIndex;
|
||||
return m_max_capacity - m_writerOffset;
|
||||
}
|
||||
|
||||
inline void ensureCapacity(const int32_t &capacity) {
|
||||
@@ -156,27 +159,27 @@ namespace zfoo {
|
||||
}
|
||||
|
||||
inline bool isReadable() {
|
||||
return m_writerIndex > m_readerIndex;
|
||||
return m_writerOffset > m_readerOffset;
|
||||
}
|
||||
|
||||
inline void writeBool(const bool &value) {
|
||||
ensureCapacity(1);
|
||||
int8_t v = value ? 1 : 0;
|
||||
m_buffer[m_writerIndex++] = v;
|
||||
m_buffer[m_writerOffset++] = v;
|
||||
}
|
||||
|
||||
inline bool readBool() {
|
||||
int8_t value = m_buffer[m_readerIndex++];
|
||||
int8_t value = m_buffer[m_readerOffset++];
|
||||
return value == 1;
|
||||
}
|
||||
|
||||
inline void writeByte(const int8_t &value) {
|
||||
ensureCapacity(1);
|
||||
m_buffer[m_writerIndex++] = value;
|
||||
m_buffer[m_writerOffset++] = value;
|
||||
}
|
||||
|
||||
inline int8_t readByte() {
|
||||
return m_buffer[m_readerIndex++];
|
||||
return m_buffer[m_readerOffset++];
|
||||
}
|
||||
|
||||
inline void setByte(const int32_t &index, const int8_t &value) {
|
||||
@@ -189,13 +192,13 @@ namespace zfoo {
|
||||
|
||||
inline void writeBytes(const int8_t *buffer, const int32_t &length) {
|
||||
ensureCapacity(length);
|
||||
memcpy(&m_buffer[m_writerIndex], buffer, length);
|
||||
m_writerIndex += length;
|
||||
memcpy(&m_buffer[m_writerOffset], buffer, length);
|
||||
m_writerOffset += length;
|
||||
}
|
||||
|
||||
inline int8_t *readBytes(const int32_t &length) {
|
||||
int8_t *bytes = &m_buffer[m_readerIndex];
|
||||
m_readerIndex += length;
|
||||
int8_t *bytes = &m_buffer[m_readerOffset];
|
||||
m_readerOffset += length;
|
||||
return bytes;
|
||||
}
|
||||
|
||||
@@ -219,14 +222,14 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
|
||||
int32_t writeIndex = m_writerIndex;
|
||||
int32_t writeIndex = m_writerOffset;
|
||||
ensureCapacity(5);
|
||||
|
||||
setByte(writeIndex++, (int8_t) (value | 0x80));
|
||||
uint32_t b = value >> 14;
|
||||
if (b == 0) {
|
||||
setByte(writeIndex++, (int8_t) a);
|
||||
writerIndex(writeIndex);
|
||||
setWriterOffset(writeIndex);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -234,7 +237,7 @@ namespace zfoo {
|
||||
a = value >> 21;
|
||||
if (a == 0) {
|
||||
setByte(writeIndex++, (int8_t) b);
|
||||
writerIndex(writeIndex);
|
||||
setWriterOffset(writeIndex);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -242,13 +245,13 @@ namespace zfoo {
|
||||
b = value >> 28;
|
||||
if (b == 0) {
|
||||
setByte(writeIndex++, (int8_t) a);
|
||||
writerIndex(writeIndex);
|
||||
setWriterOffset(writeIndex);
|
||||
return;
|
||||
}
|
||||
|
||||
setByte(writeIndex++, (int8_t) (a | 0x80));
|
||||
setByte(writeIndex++, (int8_t) b);
|
||||
writerIndex(writeIndex);
|
||||
setWriterOffset(writeIndex);
|
||||
}
|
||||
|
||||
inline int32_t writeIntCount(const int32_t &intValue) {
|
||||
@@ -269,7 +272,7 @@ namespace zfoo {
|
||||
}
|
||||
|
||||
inline int32_t readInt() {
|
||||
int32_t readIndex = m_readerIndex;
|
||||
int32_t readIndex = m_readerOffset;
|
||||
|
||||
int32_t b = getByte(readIndex++);
|
||||
uint32_t value = b;
|
||||
@@ -288,7 +291,7 @@ namespace zfoo {
|
||||
}
|
||||
}
|
||||
}
|
||||
readerIndex(readIndex);
|
||||
setReaderOffset(readIndex);
|
||||
value = ((value >> 1) ^ -((int32_t) value & 1));
|
||||
return (int32_t) value;
|
||||
}
|
||||
@@ -345,7 +348,7 @@ namespace zfoo {
|
||||
}
|
||||
|
||||
inline int64_t readLong() {
|
||||
int32_t readIndex = m_readerIndex;
|
||||
int32_t readIndex = m_readerOffset;
|
||||
|
||||
int64_t b = getByte(readIndex++);
|
||||
uint64_t value = b;
|
||||
@@ -382,7 +385,7 @@ namespace zfoo {
|
||||
}
|
||||
}
|
||||
|
||||
readerIndex(readIndex);
|
||||
setReaderOffset(readIndex);
|
||||
value = ((value >> 1) ^ -((int64_t) value & 1));
|
||||
return (int64_t) value;
|
||||
}
|
||||
@@ -437,19 +440,19 @@ namespace zfoo {
|
||||
|
||||
|
||||
//---------------------------------boolean--------------------------------------
|
||||
inline void writeBooleanArray(const vector<bool> &array) {
|
||||
inline void writeBoolArray(const vector<bool> &array) {
|
||||
if (array.empty()) {
|
||||
writeByte(0);
|
||||
return;
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeBool(value);
|
||||
}
|
||||
}
|
||||
|
||||
inline vector<bool> readBooleanArray() {
|
||||
inline vector<bool> readBoolArray() {
|
||||
int32_t length = readInt();
|
||||
int8_t *bytes = readBytes(length);
|
||||
vector<bool> array;
|
||||
@@ -459,19 +462,19 @@ namespace zfoo {
|
||||
return array;
|
||||
}
|
||||
|
||||
inline void writeBooleanList(const list<bool> &list) {
|
||||
inline void writeBoolList(const list<bool> &list) {
|
||||
if (list.empty()) {
|
||||
writeByte(0);
|
||||
return;
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeBool(value);
|
||||
}
|
||||
}
|
||||
|
||||
inline list<bool> readBooleanList() {
|
||||
inline list<bool> readBoolList() {
|
||||
int32_t length = readInt();
|
||||
list<bool> list;
|
||||
for (auto i = 0; i < length; i++) {
|
||||
@@ -480,19 +483,19 @@ namespace zfoo {
|
||||
return list;
|
||||
}
|
||||
|
||||
inline void writeBooleanSet(const set<bool> &set) {
|
||||
inline void writeBoolSet(const set<bool> &set) {
|
||||
if (set.empty()) {
|
||||
writeByte(0);
|
||||
return;
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeBool(value);
|
||||
}
|
||||
}
|
||||
|
||||
inline set<bool> readBooleanSet() {
|
||||
inline set<bool> readBoolSet() {
|
||||
int32_t length = readInt();
|
||||
set<bool> set;
|
||||
for (auto i = 0; i < length; i++) {
|
||||
@@ -509,7 +512,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeByte(value);
|
||||
}
|
||||
}
|
||||
@@ -531,7 +534,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeByte(value);
|
||||
}
|
||||
}
|
||||
@@ -552,7 +555,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeByte(value);
|
||||
}
|
||||
}
|
||||
@@ -574,7 +577,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeShort(value);
|
||||
}
|
||||
}
|
||||
@@ -595,7 +598,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeShort(value);
|
||||
}
|
||||
}
|
||||
@@ -616,7 +619,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeShort(value);
|
||||
}
|
||||
}
|
||||
@@ -638,7 +641,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeInt(value);
|
||||
}
|
||||
}
|
||||
@@ -659,7 +662,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeInt(value);
|
||||
}
|
||||
}
|
||||
@@ -680,7 +683,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeInt(value);
|
||||
}
|
||||
}
|
||||
@@ -702,7 +705,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeLong(value);
|
||||
}
|
||||
}
|
||||
@@ -723,7 +726,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeLong(value);
|
||||
}
|
||||
}
|
||||
@@ -744,7 +747,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeLong(value);
|
||||
}
|
||||
}
|
||||
@@ -766,7 +769,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeFloat(value);
|
||||
}
|
||||
}
|
||||
@@ -787,7 +790,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeFloat(value);
|
||||
}
|
||||
}
|
||||
@@ -808,7 +811,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeFloat(value);
|
||||
}
|
||||
}
|
||||
@@ -830,7 +833,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeDouble(value);
|
||||
}
|
||||
}
|
||||
@@ -851,7 +854,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeDouble(value);
|
||||
}
|
||||
}
|
||||
@@ -872,7 +875,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeDouble(value);
|
||||
}
|
||||
}
|
||||
@@ -894,7 +897,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writeString(value);
|
||||
}
|
||||
}
|
||||
@@ -915,7 +918,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writeString(value);
|
||||
}
|
||||
}
|
||||
@@ -936,7 +939,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writeString(value);
|
||||
}
|
||||
}
|
||||
@@ -956,7 +959,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeInt(key);
|
||||
writeInt(value);
|
||||
}
|
||||
@@ -979,7 +982,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeInt(key);
|
||||
writeLong(value);
|
||||
}
|
||||
@@ -1002,7 +1005,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeInt(key);
|
||||
writeString(value);
|
||||
}
|
||||
@@ -1026,7 +1029,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeInt(key);
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
@@ -1051,7 +1054,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeLong(key);
|
||||
writeInt(value);
|
||||
}
|
||||
@@ -1074,7 +1077,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeLong(key);
|
||||
writeLong(value);
|
||||
}
|
||||
@@ -1097,7 +1100,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeLong(key);
|
||||
writeString(value);
|
||||
}
|
||||
@@ -1121,7 +1124,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeLong(key);
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
@@ -1146,7 +1149,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeString(key);
|
||||
writeInt(value);
|
||||
}
|
||||
@@ -1169,7 +1172,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeString(key);
|
||||
writeLong(value);
|
||||
}
|
||||
@@ -1192,7 +1195,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeString(key);
|
||||
writeString(value);
|
||||
}
|
||||
@@ -1216,7 +1219,7 @@ namespace zfoo {
|
||||
return;
|
||||
}
|
||||
writeInt(map.size());
|
||||
for (const auto&[key, value] : map) {
|
||||
for (const auto &[key, value]: map) {
|
||||
writeString(key);
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
@@ -1245,7 +1248,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = array.size();
|
||||
writeInt(length);
|
||||
for (auto value : array) {
|
||||
for (auto value: array) {
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
}
|
||||
@@ -1270,7 +1273,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = list.size();
|
||||
writeInt(length);
|
||||
for (auto value : list) {
|
||||
for (auto value: list) {
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
}
|
||||
@@ -1295,7 +1298,7 @@ namespace zfoo {
|
||||
}
|
||||
int32_t length = set.size();
|
||||
writeInt(length);
|
||||
for (auto value : set) {
|
||||
for (auto value: set) {
|
||||
writePacket((IProtocol *) &value, protocolId);
|
||||
}
|
||||
}
|
||||
@@ -1321,17 +1324,17 @@ namespace zfoo {
|
||||
if (IS_LITTLE_ENDIAN) {
|
||||
swap_bytes<sizeof(T)>(reinterpret_cast<int8_t *>(&value));
|
||||
}
|
||||
memcpy(&m_buffer[m_writerIndex], (int8_t *) &value, sizeof(T));
|
||||
m_writerIndex += sizeof(T);
|
||||
memcpy(&m_buffer[m_writerOffset], (int8_t *) &value, sizeof(T));
|
||||
m_writerOffset += sizeof(T);
|
||||
}
|
||||
|
||||
template<class T>
|
||||
inline T read() {
|
||||
T value = *((T *) &m_buffer[m_readerIndex]);
|
||||
T value = *((T *) &m_buffer[m_readerOffset]);
|
||||
if (IS_LITTLE_ENDIAN) {
|
||||
swap_bytes<sizeof(T)>(reinterpret_cast<int8_t *>(&value));
|
||||
}
|
||||
m_readerIndex += sizeof(T);
|
||||
m_readerOffset += sizeof(T);
|
||||
return value;
|
||||
}
|
||||
|
||||
@@ -1343,7 +1346,6 @@ namespace zfoo {
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
@@ -1,50 +0,0 @@
|
||||
#ifndef ZFOO_EmptyObject
|
||||
#define ZFOO_EmptyObject
|
||||
|
||||
#include "zfoocpp/ByteBuffer.h"
|
||||
|
||||
namespace zfoo {
|
||||
|
||||
class EmptyObject : public IProtocol {
|
||||
public:
|
||||
|
||||
|
||||
~EmptyObject() override = default;
|
||||
|
||||
int16_t protocolId() override {
|
||||
return 0;
|
||||
}
|
||||
};
|
||||
|
||||
class EmptyObjectRegistration : public IProtocolRegistration {
|
||||
public:
|
||||
int16_t protocolId() override {
|
||||
return 0;
|
||||
}
|
||||
|
||||
void write(ByteBuffer &buffer, IProtocol *packet) override {
|
||||
if (packet == nullptr) {
|
||||
buffer.writeInt(0);
|
||||
return;
|
||||
}
|
||||
auto *message = (EmptyObject *) packet;
|
||||
buffer.writeInt(-1);
|
||||
}
|
||||
|
||||
IProtocol *read(ByteBuffer &buffer) override {
|
||||
auto *packet = new EmptyObject();
|
||||
auto length = buffer.readInt();
|
||||
if (length == 0) {
|
||||
return packet;
|
||||
}
|
||||
auto beforeReadIndex = buffer.readerIndex();
|
||||
|
||||
if (length > 0) {
|
||||
buffer.readerIndex(beforeReadIndex + length);
|
||||
}
|
||||
return packet;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
||||
@@ -1,136 +0,0 @@
|
||||
#ifndef ZFOO_NormalObject
|
||||
#define ZFOO_NormalObject
|
||||
|
||||
#include "zfoocpp/ByteBuffer.h"
|
||||
#include "zfoocpp/ObjectA.h"
|
||||
#include "zfoocpp/ObjectB.h"
|
||||
namespace zfoo {
|
||||
|
||||
class NormalObject : public IProtocol {
|
||||
public:
|
||||
int8_t a;
|
||||
vector<int8_t> aaa;
|
||||
int16_t b;
|
||||
int32_t c;
|
||||
int64_t d;
|
||||
float e;
|
||||
double f;
|
||||
bool g;
|
||||
string jj;
|
||||
ObjectA kk;
|
||||
list<int32_t> l;
|
||||
list<int64_t> ll;
|
||||
list<ObjectA> lll;
|
||||
list<string> llll;
|
||||
map<int32_t, string> m;
|
||||
map<int32_t, ObjectA> mm;
|
||||
set<int32_t> s;
|
||||
set<string> ssss;
|
||||
int32_t outCompatibleValue;
|
||||
int32_t outCompatibleValue2;
|
||||
|
||||
~NormalObject() override = default;
|
||||
|
||||
int16_t protocolId() override {
|
||||
return 101;
|
||||
}
|
||||
};
|
||||
|
||||
class NormalObjectRegistration : public IProtocolRegistration {
|
||||
public:
|
||||
int16_t protocolId() override {
|
||||
return 101;
|
||||
}
|
||||
|
||||
void write(ByteBuffer &buffer, IProtocol *packet) override {
|
||||
if (packet == nullptr) {
|
||||
buffer.writeInt(0);
|
||||
return;
|
||||
}
|
||||
auto *message = (NormalObject *) packet;
|
||||
auto beforeWriteIndex = buffer.writerIndex();
|
||||
buffer.writeInt(857);
|
||||
buffer.writeByte(message->a);
|
||||
buffer.writeByteArray(message->aaa);
|
||||
buffer.writeShort(message->b);
|
||||
buffer.writeInt(message->c);
|
||||
buffer.writeLong(message->d);
|
||||
buffer.writeFloat(message->e);
|
||||
buffer.writeDouble(message->f);
|
||||
buffer.writeBool(message->g);
|
||||
buffer.writeString(message->jj);
|
||||
buffer.writePacket(&message->kk, 102);
|
||||
buffer.writeIntList(message->l);
|
||||
buffer.writeLongList(message->ll);
|
||||
buffer.writePacketList(message->lll, 102);
|
||||
buffer.writeStringList(message->llll);
|
||||
buffer.writeIntStringMap(message->m);
|
||||
buffer.writeIntPacketMap(message->mm, 102);
|
||||
buffer.writeIntSet(message->s);
|
||||
buffer.writeStringSet(message->ssss);
|
||||
buffer.writeInt(message->outCompatibleValue);
|
||||
buffer.writeInt(message->outCompatibleValue2);
|
||||
buffer.adjustPadding(857, beforeWriteIndex);
|
||||
}
|
||||
|
||||
IProtocol *read(ByteBuffer &buffer) override {
|
||||
auto *packet = new NormalObject();
|
||||
auto length = buffer.readInt();
|
||||
if (length == 0) {
|
||||
return packet;
|
||||
}
|
||||
auto beforeReadIndex = buffer.readerIndex();
|
||||
int8_t result0 = buffer.readByte();
|
||||
packet->a = result0;
|
||||
auto array1 = buffer.readByteArray();
|
||||
packet->aaa = array1;
|
||||
auto result2 = buffer.readShort();
|
||||
packet->b = result2;
|
||||
int32_t result3 = buffer.readInt();
|
||||
packet->c = result3;
|
||||
auto result4 = buffer.readLong();
|
||||
packet->d = result4;
|
||||
float result5 = buffer.readFloat();
|
||||
packet->e = result5;
|
||||
double result6 = buffer.readDouble();
|
||||
packet->f = result6;
|
||||
bool result7 = buffer.readBool();
|
||||
packet->g = result7;
|
||||
auto result8 = buffer.readString();
|
||||
packet->jj = result8;
|
||||
auto result9 = buffer.readPacket(102);
|
||||
auto *result10 = (ObjectA *) result9.get();
|
||||
packet->kk = *result10;
|
||||
auto list11 = buffer.readIntList();
|
||||
packet->l = list11;
|
||||
auto list12 = buffer.readLongList();
|
||||
packet->ll = list12;
|
||||
auto list13 = buffer.readPacketList<ObjectA>(102);
|
||||
packet->lll = list13;
|
||||
auto list14 = buffer.readStringList();
|
||||
packet->llll = list14;
|
||||
auto map15 = buffer.readIntStringMap();
|
||||
packet->m = map15;
|
||||
auto map16 = buffer.readIntPacketMap<ObjectA>(102);
|
||||
packet->mm = map16;
|
||||
auto set17 = buffer.readIntSet();
|
||||
packet->s = set17;
|
||||
auto set18 = buffer.readStringSet();
|
||||
packet->ssss = set18;
|
||||
if (buffer.compatibleRead(beforeReadIndex, length)) {
|
||||
int32_t result19 = buffer.readInt();
|
||||
packet->outCompatibleValue = result19;
|
||||
}
|
||||
if (buffer.compatibleRead(beforeReadIndex, length)) {
|
||||
int32_t result20 = buffer.readInt();
|
||||
packet->outCompatibleValue2 = result20;
|
||||
}
|
||||
if (length > 0) {
|
||||
buffer.readerIndex(beforeReadIndex + length);
|
||||
}
|
||||
return packet;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
||||
@@ -1,69 +0,0 @@
|
||||
#ifndef ZFOO_ObjectA
|
||||
#define ZFOO_ObjectA
|
||||
|
||||
#include "zfoocpp/ByteBuffer.h"
|
||||
#include "zfoocpp/ObjectB.h"
|
||||
namespace zfoo {
|
||||
|
||||
class ObjectA : public IProtocol {
|
||||
public:
|
||||
int32_t a;
|
||||
map<int32_t, string> m;
|
||||
ObjectB objectB;
|
||||
int32_t innerCompatibleValue;
|
||||
|
||||
~ObjectA() override = default;
|
||||
|
||||
int16_t protocolId() override {
|
||||
return 102;
|
||||
}
|
||||
};
|
||||
|
||||
class ObjectARegistration : public IProtocolRegistration {
|
||||
public:
|
||||
int16_t protocolId() override {
|
||||
return 102;
|
||||
}
|
||||
|
||||
void write(ByteBuffer &buffer, IProtocol *packet) override {
|
||||
if (packet == nullptr) {
|
||||
buffer.writeInt(0);
|
||||
return;
|
||||
}
|
||||
auto *message = (ObjectA *) packet;
|
||||
auto beforeWriteIndex = buffer.writerIndex();
|
||||
buffer.writeInt(201);
|
||||
buffer.writeInt(message->a);
|
||||
buffer.writeIntStringMap(message->m);
|
||||
buffer.writePacket(&message->objectB, 103);
|
||||
buffer.writeInt(message->innerCompatibleValue);
|
||||
buffer.adjustPadding(201, beforeWriteIndex);
|
||||
}
|
||||
|
||||
IProtocol *read(ByteBuffer &buffer) override {
|
||||
auto *packet = new ObjectA();
|
||||
auto length = buffer.readInt();
|
||||
if (length == 0) {
|
||||
return packet;
|
||||
}
|
||||
auto beforeReadIndex = buffer.readerIndex();
|
||||
int32_t result0 = buffer.readInt();
|
||||
packet->a = result0;
|
||||
auto map1 = buffer.readIntStringMap();
|
||||
packet->m = map1;
|
||||
auto result2 = buffer.readPacket(103);
|
||||
auto *result3 = (ObjectB *) result2.get();
|
||||
packet->objectB = *result3;
|
||||
if (buffer.compatibleRead(beforeReadIndex, length)) {
|
||||
int32_t result4 = buffer.readInt();
|
||||
packet->innerCompatibleValue = result4;
|
||||
}
|
||||
if (length > 0) {
|
||||
buffer.readerIndex(beforeReadIndex + length);
|
||||
}
|
||||
return packet;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
||||
@@ -1,60 +0,0 @@
|
||||
#ifndef ZFOO_ObjectB
|
||||
#define ZFOO_ObjectB
|
||||
|
||||
#include "zfoocpp/ByteBuffer.h"
|
||||
|
||||
namespace zfoo {
|
||||
|
||||
class ObjectB : public IProtocol {
|
||||
public:
|
||||
bool flag;
|
||||
int32_t innerCompatibleValue;
|
||||
|
||||
~ObjectB() override = default;
|
||||
|
||||
int16_t protocolId() override {
|
||||
return 103;
|
||||
}
|
||||
};
|
||||
|
||||
class ObjectBRegistration : public IProtocolRegistration {
|
||||
public:
|
||||
int16_t protocolId() override {
|
||||
return 103;
|
||||
}
|
||||
|
||||
void write(ByteBuffer &buffer, IProtocol *packet) override {
|
||||
if (packet == nullptr) {
|
||||
buffer.writeInt(0);
|
||||
return;
|
||||
}
|
||||
auto *message = (ObjectB *) packet;
|
||||
auto beforeWriteIndex = buffer.writerIndex();
|
||||
buffer.writeInt(4);
|
||||
buffer.writeBool(message->flag);
|
||||
buffer.writeInt(message->innerCompatibleValue);
|
||||
buffer.adjustPadding(4, beforeWriteIndex);
|
||||
}
|
||||
|
||||
IProtocol *read(ByteBuffer &buffer) override {
|
||||
auto *packet = new ObjectB();
|
||||
auto length = buffer.readInt();
|
||||
if (length == 0) {
|
||||
return packet;
|
||||
}
|
||||
auto beforeReadIndex = buffer.readerIndex();
|
||||
bool result0 = buffer.readBool();
|
||||
packet->flag = result0;
|
||||
if (buffer.compatibleRead(beforeReadIndex, length)) {
|
||||
int32_t result1 = buffer.readInt();
|
||||
packet->innerCompatibleValue = result1;
|
||||
}
|
||||
if (length > 0) {
|
||||
buffer.readerIndex(beforeReadIndex + length);
|
||||
}
|
||||
return packet;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
||||
@@ -2,11 +2,11 @@
|
||||
#define ZFOO_PROTOCOLMANAGER_H
|
||||
|
||||
#include "ByteBuffer.h"
|
||||
#include "zfoocpp/EmptyObject.h"
|
||||
#include "zfoocpp/NormalObject.h"
|
||||
#include "zfoocpp/ObjectA.h"
|
||||
#include "zfoocpp/ObjectB.h"
|
||||
#include "zfoocpp/SimpleObject.h"
|
||||
#include "zfoocpp/packet/EmptyObject.h"
|
||||
#include "zfoocpp/packet/NormalObject.h"
|
||||
#include "zfoocpp/packet/ObjectA.h"
|
||||
#include "zfoocpp/packet/ObjectB.h"
|
||||
#include "zfoocpp/packet/SimpleObject.h"
|
||||
namespace zfoo {
|
||||
|
||||
const int16_t MAX_PROTOCOL_NUM = 32767;
|
||||
|
||||
@@ -1,56 +0,0 @@
|
||||
#ifndef ZFOO_SimpleObject
|
||||
#define ZFOO_SimpleObject
|
||||
|
||||
#include "zfoocpp/ByteBuffer.h"
|
||||
|
||||
namespace zfoo {
|
||||
|
||||
class SimpleObject : public IProtocol {
|
||||
public:
|
||||
int32_t c;
|
||||
bool g;
|
||||
|
||||
~SimpleObject() override = default;
|
||||
|
||||
int16_t protocolId() override {
|
||||
return 104;
|
||||
}
|
||||
};
|
||||
|
||||
class SimpleObjectRegistration : public IProtocolRegistration {
|
||||
public:
|
||||
int16_t protocolId() override {
|
||||
return 104;
|
||||
}
|
||||
|
||||
void write(ByteBuffer &buffer, IProtocol *packet) override {
|
||||
if (packet == nullptr) {
|
||||
buffer.writeInt(0);
|
||||
return;
|
||||
}
|
||||
auto *message = (SimpleObject *) packet;
|
||||
buffer.writeInt(-1);
|
||||
buffer.writeInt(message->c);
|
||||
buffer.writeBool(message->g);
|
||||
}
|
||||
|
||||
IProtocol *read(ByteBuffer &buffer) override {
|
||||
auto *packet = new SimpleObject();
|
||||
auto length = buffer.readInt();
|
||||
if (length == 0) {
|
||||
return packet;
|
||||
}
|
||||
auto beforeReadIndex = buffer.readerIndex();
|
||||
int32_t result0 = buffer.readInt();
|
||||
packet->c = result0;
|
||||
bool result1 = buffer.readBool();
|
||||
packet->g = result1;
|
||||
if (length > 0) {
|
||||
buffer.readerIndex(beforeReadIndex + length);
|
||||
}
|
||||
return packet;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user