From 2ce377f5a799abce0b6a3c8539857b702efaa5b3 Mon Sep 17 00:00:00 2001 From: Kasper Hjort Berthelsen Date: Wed, 22 May 2024 13:51:37 +0200 Subject: [PATCH 1/1] Silence Wcast-align in public headers --- include/flatbuffers/buffer.h | 9 +++++++++ include/flatbuffers/flatbuffer_builder.h | 12 ++++++++++++ include/flatbuffers/table.h | 6 ++++++ include/flatbuffers/vector_downward.h | 6 ++++++ 4 files changed, 33 insertions(+) diff --git a/include/flatbuffers/buffer.h b/include/flatbuffers/buffer.h index 94d4f790..f496b5a5 100644 --- a/include/flatbuffers/buffer.h +++ b/include/flatbuffers/buffer.h @@ -96,12 +96,18 @@ template struct IndirectHelper { static const size_t element_stride = sizeof(T); static return_type Read(const uint8_t *p, const size_t i) { +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" return EndianScalar((reinterpret_cast(p))[i]); +#pragma GCC diagnostic pop } static mutable_return_type Read(uint8_t *p, const size_t i) { +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" return reinterpret_cast( Read(const_cast(p), i)); } +#pragma GCC diagnostic pop }; // For vector of Offsets. @@ -119,9 +125,12 @@ struct IndirectHelper> { // Then read the scalar value of the offset (which may be 32 or 64-bits) and // then determine the relative location from the offset location. +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" return reinterpret_cast( offset_location + ReadScalar(offset_location)); } +#pragma GCC diagnostic pop static mutable_return_type Read(uint8_t *const p, const offset_type i) { // Offsets are relative to themselves, so first update the pointer to // point to the offset location. diff --git a/include/flatbuffers/flatbuffer_builder.h b/include/flatbuffers/flatbuffer_builder.h index 9a2d6254..4ea23b88 100644 --- a/include/flatbuffers/flatbuffer_builder.h +++ b/include/flatbuffers/flatbuffer_builder.h @@ -54,7 +54,10 @@ const T *data(const std::vector &v) { // Eventually the returned pointer gets passed down to memcpy, so // we need it to be non-null to avoid undefined behavior. static uint8_t t; +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" return v.empty() ? reinterpret_cast(&t) : &v.front(); +#pragma GCC diagnostic pop } template> T *data(std::vector &v) { @@ -440,7 +443,10 @@ template class FlatBufferBuilderImpl { // Write the offsets into the table for (auto it = buf_.scratch_end() - num_field_loc * sizeof(FieldLoc); it < buf_.scratch_end(); it += sizeof(FieldLoc)) { +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" auto field_location = reinterpret_cast(it); +#pragma GCC diagnostic pop const voffset_t pos = static_cast(vtable_offset_loc - field_location->off); // If this asserts, it means you've set a field twice. @@ -449,7 +455,10 @@ template class FlatBufferBuilderImpl { WriteScalar(buf_.data() + field_location->id, pos); } ClearOffsets(); +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" auto vt1 = reinterpret_cast(buf_.data()); +#pragma GCC diagnostic pop auto vt1_size = ReadScalar(vt1); auto vt_use = GetSizeRelative32BitRegion(); // See if we already have generated a vtable with this exact same @@ -457,8 +466,11 @@ template class FlatBufferBuilderImpl { if (dedup_vtables_) { for (auto it = buf_.scratch_data(); it < buf_.scratch_end(); it += sizeof(uoffset_t)) { +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" auto vt_offset_ptr = reinterpret_cast(it); auto vt2 = reinterpret_cast(buf_.data_at(*vt_offset_ptr)); +#pragma GCC diagnostic pop auto vt2_size = ReadScalar(vt2); if (vt1_size != vt2_size || 0 != memcmp(vt2, vt1, vt1_size)) continue; vt_use = *vt_offset_ptr; diff --git a/include/flatbuffers/table.h b/include/flatbuffers/table.h index e92d8ae8..c2400a3b 100644 --- a/include/flatbuffers/table.h +++ b/include/flatbuffers/table.h @@ -51,8 +51,11 @@ class Table { P GetPointer(voffset_t field) { auto field_offset = GetOptionalFieldOffset(field); auto p = data_ + field_offset; +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" return field_offset ? reinterpret_cast

(p + ReadScalar(p)) : nullptr; +#pragma GCC diagnostic pop } template P GetPointer(voffset_t field) const { @@ -70,7 +73,10 @@ class Table { template P GetStruct(voffset_t field) const { auto field_offset = GetOptionalFieldOffset(field); auto p = const_cast(data_ + field_offset); +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" return field_offset ? reinterpret_cast

(p) : nullptr; +#pragma GCC diagnostic pop } template diff --git a/include/flatbuffers/vector_downward.h b/include/flatbuffers/vector_downward.h index 2b5a92cf..dd869444 100644 --- a/include/flatbuffers/vector_downward.h +++ b/include/flatbuffers/vector_downward.h @@ -199,12 +199,18 @@ template class vector_downward { // Specialized version of push() that avoids memcpy call for small data. template void push_small(const T &little_endian_t) { make_space(sizeof(T)); +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" *reinterpret_cast(cur_) = little_endian_t; +#pragma GCC diagnostic pop } template void scratch_push_small(const T &t) { ensure_space(sizeof(T)); +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-align" *reinterpret_cast(scratch_) = t; +#pragma GCC diagnostic pop scratch_ += sizeof(T); } -- 2.34.1