Commit 9b5fdb09 authored by Jon Skeet's avatar Jon Skeet

Ignore incomplete extensions when building a FileDescriptor

FileDescriptor construction uses an extension registry including extensions from imports. If these were created using an older version of protoc, the FieldDescriptor.Extension property may be null; we ignore such extensions rather than failing.
parent 7581fd5e
...@@ -282,6 +282,9 @@ namespace Google.Protobuf.Reflection ...@@ -282,6 +282,9 @@ namespace Google.Protobuf.Reflection
/// <summary> /// <summary>
/// Unmodifiable list of top-level extensions declared in this file. /// Unmodifiable list of top-level extensions declared in this file.
/// Note that some extensions may be incomplete (FieldDescriptor.Extension may be null)
/// if this descriptor was generated using a version of protoc that did not fully
/// support extensions in C#.
/// </summary> /// </summary>
public ExtensionCollection Extensions { get; } public ExtensionCollection Extensions { get; }
...@@ -456,6 +459,7 @@ namespace Google.Protobuf.Reflection ...@@ -456,6 +459,7 @@ namespace Google.Protobuf.Reflection
{ {
return descriptor.Extensions.UnorderedExtensions return descriptor.Extensions.UnorderedExtensions
.Select(s => s.Extension) .Select(s => s.Extension)
.Where(e => e != null)
.Concat(descriptor.Dependencies.Concat(descriptor.PublicDependencies).SelectMany(GetAllDependedExtensions)) .Concat(descriptor.Dependencies.Concat(descriptor.PublicDependencies).SelectMany(GetAllDependedExtensions))
.Concat(descriptor.MessageTypes.SelectMany(GetAllDependedExtensionsFromMessage)); .Concat(descriptor.MessageTypes.SelectMany(GetAllDependedExtensionsFromMessage));
} }
...@@ -464,6 +468,7 @@ namespace Google.Protobuf.Reflection ...@@ -464,6 +468,7 @@ namespace Google.Protobuf.Reflection
{ {
return descriptor.Extensions.UnorderedExtensions return descriptor.Extensions.UnorderedExtensions
.Select(s => s.Extension) .Select(s => s.Extension)
.Where(e => e != null)
.Concat(descriptor.NestedTypes.SelectMany(GetAllDependedExtensionsFromMessage)); .Concat(descriptor.NestedTypes.SelectMany(GetAllDependedExtensionsFromMessage));
} }
......
...@@ -215,7 +215,10 @@ namespace Google.Protobuf.Reflection ...@@ -215,7 +215,10 @@ namespace Google.Protobuf.Reflection
public FieldCollection Fields { get; } public FieldCollection Fields { get; }
/// <summary> /// <summary>
/// An unmodifiable list of extensions defined in this message's scrope /// An unmodifiable list of extensions defined in this message's scope.
/// Note that some extensions may be incomplete (FieldDescriptor.Extension may be null)
/// if they are declared in a file generated using a version of protoc that did not fully
/// support extensions in C#.
/// </summary> /// </summary>
public ExtensionCollection Extensions { get; } public ExtensionCollection Extensions { get; }
......
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