summaryrefslogtreecommitdiff
path: root/include/google/protobuf/generated_message_reflection.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/google/protobuf/generated_message_reflection.h')
-rw-r--r--include/google/protobuf/generated_message_reflection.h354
1 files changed, 0 insertions, 354 deletions
diff --git a/include/google/protobuf/generated_message_reflection.h b/include/google/protobuf/generated_message_reflection.h
deleted file mode 100644
index 334b2ccf1d..0000000000
--- a/include/google/protobuf/generated_message_reflection.h
+++ /dev/null
@@ -1,354 +0,0 @@
-// Protocol Buffers - Google's data interchange format
-// Copyright 2008 Google Inc. All rights reserved.
-// https://developers.google.com/protocol-buffers/
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the names of its
-// contributors may be used to endorse or promote products derived from
-// this software without specific prior written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-// Author: kenton@google.com (Kenton Varda)
-// Based on original Protocol Buffers design by
-// Sanjay Ghemawat, Jeff Dean, and others.
-//
-// This header is logically internal, but is made public because it is used
-// from protocol-compiler-generated code, which may reside in other components.
-
-#ifndef GOOGLE_PROTOBUF_GENERATED_MESSAGE_REFLECTION_H__
-#define GOOGLE_PROTOBUF_GENERATED_MESSAGE_REFLECTION_H__
-
-#include <google/protobuf/stubs/casts.h>
-#include <google/protobuf/stubs/common.h>
-#include <google/protobuf/stubs/once.h>
-#include <google/protobuf/port.h>
-#include <google/protobuf/descriptor.h>
-#include <google/protobuf/generated_enum_reflection.h>
-#include <google/protobuf/unknown_field_set.h>
-
-
-// Must be included last.
-#include <google/protobuf/port_def.inc>
-
-#ifdef SWIG
-#error "You cannot SWIG proto headers"
-#endif
-
-namespace google {
-namespace protobuf {
-class MapKey;
-class MapValueRef;
-class MessageLayoutInspector;
-class Message;
-struct Metadata;
-} // namespace protobuf
-} // namespace google
-
-namespace google {
-namespace protobuf {
-namespace internal {
-class DefaultEmptyOneof;
-// Defined in other files.
-class ExtensionSet; // extension_set.h
-class WeakFieldMap; // weak_field_map.h
-
-// This struct describes the internal layout of the message, hence this is
-// used to act on the message reflectively.
-// default_instance: The default instance of the message. This is only
-// used to obtain pointers to default instances of embedded
-// messages, which GetMessage() will return if the particular
-// sub-message has not been initialized yet. (Thus, all
-// embedded message fields *must* have non-null pointers
-// in the default instance.)
-// offsets: An array of ints giving the byte offsets.
-// For each oneof or weak field, the offset is relative to the
-// default_instance. These can be computed at compile time
-// using the
-// PROTO2_GENERATED_DEFAULT_ONEOF_FIELD_OFFSET()
-// macro. For each none oneof field, the offset is related to
-// the start of the message object. These can be computed at
-// compile time using the
-// PROTO2_GENERATED_MESSAGE_FIELD_OFFSET() macro.
-// Besides offsets for all fields, this array also contains
-// offsets for oneof unions. The offset of the i-th oneof union
-// is offsets[descriptor->field_count() + i].
-// has_bit_indices: Mapping from field indexes to their index in the has
-// bit array.
-// has_bits_offset: Offset in the message of an array of uint32s of size
-// descriptor->field_count()/32, rounded up. This is a
-// bitfield where each bit indicates whether or not the
-// corresponding field of the message has been initialized.
-// The bit for field index i is obtained by the expression:
-// has_bits[i / 32] & (1 << (i % 32))
-// unknown_fields_offset: Offset in the message of the UnknownFieldSet for
-// the message.
-// extensions_offset: Offset in the message of the ExtensionSet for the
-// message, or -1 if the message type has no extension
-// ranges.
-// oneof_case_offset: Offset in the message of an array of uint32s of
-// size descriptor->oneof_decl_count(). Each uint32_t
-// indicates what field is set for each oneof.
-// object_size: The size of a message object of this type, as measured
-// by sizeof().
-// arena_offset: If a message doesn't have a unknown_field_set that stores
-// the arena, it must have a direct pointer to the arena.
-// weak_field_map_offset: If the message proto has weak fields, this is the
-// offset of _weak_field_map_ in the generated proto. Otherwise
-// -1.
-struct ReflectionSchema {
- public:
- // Size of a google::protobuf::Message object of this type.
- uint32_t GetObjectSize() const { return static_cast<uint32_t>(object_size_); }
-
- bool InRealOneof(const FieldDescriptor* field) const {
- return field->containing_oneof() &&
- !field->containing_oneof()->is_synthetic();
- }
-
- // Offset of a non-oneof field. Getting a field offset is slightly more
- // efficient when we know statically that it is not a oneof field.
- uint32_t GetFieldOffsetNonOneof(const FieldDescriptor* field) const {
- GOOGLE_DCHECK(!InRealOneof(field));
- return OffsetValue(offsets_[field->index()], field->type());
- }
-
- // Offset of any field.
- uint32_t GetFieldOffset(const FieldDescriptor* field) const {
- if (InRealOneof(field)) {
- size_t offset =
- static_cast<size_t>(field->containing_type()->field_count()) +
- field->containing_oneof()->index();
- return OffsetValue(offsets_[offset], field->type());
- } else {
- return GetFieldOffsetNonOneof(field);
- }
- }
-
- bool IsFieldInlined(const FieldDescriptor* field) const {
- return Inlined(offsets_[field->index()], field->type());
- }
-
- uint32_t GetOneofCaseOffset(const OneofDescriptor* oneof_descriptor) const {
- return static_cast<uint32_t>(oneof_case_offset_) +
- static_cast<uint32_t>(
- static_cast<size_t>(oneof_descriptor->index()) *
- sizeof(uint32_t));
- }
-
- bool HasHasbits() const { return has_bits_offset_ != -1; }
-
- // Bit index within the bit array of hasbits. Bit order is low-to-high.
- uint32_t HasBitIndex(const FieldDescriptor* field) const {
- if (has_bits_offset_ == -1) return static_cast<uint32_t>(-1);
- GOOGLE_DCHECK(HasHasbits());
- return has_bit_indices_[field->index()];
- }
-
- // Byte offset of the hasbits array.
- uint32_t HasBitsOffset() const {
- GOOGLE_DCHECK(HasHasbits());
- return static_cast<uint32_t>(has_bits_offset_);
- }
-
- bool HasInlinedString() const { return inlined_string_donated_offset_ != -1; }
-
- // Bit index within the bit array of _inlined_string_donated_. Bit order is
- // low-to-high.
- uint32_t InlinedStringIndex(const FieldDescriptor* field) const {
- GOOGLE_DCHECK(HasInlinedString());
- return inlined_string_indices_[field->index()];
- }
-
- // Byte offset of the _inlined_string_donated_ array.
- uint32_t InlinedStringDonatedOffset() const {
- GOOGLE_DCHECK(HasInlinedString());
- return static_cast<uint32_t>(inlined_string_donated_offset_);
- }
-
- // The offset of the InternalMetadataWithArena member.
- // For Lite this will actually be an InternalMetadataWithArenaLite.
- // The schema doesn't contain enough information to distinguish between
- // these two cases.
- uint32_t GetMetadataOffset() const {
- return static_cast<uint32_t>(metadata_offset_);
- }
-
- // Whether this message has an ExtensionSet.
- bool HasExtensionSet() const { return extensions_offset_ != -1; }
-
- // The offset of the ExtensionSet in this message.
- uint32_t GetExtensionSetOffset() const {
- GOOGLE_DCHECK(HasExtensionSet());
- return static_cast<uint32_t>(extensions_offset_);
- }
-
- // The off set of WeakFieldMap when the message contains weak fields.
- // The default is 0 for now.
- int GetWeakFieldMapOffset() const { return weak_field_map_offset_; }
-
- bool IsDefaultInstance(const Message& message) const {
- return &message == default_instance_;
- }
-
- // Returns a pointer to the default value for this field. The size and type
- // of the underlying data depends on the field's type.
- const void* GetFieldDefault(const FieldDescriptor* field) const {
- return reinterpret_cast<const uint8_t*>(default_instance_) +
- OffsetValue(offsets_[field->index()], field->type());
- }
-
- // Returns true if the field is implicitly backed by LazyField.
- bool IsEagerlyVerifiedLazyField(const FieldDescriptor* field) const {
- GOOGLE_DCHECK_EQ(field->type(), FieldDescriptor::TYPE_MESSAGE);
- (void)field;
- return false;
- }
-
- bool IsFieldStripped(const FieldDescriptor* field) const {
- (void)field;
- return false;
- }
-
- bool IsMessageStripped(const Descriptor* descriptor) const {
- (void)descriptor;
- return false;
- }
-
-
- bool HasWeakFields() const { return weak_field_map_offset_ > 0; }
-
- // These members are intended to be private, but we cannot actually make them
- // private because this prevents us from using aggregate initialization of
- // them, ie.
- //
- // ReflectionSchema schema = {a, b, c, d, e, ...};
- // private:
- const Message* default_instance_;
- const uint32_t* offsets_;
- const uint32_t* has_bit_indices_;
- int has_bits_offset_;
- int metadata_offset_;
- int extensions_offset_;
- int oneof_case_offset_;
- int object_size_;
- int weak_field_map_offset_;
- const uint32_t* inlined_string_indices_;
- int inlined_string_donated_offset_;
-
- // We tag offset values to provide additional data about fields (such as
- // "unused" or "lazy" or "inlined").
- static uint32_t OffsetValue(uint32_t v, FieldDescriptor::Type type) {
- if (type == FieldDescriptor::TYPE_MESSAGE ||
- type == FieldDescriptor::TYPE_STRING ||
- type == FieldDescriptor::TYPE_BYTES) {
- return v & 0xFFFFFFFEu;
- }
- return v;
- }
-
- static bool Inlined(uint32_t v, FieldDescriptor::Type type) {
- if (type == FieldDescriptor::TYPE_STRING ||
- type == FieldDescriptor::TYPE_BYTES) {
- return (v & 1u) != 0u;
- } else {
- // Non string/byte fields are not inlined.
- return false;
- }
- }
-};
-
-// Structs that the code generator emits directly to describe a message.
-// These should never used directly except to build a ReflectionSchema
-// object.
-//
-// EXPERIMENTAL: these are changing rapidly, and may completely disappear
-// or merge with ReflectionSchema.
-struct MigrationSchema {
- int32_t offsets_index;
- int32_t has_bit_indices_index;
- int32_t inlined_string_indices_index;
- int object_size;
-};
-
-// This struct tries to reduce unnecessary padding.
-// The num_xxx might not be close to their respective pointer, but this saves
-// padding.
-struct PROTOBUF_EXPORT DescriptorTable {
- mutable bool is_initialized;
- bool is_eager;
- int size; // of serialized descriptor
- const char* descriptor;
- const char* filename;
- once_flag* once;
- const DescriptorTable* const* deps;
- int num_deps;
- int num_messages;
- const MigrationSchema* schemas;
- const Message* const* default_instances;
- const uint32_t* offsets;
- // update the following descriptor arrays.
- Metadata* file_level_metadata;
- const EnumDescriptor** file_level_enum_descriptors;
- const ServiceDescriptor** file_level_service_descriptors;
-};
-
-enum {
- // Tag used on offsets for fields that don't have a real offset.
- // For example, weak message fields go into the WeakFieldMap and not in an
- // actual field.
- kInvalidFieldOffsetTag = 0x40000000u,
-};
-
-// AssignDescriptors() pulls the compiled FileDescriptor from the DescriptorPool
-// and uses it to populate all of the global variables which store pointers to
-// the descriptor objects. It also constructs the reflection objects. It is
-// called the first time anyone calls descriptor() or GetReflection() on one of
-// the types defined in the file. AssignDescriptors() is thread-safe.
-void PROTOBUF_EXPORT AssignDescriptors(const DescriptorTable* table,
- bool eager = false);
-
-// Overload used to implement GetMetadataStatic in the generated code.
-// See comments in compiler/cpp/internal/file.cc as to why.
-// It takes a `Metadata` and returns it to allow for tail calls and reduce
-// binary size.
-Metadata PROTOBUF_EXPORT AssignDescriptors(const DescriptorTable* (*table)(),
- internal::once_flag* once,
- const Metadata& metadata);
-
-// These cannot be in lite so we put them in the reflection.
-PROTOBUF_EXPORT void UnknownFieldSetSerializer(const uint8_t* base,
- uint32_t offset, uint32_t tag,
- uint32_t has_offset,
- io::CodedOutputStream* output);
-
-struct PROTOBUF_EXPORT AddDescriptorsRunner {
- explicit AddDescriptorsRunner(const DescriptorTable* table);
-};
-
-} // namespace internal
-} // namespace protobuf
-} // namespace google
-
-#include <google/protobuf/port_undef.inc>
-
-#endif // GOOGLE_PROTOBUF_GENERATED_MESSAGE_REFLECTION_H__