aboutsummaryrefslogtreecommitdiff
path: root/src/ProtocolBuffers
diff options
context:
space:
mode:
authorcsharptest <roger@csharptest.net>2010-11-07 17:25:47 -0600
committercsharptest <roger@csharptest.net>2010-11-07 17:25:47 -0600
commit80824a51c2730cad30395cf8c54b2a44546cd744 (patch)
tree1f523a817bd0059554fe1ee2690b4ea670de59b7 /src/ProtocolBuffers
parent980ba8dcd470ddb964a84da1317028dd81c1d60a (diff)
downloadprotobuf-80824a51c2730cad30395cf8c54b2a44546cd744.tar.gz
protobuf-80824a51c2730cad30395cf8c54b2a44546cd744.tar.bz2
protobuf-80824a51c2730cad30395cf8c54b2a44546cd744.zip
First Lite tests are passing.
Diffstat (limited to 'src/ProtocolBuffers')
-rw-r--r--src/ProtocolBuffers/Descriptors/EnumDescriptor.cs3
-rw-r--r--src/ProtocolBuffers/EnumLite.cs11
-rw-r--r--src/ProtocolBuffers/ExtendableBuilderLite.cs6
-rw-r--r--src/ProtocolBuffers/ExtendableMessageLite.cs4
-rw-r--r--src/ProtocolBuffers/GeneratedExtensionLite.cs73
5 files changed, 88 insertions, 9 deletions
diff --git a/src/ProtocolBuffers/Descriptors/EnumDescriptor.cs b/src/ProtocolBuffers/Descriptors/EnumDescriptor.cs
index c121c7e6..d6ef4e17 100644
--- a/src/ProtocolBuffers/Descriptors/EnumDescriptor.cs
+++ b/src/ProtocolBuffers/Descriptors/EnumDescriptor.cs
@@ -87,6 +87,9 @@ namespace Google.ProtocolBuffers.Descriptors {
return File.DescriptorPool.FindEnumValueByNumber(this, number);
}
+ IEnumLite IEnumLiteMap.FindValueByNumber(int number) {
+ return FindValueByNumber(number);
+ }
/// <summary>
/// Finds an enum value by name.
/// </summary>
diff --git a/src/ProtocolBuffers/EnumLite.cs b/src/ProtocolBuffers/EnumLite.cs
index 92187b38..a408fd43 100644
--- a/src/ProtocolBuffers/EnumLite.cs
+++ b/src/ProtocolBuffers/EnumLite.cs
@@ -57,11 +57,12 @@ namespace Google.ProtocolBuffers {
///</summary>
public interface IEnumLiteMap<T> : IEnumLiteMap
where T : IEnumLite {
- T FindValueByNumber(int number);
+ new T FindValueByNumber(int number);
}
public interface IEnumLiteMap {
bool IsValidValue(IEnumLite value);
+ IEnumLite FindValueByNumber(int number);
}
public class EnumLiteMap<TEnum> : IEnumLiteMap<IEnumLite>
@@ -88,12 +89,16 @@ namespace Google.ProtocolBuffers {
items.Add(evalue.ToInt32(CultureInfo.InvariantCulture), new EnumValue(evalue.ToInt32(CultureInfo.InvariantCulture)));
}
- IEnumLite IEnumLiteMap<IEnumLite>.FindValueByNumber(int number) {
+ IEnumLite IEnumLiteMap.FindValueByNumber(int number) {
+ return FindValueByNumber(number);
+ }
+
+ public IEnumLite FindValueByNumber(int number) {
IEnumLite val;
return items.TryGetValue(number, out val) ? val : null;
}
- bool IEnumLiteMap.IsValidValue(IEnumLite value) {
+ public bool IsValidValue(IEnumLite value) {
return items.ContainsKey(value.Number);
}
}
diff --git a/src/ProtocolBuffers/ExtendableBuilderLite.cs b/src/ProtocolBuffers/ExtendableBuilderLite.cs
index 815b51b3..df0323ba 100644
--- a/src/ProtocolBuffers/ExtendableBuilderLite.cs
+++ b/src/ProtocolBuffers/ExtendableBuilderLite.cs
@@ -76,7 +76,7 @@ namespace Google.ProtocolBuffers {
public TBuilder SetExtension<TExtension>(GeneratedExtensionLite<TMessage, TExtension> extension, TExtension value) {
ExtendableMessageLite<TMessage, TBuilder> message = MessageBeingBuilt;
message.VerifyExtensionContainingType(extension);
- message.Extensions[extension.Descriptor] = (value);
+ message.Extensions[extension.Descriptor] = extension.ToReflectionType(value);
return ThisBuilder;
}
@@ -86,7 +86,7 @@ namespace Google.ProtocolBuffers {
public TBuilder SetExtension<TExtension>(GeneratedExtensionLite<TMessage, IList<TExtension>> extension, int index, TExtension value) {
ExtendableMessageLite<TMessage, TBuilder> message = MessageBeingBuilt;
message.VerifyExtensionContainingType(extension);
- message.Extensions[extension.Descriptor, index] = (value);
+ message.Extensions[extension.Descriptor, index] = extension.SingularToReflectionType(value);
return ThisBuilder;
}
@@ -96,7 +96,7 @@ namespace Google.ProtocolBuffers {
public ExtendableBuilderLite<TMessage, TBuilder> AddExtension<TExtension>(GeneratedExtensionLite<TMessage, IList<TExtension>> extension, TExtension value) {
ExtendableMessageLite<TMessage, TBuilder> message = MessageBeingBuilt;
message.VerifyExtensionContainingType(extension);
- message.Extensions.AddRepeatedField(extension.Descriptor, (value));
+ message.Extensions.AddRepeatedField(extension.Descriptor, extension.SingularToReflectionType(value));
return this;
}
diff --git a/src/ProtocolBuffers/ExtendableMessageLite.cs b/src/ProtocolBuffers/ExtendableMessageLite.cs
index 4cd90e48..fc2ccb6c 100644
--- a/src/ProtocolBuffers/ExtendableMessageLite.cs
+++ b/src/ProtocolBuffers/ExtendableMessageLite.cs
@@ -74,7 +74,7 @@ namespace Google.ProtocolBuffers {
if (value == null) {
return extension.DefaultValue;
} else {
- return (TExtension)value;
+ return (TExtension)extension.FromReflectionType(value);
}
}
@@ -83,7 +83,7 @@ namespace Google.ProtocolBuffers {
/// </summary>
public TExtension GetExtension<TExtension>(GeneratedExtensionLite<TMessage, IList<TExtension>> extension, int index) {
VerifyExtensionContainingType(extension);
- return (TExtension)extensions[extension.Descriptor, index];
+ return (TExtension)extension.SingularFromReflectionType(extensions[extension.Descriptor, index]);
}
/// <summary>
diff --git a/src/ProtocolBuffers/GeneratedExtensionLite.cs b/src/ProtocolBuffers/GeneratedExtensionLite.cs
index e27dff72..c2ba5627 100644
--- a/src/ProtocolBuffers/GeneratedExtensionLite.cs
+++ b/src/ProtocolBuffers/GeneratedExtensionLite.cs
@@ -33,6 +33,7 @@
#endregion
using System;
+using System.Collections;
using System.Collections.Generic;
using Google.ProtocolBuffers.Collections;
using Google.ProtocolBuffers.Descriptors;
@@ -224,8 +225,78 @@ namespace Google.ProtocolBuffers {
}
}
+ /// <summary>
+ /// Converts from the type used by the native accessors to the type
+ /// used by reflection accessors. For example, the reflection accessors
+ /// for enums use EnumValueDescriptors but the native accessors use
+ /// the generated enum type.
+ /// </summary>
+ public object ToReflectionType(object value) {
+ if (descriptor.IsRepeated) {
+ if (descriptor.MappedType == MappedType.Enum) {
+ // Must convert the whole list.
+ IList<object> result = new List<object>();
+ foreach (object element in (IEnumerable)value) {
+ result.Add(SingularToReflectionType(element));
+ }
+ return result;
+ } else {
+ return value;
+ }
+ } else {
+ return SingularToReflectionType(value);
+ }
+ }
+
+ /// <summary>
+ /// Like ToReflectionType(object) but for a single element.
+ /// </summary>
+ internal Object SingularToReflectionType(object value) {
+ return descriptor.MappedType == MappedType.Enum
+ ? descriptor.EnumType.FindValueByNumber((int)value)
+ : value;
+ }
+
+ public object FromReflectionType(object value) {
+ if (descriptor.IsRepeated) {
+ if (Descriptor.MappedType == MappedType.Message ||
+ Descriptor.MappedType == MappedType.Enum) {
+ // Must convert the whole list.
+ List<TExtensionType> result = new List<TExtensionType>();
+ foreach (object element in (IEnumerable)value) {
+ result.Add((TExtensionType)SingularFromReflectionType(element));
+ }
+ return result;
+ } else {
+ return value;
+ }
+ } else {
+ return SingularFromReflectionType(value);
+ }
+ }
+
public object SingularFromReflectionType(object value) {
- return value;
+ switch (Descriptor.MappedType) {
+ case MappedType.Message:
+ if (value is TExtensionType) {
+ return value;
+ } else {
+ // It seems the copy of the embedded message stored inside the
+ // extended message is not of the exact type the user was
+ // expecting. This can happen if a user defines a
+ // GeneratedExtension manually and gives it a different type.
+ // This should not happen in normal use. But, to be nice, we'll
+ // copy the message to whatever type the caller was expecting.
+ return MessageDefaultInstance.WeakCreateBuilderForType()
+ .WeakMergeFrom((IMessageLite)value).WeakBuild();
+ }
+ case MappedType.Enum:
+ // Just return a boxed int - that can be unboxed to the enum
+ IEnumLite enumValue = (IEnumLite)value;
+ return enumValue.Number;
+ default:
+ return value;
+ }
}
}
} \ No newline at end of file