Commit 760c9473 authored by gejun's avatar gejun

Suppress strict-alias warnings in recordio.cc

parent 751b3696
...@@ -172,7 +172,8 @@ bool RecordReader::CutUntilNextRecordCandidate() { ...@@ -172,7 +172,8 @@ bool RecordReader::CutUntilNextRecordCandidate() {
if (_cutter.copy_to(magic, sizeof(magic)) != sizeof(magic)) { if (_cutter.copy_to(magic, sizeof(magic)) != sizeof(magic)) {
return false; return false;
} }
if (*(const uint32_t*)magic == *(const uint32_t*)BRPC_RECORDIO_MAGIC) { void* dummy = magic; // suppressing strict-aliasing warning
if (*(const uint32_t*)dummy == *(const uint32_t*)BRPC_RECORDIO_MAGIC) {
_cutter.pop_front(sizeof(magic)); _cutter.pop_front(sizeof(magic));
_ncut += sizeof(magic); _ncut += sizeof(magic);
} }
...@@ -184,7 +185,8 @@ bool RecordReader::CutUntilNextRecordCandidate() { ...@@ -184,7 +185,8 @@ bool RecordReader::CutUntilNextRecordCandidate() {
} }
const size_t m = nc + 1 - sizeof(magic); const size_t m = nc + 1 - sizeof(magic);
for (size_t i = 0; i < m; ++i) { for (size_t i = 0; i < m; ++i) {
if (*(const uint32_t*)(buf + i) == *(const uint32_t*)BRPC_RECORDIO_MAGIC) { void* dummy = buf + i; // suppressing strict-aliasing warning
if (*(const uint32_t*)dummy == *(const uint32_t*)BRPC_RECORDIO_MAGIC) {
_cutter.pop_front(i); _cutter.pop_front(i);
_ncut += i; _ncut += i;
LOG(INFO) << "Found record candidate after " << _ncut - old_ncut << " bytes"; LOG(INFO) << "Found record candidate after " << _ncut - old_ncut << " bytes";
...@@ -204,7 +206,8 @@ int RecordReader::CutRecord(Record* rec) { ...@@ -204,7 +206,8 @@ int RecordReader::CutRecord(Record* rec) {
if (_cutter.copy_to(headbuf, sizeof(headbuf)) != sizeof(headbuf)) { if (_cutter.copy_to(headbuf, sizeof(headbuf)) != sizeof(headbuf)) {
return 0; return 0;
} }
if (*(const uint32_t*)headbuf != *(const uint32_t*)BRPC_RECORDIO_MAGIC) { void* dummy = headbuf; // suppressing strict-aliasing warning
if (*(const uint32_t*)dummy != *(const uint32_t*)BRPC_RECORDIO_MAGIC) {
LOG(ERROR) << "Invalid magic_num=" LOG(ERROR) << "Invalid magic_num="
<< butil::PrintedAsBinary(std::string((char*)headbuf, 4)) << butil::PrintedAsBinary(std::string((char*)headbuf, 4))
<< ", offset=" << read_bytes(); << ", offset=" << read_bytes();
...@@ -310,7 +313,8 @@ int RecordWriter::WriteWithoutFlush(const Record& rec) { ...@@ -310,7 +313,8 @@ int RecordWriter::WriteWithoutFlush(const Record& rec) {
if (!rec.Payload().empty()) { if (!rec.Payload().empty()) {
_buf.append(rec.Payload()); _buf.append(rec.Payload());
} }
*(uint32_t*)headbuf = *(const uint32_t*)BRPC_RECORDIO_MAGIC; void* dummy = headbuf; // suppressing strict-aliasing warning
*(uint32_t*)dummy = *(const uint32_t*)BRPC_RECORDIO_MAGIC;
const size_t data_size = _buf.size() - old_size - sizeof(headbuf); const size_t data_size = _buf.size() - old_size - sizeof(headbuf);
if (data_size > 0x7FFFFFFFULL) { if (data_size > 0x7FFFFFFFULL) {
LOG(ERROR) << "data_size=" << data_size << " is too long"; LOG(ERROR) << "data_size=" << data_size << " is too long";
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment