Commit 17d57dbb authored by liujisi@google.com's avatar liujisi@google.com

Add an intermediate method to propagate the friendship access to nested classes…

Add an intermediate method to propagate the friendship access to nested classes as a workaround for old compilers (e.g. gcc 3.4)
parent c345db7d
...@@ -2160,6 +2160,11 @@ class DescriptorBuilder { ...@@ -2160,6 +2160,11 @@ class DescriptorBuilder {
static inline bool get_is_placeholder(const Descriptor* descriptor) { static inline bool get_is_placeholder(const Descriptor* descriptor) {
return descriptor->is_placeholder_; return descriptor->is_placeholder_;
} }
static inline void assert_mutex_held(const DescriptorPool* pool) {
if (pool->mutex_ != NULL) {
pool->mutex_->AssertHeld();
}
}
// Must be run only after options have been interpreted. // Must be run only after options have been interpreted.
// //
...@@ -4338,9 +4343,7 @@ class DescriptorBuilder::OptionInterpreter::AggregateOptionFinder ...@@ -4338,9 +4343,7 @@ class DescriptorBuilder::OptionInterpreter::AggregateOptionFinder
virtual const FieldDescriptor* FindExtension( virtual const FieldDescriptor* FindExtension(
Message* message, const string& name) const { Message* message, const string& name) const {
if (builder_->pool_->mutex_ != NULL) { assert_mutex_held(builder_->pool_);
builder_->pool_->mutex_->AssertHeld();
}
Symbol result = builder_->LookupSymbolNoPlaceholder( Symbol result = builder_->LookupSymbolNoPlaceholder(
name, message->GetDescriptor()->full_name()); name, message->GetDescriptor()->full_name());
if (result.type == Symbol::FIELD && if (result.type == Symbol::FIELD &&
......
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