|
@@ -1015,7 +1015,7 @@ struct FieldNumberSorter {
|
|
|
}
|
|
|
};
|
|
|
|
|
|
-inline bool IsIndexInHasBitSet(const uint32* has_bit_set,
|
|
|
+bool IsIndexInHasBitSet(const uint32* has_bit_set,
|
|
|
uint32 has_bit_index) {
|
|
|
GOOGLE_DCHECK_NE(has_bit_index, ~0u);
|
|
|
return ((has_bit_set[has_bit_index / 32] >> (has_bit_index % 32)) &
|
|
@@ -1288,7 +1288,7 @@ void Reflection::AddString(Message* message, const FieldDescriptor* field,
|
|
|
|
|
|
// -------------------------------------------------------------------
|
|
|
|
|
|
-inline bool CreateUnknownEnumValues(const FileDescriptor* file) {
|
|
|
+bool CreateUnknownEnumValues(const FileDescriptor* file) {
|
|
|
return file->syntax() == FileDescriptor::SYNTAX_PROTO3;
|
|
|
}
|
|
|
|
|
@@ -1864,62 +1864,62 @@ Type* Reflection::MutableRaw(Message* message,
|
|
|
return GetPointerAtOffset<Type>(message, schema_.GetFieldOffset(field));
|
|
|
}
|
|
|
|
|
|
-inline const uint32* Reflection::GetHasBits(const Message& message) const {
|
|
|
+const uint32* Reflection::GetHasBits(const Message& message) const {
|
|
|
GOOGLE_DCHECK(schema_.HasHasbits());
|
|
|
return &GetConstRefAtOffset<uint32>(message, schema_.HasBitsOffset());
|
|
|
}
|
|
|
|
|
|
-inline uint32* Reflection::MutableHasBits(Message* message) const {
|
|
|
+uint32* Reflection::MutableHasBits(Message* message) const {
|
|
|
GOOGLE_DCHECK(schema_.HasHasbits());
|
|
|
return GetPointerAtOffset<uint32>(message, schema_.HasBitsOffset());
|
|
|
}
|
|
|
|
|
|
-inline uint32 Reflection::GetOneofCase(
|
|
|
+uint32 Reflection::GetOneofCase(
|
|
|
const Message& message, const OneofDescriptor* oneof_descriptor) const {
|
|
|
return GetConstRefAtOffset<uint32>(
|
|
|
message, schema_.GetOneofCaseOffset(oneof_descriptor));
|
|
|
}
|
|
|
|
|
|
-inline uint32* Reflection::MutableOneofCase(
|
|
|
+uint32* Reflection::MutableOneofCase(
|
|
|
Message* message, const OneofDescriptor* oneof_descriptor) const {
|
|
|
return GetPointerAtOffset<uint32>(
|
|
|
message, schema_.GetOneofCaseOffset(oneof_descriptor));
|
|
|
}
|
|
|
|
|
|
-inline const ExtensionSet& Reflection::GetExtensionSet(
|
|
|
+const ExtensionSet& Reflection::GetExtensionSet(
|
|
|
const Message& message) const {
|
|
|
return GetConstRefAtOffset<ExtensionSet>(message,
|
|
|
schema_.GetExtensionSetOffset());
|
|
|
}
|
|
|
|
|
|
-inline ExtensionSet* Reflection::MutableExtensionSet(Message* message) const {
|
|
|
+ExtensionSet* Reflection::MutableExtensionSet(Message* message) const {
|
|
|
return GetPointerAtOffset<ExtensionSet>(message,
|
|
|
schema_.GetExtensionSetOffset());
|
|
|
}
|
|
|
|
|
|
-inline Arena* Reflection::GetArena(Message* message) const {
|
|
|
+Arena* Reflection::GetArena(Message* message) const {
|
|
|
return GetInternalMetadataWithArena(*message).arena();
|
|
|
}
|
|
|
|
|
|
-inline const InternalMetadataWithArena&
|
|
|
+const InternalMetadataWithArena&
|
|
|
Reflection::GetInternalMetadataWithArena(const Message& message) const {
|
|
|
return GetConstRefAtOffset<InternalMetadataWithArena>(
|
|
|
message, schema_.GetMetadataOffset());
|
|
|
}
|
|
|
|
|
|
-inline InternalMetadataWithArena* Reflection::MutableInternalMetadataWithArena(
|
|
|
+InternalMetadataWithArena* Reflection::MutableInternalMetadataWithArena(
|
|
|
Message* message) const {
|
|
|
return GetPointerAtOffset<InternalMetadataWithArena>(
|
|
|
message, schema_.GetMetadataOffset());
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline const Type& Reflection::DefaultRaw(const FieldDescriptor* field) const {
|
|
|
+const Type& Reflection::DefaultRaw(const FieldDescriptor* field) const {
|
|
|
return *reinterpret_cast<const Type*>(schema_.GetFieldDefault(field));
|
|
|
}
|
|
|
|
|
|
// Simple accessors for manipulating has_bits_.
|
|
|
-inline bool Reflection::HasBit(const Message& message,
|
|
|
+bool Reflection::HasBit(const Message& message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
GOOGLE_DCHECK(!field->options().weak());
|
|
|
if (schema_.HasHasbits()) {
|
|
@@ -1980,7 +1980,7 @@ inline bool Reflection::HasBit(const Message& message,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-inline void Reflection::SetBit(Message* message,
|
|
|
+void Reflection::SetBit(Message* message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
GOOGLE_DCHECK(!field->options().weak());
|
|
|
if (!schema_.HasHasbits()) {
|
|
@@ -1991,7 +1991,7 @@ inline void Reflection::SetBit(Message* message,
|
|
|
(static_cast<uint32>(1) << (index % 32));
|
|
|
}
|
|
|
|
|
|
-inline void Reflection::ClearBit(Message* message,
|
|
|
+void Reflection::ClearBit(Message* message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
GOOGLE_DCHECK(!field->options().weak());
|
|
|
if (!schema_.HasHasbits()) {
|
|
@@ -2002,7 +2002,7 @@ inline void Reflection::ClearBit(Message* message,
|
|
|
~(static_cast<uint32>(1) << (index % 32));
|
|
|
}
|
|
|
|
|
|
-inline void Reflection::SwapBit(Message* message1, Message* message2,
|
|
|
+void Reflection::SwapBit(Message* message1, Message* message2,
|
|
|
const FieldDescriptor* field) const {
|
|
|
GOOGLE_DCHECK(!field->options().weak());
|
|
|
if (!schema_.HasHasbits()) {
|
|
@@ -2026,24 +2026,24 @@ bool Reflection::HasOneof(const Message& message,
|
|
|
return (GetOneofCase(message, oneof_descriptor) > 0);
|
|
|
}
|
|
|
|
|
|
-inline bool Reflection::HasOneofField(const Message& message,
|
|
|
+bool Reflection::HasOneofField(const Message& message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
return (GetOneofCase(message, field->containing_oneof()) == field->number());
|
|
|
}
|
|
|
|
|
|
-inline void Reflection::SetOneofCase(Message* message,
|
|
|
+void Reflection::SetOneofCase(Message* message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
*MutableOneofCase(message, field->containing_oneof()) = field->number();
|
|
|
}
|
|
|
|
|
|
-inline void Reflection::ClearOneofField(Message* message,
|
|
|
+void Reflection::ClearOneofField(Message* message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
if (HasOneofField(*message, field)) {
|
|
|
ClearOneof(message, field->containing_oneof());
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-inline void Reflection::ClearOneof(
|
|
|
+void Reflection::ClearOneof(
|
|
|
Message* message, const OneofDescriptor* oneof_descriptor) const {
|
|
|
// TODO(jieluo): Consider to cache the unused object instead of deleting
|
|
|
// it. It will be much faster if an application switches a lot from
|
|
@@ -2117,13 +2117,13 @@ void* Reflection::MutableRawRepeatedString(Message* message,
|
|
|
// template instance is only called from one location. These are
|
|
|
// used for all types except messages.
|
|
|
template <typename Type>
|
|
|
-inline const Type& Reflection::GetField(const Message& message,
|
|
|
+const Type& Reflection::GetField(const Message& message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
return GetRaw<Type>(message, field);
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline void Reflection::SetField(Message* message, const FieldDescriptor* field,
|
|
|
+void Reflection::SetField(Message* message, const FieldDescriptor* field,
|
|
|
const Type& value) const {
|
|
|
if (field->containing_oneof() && !HasOneofField(*message, field)) {
|
|
|
ClearOneof(message, field->containing_oneof());
|
|
@@ -2134,7 +2134,7 @@ inline void Reflection::SetField(Message* message, const FieldDescriptor* field,
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline Type* Reflection::MutableField(Message* message,
|
|
|
+Type* Reflection::MutableField(Message* message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
field->containing_oneof() ? SetOneofCase(message, field)
|
|
|
: SetBit(message, field);
|
|
@@ -2142,28 +2142,28 @@ inline Type* Reflection::MutableField(Message* message,
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline const Type& Reflection::GetRepeatedField(const Message& message,
|
|
|
+const Type& Reflection::GetRepeatedField(const Message& message,
|
|
|
const FieldDescriptor* field,
|
|
|
int index) const {
|
|
|
return GetRaw<RepeatedField<Type> >(message, field).Get(index);
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline const Type& Reflection::GetRepeatedPtrField(const Message& message,
|
|
|
+const Type& Reflection::GetRepeatedPtrField(const Message& message,
|
|
|
const FieldDescriptor* field,
|
|
|
int index) const {
|
|
|
return GetRaw<RepeatedPtrField<Type> >(message, field).Get(index);
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline void Reflection::SetRepeatedField(Message* message,
|
|
|
+void Reflection::SetRepeatedField(Message* message,
|
|
|
const FieldDescriptor* field,
|
|
|
int index, Type value) const {
|
|
|
MutableRaw<RepeatedField<Type> >(message, field)->Set(index, value);
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline Type* Reflection::MutableRepeatedField(Message* message,
|
|
|
+Type* Reflection::MutableRepeatedField(Message* message,
|
|
|
const FieldDescriptor* field,
|
|
|
int index) const {
|
|
|
RepeatedPtrField<Type>* repeated =
|
|
@@ -2172,13 +2172,13 @@ inline Type* Reflection::MutableRepeatedField(Message* message,
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline void Reflection::AddField(Message* message, const FieldDescriptor* field,
|
|
|
+void Reflection::AddField(Message* message, const FieldDescriptor* field,
|
|
|
const Type& value) const {
|
|
|
MutableRaw<RepeatedField<Type> >(message, field)->Add(value);
|
|
|
}
|
|
|
|
|
|
template <typename Type>
|
|
|
-inline Type* Reflection::AddField(Message* message,
|
|
|
+Type* Reflection::AddField(Message* message,
|
|
|
const FieldDescriptor* field) const {
|
|
|
RepeatedPtrField<Type>* repeated =
|
|
|
MutableRaw<RepeatedPtrField<Type> >(message, field);
|