Commit 64678265 authored by Adam Greene's avatar Adam Greene

allow a message field to be unset

parent 4b2a6328
...@@ -155,7 +155,9 @@ void native_slot_set_value_and_case(upb_fieldtype_t type, VALUE type_class, ...@@ -155,7 +155,9 @@ void native_slot_set_value_and_case(upb_fieldtype_t type, VALUE type_class,
break; break;
} }
case UPB_TYPE_MESSAGE: { case UPB_TYPE_MESSAGE: {
if (CLASS_OF(value) != type_class) { if (CLASS_OF(value) == CLASS_OF(Qnil)) {
value = Qnil;
} else if (CLASS_OF(value) != type_class) {
rb_raise(rb_eTypeError, rb_raise(rb_eTypeError,
"Invalid type %s to assign to submessage field.", "Invalid type %s to assign to submessage field.",
rb_class2name(CLASS_OF(value))); rb_class2name(CLASS_OF(value)));
......
...@@ -78,7 +78,7 @@ ...@@ -78,7 +78,7 @@
<dependency> <dependency>
<groupId>com.google.protobuf</groupId> <groupId>com.google.protobuf</groupId>
<artifactId>protobuf-java</artifactId> <artifactId>protobuf-java</artifactId>
<version>3.0.0-pre</version> <version>3.0.0-alpha-3-pre</version>
</dependency> </dependency>
</dependencies> </dependencies>
</project> </project>
...@@ -659,14 +659,14 @@ public class RubyMessage extends RubyObject { ...@@ -659,14 +659,14 @@ public class RubyMessage extends RubyObject {
} else { } else {
Descriptors.FieldDescriptor.Type fieldType = fieldDescriptor.getType(); Descriptors.FieldDescriptor.Type fieldType = fieldDescriptor.getType();
IRubyObject typeClass = context.runtime.getObject(); IRubyObject typeClass = context.runtime.getObject();
boolean addValue = true;
if (fieldType == Descriptors.FieldDescriptor.Type.MESSAGE) { if (fieldType == Descriptors.FieldDescriptor.Type.MESSAGE) {
typeClass = ((RubyDescriptor) getDescriptorForField(context, fieldDescriptor)).msgclass(context); typeClass = ((RubyDescriptor) getDescriptorForField(context, fieldDescriptor)).msgclass(context);
if (value.isNil()){
addValue = false;
}
} else if (fieldType == Descriptors.FieldDescriptor.Type.ENUM) { } else if (fieldType == Descriptors.FieldDescriptor.Type.ENUM) {
typeClass = ((RubyEnumDescriptor) getDescriptorForField(context, fieldDescriptor)).enummodule(context); typeClass = ((RubyEnumDescriptor) getDescriptorForField(context, fieldDescriptor)).enummodule(context);
}
Utils.checkType(context, fieldType, value, (RubyModule) typeClass);
// Convert integer enum to symbol
if (fieldType == Descriptors.FieldDescriptor.Type.ENUM) {
Descriptors.EnumDescriptor enumDescriptor = fieldDescriptor.getEnumType(); Descriptors.EnumDescriptor enumDescriptor = fieldDescriptor.getEnumType();
if (Utils.isRubyNum(value)) { if (Utils.isRubyNum(value)) {
Descriptors.EnumValueDescriptor val = Descriptors.EnumValueDescriptor val =
...@@ -674,7 +674,12 @@ public class RubyMessage extends RubyObject { ...@@ -674,7 +674,12 @@ public class RubyMessage extends RubyObject {
if (val.getIndex() != -1) value = context.runtime.newSymbol(val.getName()); if (val.getIndex() != -1) value = context.runtime.newSymbol(val.getName());
} }
} }
this.fields.put(fieldDescriptor, value); if (addValue) {
Utils.checkType(context, fieldType, value, (RubyModule) typeClass);
this.fields.put(fieldDescriptor, value);
} else {
this.fields.remove(fieldDescriptor);
}
} }
} }
return context.runtime.getNil(); return context.runtime.getNil();
......
...@@ -154,6 +154,8 @@ module BasicTest ...@@ -154,6 +154,8 @@ module BasicTest
assert m.optional_bytes == "world" assert m.optional_bytes == "world"
m.optional_msg = TestMessage2.new(:foo => 42) m.optional_msg = TestMessage2.new(:foo => 42)
assert m.optional_msg == TestMessage2.new(:foo => 42) assert m.optional_msg == TestMessage2.new(:foo => 42)
m.optional_msg = nil
assert m.optional_msg == nil
end end
def test_ctor_args def test_ctor_args
......
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