aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJie Luo <anandolee@gmail.com>2015-05-01 10:50:22 -0700
committerJie Luo <anandolee@gmail.com>2015-05-01 10:50:22 -0700
commit447de3ad6e3fc21d1f5c4f3e50c63b938873a063 (patch)
tree01e4df4def2986b5c029a67bd83da3eb3263e439 /src
parent0884b77975146be5d0557b254fbeab940cda641a (diff)
parentea48104cddf9dba8a7e525eebbccfe98fd1e1eff (diff)
downloadprotobuf-447de3ad6e3fc21d1f5c4f3e50c63b938873a063.tar.gz
protobuf-447de3ad6e3fc21d1f5c4f3e50c63b938873a063.tar.bz2
protobuf-447de3ad6e3fc21d1f5c4f3e50c63b938873a063.zip
Merge pull request #321 from anandolee/csharp
Field Presence for Protocol Buffer C# Proto3
Diffstat (limited to 'src')
-rw-r--r--src/google/protobuf/compiler/csharp/csharp_enum_field.cc79
-rw-r--r--src/google/protobuf/compiler/csharp/csharp_helpers.h4
-rw-r--r--src/google/protobuf/compiler/csharp/csharp_message.cc4
-rw-r--r--src/google/protobuf/compiler/csharp/csharp_primitive_field.cc84
4 files changed, 129 insertions, 42 deletions
diff --git a/src/google/protobuf/compiler/csharp/csharp_enum_field.cc b/src/google/protobuf/compiler/csharp/csharp_enum_field.cc
index d5b1b477..34d1c5c6 100644
--- a/src/google/protobuf/compiler/csharp/csharp_enum_field.cc
+++ b/src/google/protobuf/compiler/csharp/csharp_enum_field.cc
@@ -56,13 +56,17 @@ EnumFieldGenerator::~EnumFieldGenerator() {
}
void EnumFieldGenerator::GenerateMembers(Writer* writer) {
- writer->WriteLine("private bool has$0$;", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("private bool has$0$;", property_name());
+ }
writer->WriteLine("private $0$ $1$_ = $2$;", type_name(), name(),
default_value());
AddDeprecatedFlag(writer);
- writer->WriteLine("public bool Has$0$ {", property_name());
- writer->WriteLine(" get { return has$0$; }", property_name());
- writer->WriteLine("}");
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("public bool Has$0$ {", property_name());
+ writer->WriteLine(" get { return has$0$; }", property_name());
+ writer->WriteLine("}");
+ }
AddPublicMemberAttributes(writer);
writer->WriteLine("public $0$ $1$ {", type_name(), property_name());
writer->WriteLine(" get { return $0$_; }", name());
@@ -71,9 +75,11 @@ void EnumFieldGenerator::GenerateMembers(Writer* writer) {
void EnumFieldGenerator::GenerateBuilderMembers(Writer* writer) {
AddDeprecatedFlag(writer);
- writer->WriteLine("public bool Has$0$ {", property_name());
- writer->WriteLine(" get { return result.has$0$; }", property_name());
- writer->WriteLine("}");
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("public bool Has$0$ {", property_name());
+ writer->WriteLine(" get { return result.has$0$; }", property_name());
+ writer->WriteLine("}");
+ }
AddPublicMemberAttributes(writer);
writer->WriteLine("public $0$ $1$ {", type_name(), property_name());
writer->WriteLine(" get { return result.$0$; }", property_name());
@@ -83,21 +89,29 @@ void EnumFieldGenerator::GenerateBuilderMembers(Writer* writer) {
writer->WriteLine("public Builder Set$0$($1$ value) {", property_name(),
type_name());
writer->WriteLine(" PrepareBuilder();");
- writer->WriteLine(" result.has$0$ = true;", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine(" result.has$0$ = true;", property_name());
+ }
writer->WriteLine(" result.$0$_ = value;", name());
writer->WriteLine(" return this;");
writer->WriteLine("}");
AddDeprecatedFlag(writer);
writer->WriteLine("public Builder Clear$0$() {", property_name());
writer->WriteLine(" PrepareBuilder();");
- writer->WriteLine(" result.has$0$ = false;", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine(" result.has$0$ = false;", property_name());
+ }
writer->WriteLine(" result.$0$_ = $1$;", name(), default_value());
writer->WriteLine(" return this;");
writer->WriteLine("}");
}
void EnumFieldGenerator::GenerateMergingCode(Writer* writer) {
- writer->WriteLine("if (other.Has$0$) {", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("if (other.Has$0$) {", property_name());
+ } else {
+ writer->WriteLine("if (other.$0$ != $1$) {", property_name(), default_value());
+ }
writer->WriteLine(" $0$ = other.$0$;", property_name());
writer->WriteLine("}");
}
@@ -110,7 +124,9 @@ void EnumFieldGenerator::GenerateParsingCode(Writer* writer) {
writer->WriteLine("object unknown;");
writer->WriteLine("if(input.ReadEnum(ref result.$0$_, out unknown)) {",
name());
- writer->WriteLine(" result.has$0$ = true;", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine(" result.has$0$ = true;", property_name());
+ }
writer->WriteLine("} else if(unknown is int) {");
if (!use_lite_runtime()) {
writer->WriteLine(" if (unknownFields == null) {"); // First unknown field - create builder now
@@ -125,7 +141,11 @@ void EnumFieldGenerator::GenerateParsingCode(Writer* writer) {
}
void EnumFieldGenerator::GenerateSerializationCode(Writer* writer) {
- writer->WriteLine("if (has$0$) {", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("if (has$0$) {", property_name());
+ } else {
+ writer->WriteLine("if ($0$ != $1$) {", property_name(), default_value());
+ }
writer->WriteLine(
" output.WriteEnum($0$, field_names[$2$], (int) $1$, $1$);", number(),
property_name(), field_ordinal());
@@ -133,7 +153,11 @@ void EnumFieldGenerator::GenerateSerializationCode(Writer* writer) {
}
void EnumFieldGenerator::GenerateSerializedSizeCode(Writer* writer) {
- writer->WriteLine("if (has$0$) {", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("if (has$0$) {", property_name());
+ } else {
+ writer->WriteLine("if ($0$ != $1$) {", property_name(), default_value());
+ }
writer->WriteLine(
" size += pb::CodedOutputStream.ComputeEnumSize($0$, (int) $1$);",
number(), property_name());
@@ -141,17 +165,32 @@ void EnumFieldGenerator::GenerateSerializedSizeCode(Writer* writer) {
}
void EnumFieldGenerator::WriteHash(Writer* writer) {
- writer->WriteLine("if (has$0$) hash ^= $1$_.GetHashCode();", property_name(),
- name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("if (has$0$) {", property_name());
+ } else {
+ writer->WriteLine("if ($0$ != $1$) {", property_name(), default_value());
+ }
+ writer->WriteLine(" hash ^= $0$_.GetHashCode();", name());
+ writer->WriteLine("}");
}
void EnumFieldGenerator::WriteEquals(Writer* writer) {
- writer->WriteLine(
- "if (has$0$ != other.has$0$ || (has$0$ && !$1$_.Equals(other.$1$_))) return false;",
- property_name(), name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine(
+ "if (has$0$ != other.has$0$ || (has$0$ && !$1$_.Equals(other.$1$_))) return false;",
+ property_name(), name());
+ } else {
+ writer->WriteLine(
+ "if (!$0$_.Equals(other.$0$_)) return false;", name());
+ }
}
void EnumFieldGenerator::WriteToString(Writer* writer) {
- writer->WriteLine("PrintField(\"$0$\", has$1$, $2$_, writer);",
- descriptor_->name(), property_name(), name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("PrintField(\"$0$\", has$1$, $2$_, writer);",
+ descriptor_->name(), property_name(), name());
+ } else {
+ writer->WriteLine("PrintField(\"$0$\", $1$_, writer);",
+ descriptor_->name(), name());
+ }
}
} // namespace csharp
diff --git a/src/google/protobuf/compiler/csharp/csharp_helpers.h b/src/google/protobuf/compiler/csharp/csharp_helpers.h
index 8fdd214e..bc77f43a 100644
--- a/src/google/protobuf/compiler/csharp/csharp_helpers.h
+++ b/src/google/protobuf/compiler/csharp/csharp_helpers.h
@@ -101,6 +101,10 @@ FieldGeneratorBase* CreateFieldGenerator(const FieldDescriptor* descriptor, int
bool HasRequiredFields(const Descriptor* descriptor);
+inline bool SupportFieldPresence(const FileDescriptor* file) {
+ return file->syntax() != FileDescriptor::SYNTAX_PROTO3;
+}
+
} // namespace csharp
} // namespace compiler
} // namespace protobuf
diff --git a/src/google/protobuf/compiler/csharp/csharp_message.cc b/src/google/protobuf/compiler/csharp/csharp_message.cc
index f7c8ddfb..36f41c70 100644
--- a/src/google/protobuf/compiler/csharp/csharp_message.cc
+++ b/src/google/protobuf/compiler/csharp/csharp_message.cc
@@ -279,7 +279,9 @@ void MessageGenerator::Generate(Writer* writer) {
}
if (optimize_speed()) {
- GenerateIsInitialized(writer);
+ if (SupportFieldPresence(descriptor_->file())) {
+ GenerateIsInitialized(writer);
+ }
GenerateMessageSerializationMethods(writer);
}
if (use_lite_runtime()) {
diff --git a/src/google/protobuf/compiler/csharp/csharp_primitive_field.cc b/src/google/protobuf/compiler/csharp/csharp_primitive_field.cc
index 54287b41..a193afda 100644
--- a/src/google/protobuf/compiler/csharp/csharp_primitive_field.cc
+++ b/src/google/protobuf/compiler/csharp/csharp_primitive_field.cc
@@ -57,13 +57,17 @@ PrimitiveFieldGenerator::~PrimitiveFieldGenerator() {
}
void PrimitiveFieldGenerator::GenerateMembers(Writer* writer) {
- writer->WriteLine("private bool has$0$;", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("private bool has$0$;", property_name());
+ }
writer->WriteLine("private $0$ $1$_$2$;", type_name(), name(),
has_default_value() ? " = " + default_value() : "");
AddDeprecatedFlag(writer);
- writer->WriteLine("public bool Has$0$ {", property_name());
- writer->WriteLine(" get { return has$0$; }", property_name());
- writer->WriteLine("}");
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("public bool Has$0$ {", property_name());
+ writer->WriteLine(" get { return has$0$; }", property_name());
+ writer->WriteLine("}");
+ }
AddPublicMemberAttributes(writer);
writer->WriteLine("public $0$ $1$ {", type_name(), property_name());
writer->WriteLine(" get { return $0$_; }", name());
@@ -72,9 +76,11 @@ void PrimitiveFieldGenerator::GenerateMembers(Writer* writer) {
void PrimitiveFieldGenerator::GenerateBuilderMembers(Writer* writer) {
AddDeprecatedFlag(writer);
- writer->WriteLine("public bool Has$0$ {", property_name());
- writer->WriteLine(" get { return result.has$0$; }", property_name());
- writer->WriteLine("}");
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("public bool Has$0$ {", property_name());
+ writer->WriteLine(" get { return result.has$0$; }", property_name());
+ writer->WriteLine("}");
+ }
AddPublicMemberAttributes(writer);
writer->WriteLine("public $0$ $1$ {", type_name(), property_name());
writer->WriteLine(" get { return result.$0$; }", property_name());
@@ -85,21 +91,29 @@ void PrimitiveFieldGenerator::GenerateBuilderMembers(Writer* writer) {
type_name());
AddNullCheck(writer);
writer->WriteLine(" PrepareBuilder();");
- writer->WriteLine(" result.has$0$ = true;", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine(" result.has$0$ = true;", property_name());
+ }
writer->WriteLine(" result.$0$_ = value;", name());
writer->WriteLine(" return this;");
writer->WriteLine("}");
AddDeprecatedFlag(writer);
writer->WriteLine("public Builder Clear$0$() {", property_name());
writer->WriteLine(" PrepareBuilder();");
- writer->WriteLine(" result.has$0$ = false;", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine(" result.has$0$ = false;", property_name());
+ }
writer->WriteLine(" result.$0$_ = $1$;", name(), default_value());
writer->WriteLine(" return this;");
writer->WriteLine("}");
}
void PrimitiveFieldGenerator::GenerateMergingCode(Writer* writer) {
- writer->WriteLine("if (other.Has$0$) {", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("if (other.Has$0$) {", property_name());
+ } else {
+ writer->WriteLine("if (other.$0$ != $1$) {", property_name(), default_value());
+ }
writer->WriteLine(" $0$ = other.$0$;", property_name());
writer->WriteLine("}");
}
@@ -109,12 +123,21 @@ void PrimitiveFieldGenerator::GenerateBuildingCode(Writer* writer) {
}
void PrimitiveFieldGenerator::GenerateParsingCode(Writer* writer) {
- writer->WriteLine("result.has$0$ = input.Read$1$(ref result.$2$_);",
- property_name(), capitalized_type_name(), name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("result.has$0$ = input.Read$1$(ref result.$2$_);",
+ property_name(), capitalized_type_name(), name());
+ } else {
+ writer->WriteLine("input.Read$0$(ref result.$1$_);",
+ capitalized_type_name(), name());
+ }
}
void PrimitiveFieldGenerator::GenerateSerializationCode(Writer* writer) {
- writer->WriteLine("if (has$0$) {", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("if (has$0$) {", property_name());
+ } else {
+ writer->WriteLine("if ($0$ != $1$) {", property_name(), default_value());
+ }
writer->WriteLine(" output.Write$0$($1$, field_names[$3$], $2$);",
capitalized_type_name(), number(), property_name(),
field_ordinal());
@@ -122,24 +145,43 @@ void PrimitiveFieldGenerator::GenerateSerializationCode(Writer* writer) {
}
void PrimitiveFieldGenerator::GenerateSerializedSizeCode(Writer* writer) {
- writer->WriteLine("if (has$0$) {", property_name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("if (has$0$) {", property_name());
+ } else {
+ writer->WriteLine("if ($0$ != $1$) {", property_name(), default_value());
+ }
writer->WriteLine(" size += pb::CodedOutputStream.Compute$0$Size($1$, $2$);",
capitalized_type_name(), number(), property_name());
writer->WriteLine("}");
}
void PrimitiveFieldGenerator::WriteHash(Writer* writer) {
- writer->WriteLine("if (has$0$) hash ^= $1$_.GetHashCode();", property_name(),
- name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("if (has$0$) {", property_name());
+ } else {
+ writer->WriteLine("if ($0$ != $1$) {", property_name(), default_value());
+ }
+ writer->WriteLine(" hash ^= $0$_.GetHashCode();", name());
+ writer->WriteLine("}");
}
void PrimitiveFieldGenerator::WriteEquals(Writer* writer) {
- writer->WriteLine(
- "if (has$0$ != other.has$0$ || (has$0$ && !$1$_.Equals(other.$1$_))) return false;",
- property_name(), name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine(
+ "if (has$0$ != other.has$0$ || (has$0$ && !$1$_.Equals(other.$1$_))) return false;",
+ property_name(), name());
+ } else {
+ writer->WriteLine(
+ "if (!$0$_.Equals(other.$0$_)) return false;", name());
+ }
}
void PrimitiveFieldGenerator::WriteToString(Writer* writer) {
- writer->WriteLine("PrintField(\"$0$\", has$1$, $2$_, writer);",
- descriptor_->name(), property_name(), name());
+ if (SupportFieldPresence(descriptor_->file())) {
+ writer->WriteLine("PrintField(\"$0$\", has$1$, $2$_, writer);",
+ descriptor_->name(), property_name(), name());
+ } else {
+ writer->WriteLine("PrintField(\"$0$\", $1$_, writer);",
+ descriptor_->name(), name());
+ }
}
} // namespace csharp