Commit 22e1cfd8 authored by Jisi Liu's avatar Jisi Liu

Add deprecation annotation for oneof case.

parent 5ce724bc
...@@ -73,6 +73,14 @@ public class DeprecatedFieldTest extends TestCase { ...@@ -73,6 +73,14 @@ public class DeprecatedFieldTest extends TestCase {
} }
} }
public void testDeprecatedFieldInOneof() throws Exception {
Class<?> oneofCase = TestDeprecatedFields.OneofFieldsCase.class;
String name = "DEPRECATED_INT32_IN_ONEOF";
java.lang.reflect.Field enumValue = oneofCase.getField(name);
assertTrue("Enum value " + name + " should be deprecated.",
isDeprecated(enumValue));
}
private boolean isDeprecated(AnnotatedElement annotated) { private boolean isDeprecated(AnnotatedElement annotated) {
return annotated.isAnnotationPresent(Deprecated.class); return annotated.isAnnotationPresent(Deprecated.class);
} }
......
...@@ -437,11 +437,10 @@ void ImmutableMessageGenerator::Generate(io::Printer* printer) { ...@@ -437,11 +437,10 @@ void ImmutableMessageGenerator::Generate(io::Printer* printer) {
for (int j = 0; j < descriptor_->oneof_decl(i)->field_count(); j++) { for (int j = 0; j < descriptor_->oneof_decl(i)->field_count(); j++) {
const FieldDescriptor* field = descriptor_->oneof_decl(i)->field(j); const FieldDescriptor* field = descriptor_->oneof_decl(i)->field(j);
printer->Print( printer->Print(
"$field_name$($field_number$),\n", "$deprecation$$field_name$($field_number$),\n",
"field_name", "deprecation", field->options().deprecated() ? "@java.lang.Deprecated " : "",
ToUpper(field->name()), "field_name", ToUpper(field->name()),
"field_number", "field_number", SimpleItoa(field->number()));
SimpleItoa(field->number()));
} }
printer->Print( printer->Print(
"$cap_oneof_name$_NOT_SET(0);\n", "$cap_oneof_name$_NOT_SET(0);\n",
......
...@@ -189,6 +189,9 @@ message NestedTestAllTypes { ...@@ -189,6 +189,9 @@ message NestedTestAllTypes {
message TestDeprecatedFields { message TestDeprecatedFields {
optional int32 deprecated_int32 = 1 [deprecated=true]; optional int32 deprecated_int32 = 1 [deprecated=true];
oneof oneof_fields {
int32 deprecated_int32_in_oneof = 2 [deprecated=true];
}
} }
message TestDeprecatedMessage { message TestDeprecatedMessage {
......
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