| Index: third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_enum.cc
|
| diff --git a/third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_enum.cc b/third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_enum.cc
|
| index 566819898b1e31dc032804a4dc2b8c0eee86680c..bdfcc2beecb8c8effdb3d0407fc824dbb9787ede 100644
|
| --- a/third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_enum.cc
|
| +++ b/third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_enum.cc
|
| @@ -41,6 +41,7 @@
|
| #include <google/protobuf/compiler/csharp/csharp_doc_comment.h>
|
| #include <google/protobuf/compiler/csharp/csharp_enum.h>
|
| #include <google/protobuf/compiler/csharp/csharp_helpers.h>
|
| +#include <google/protobuf/compiler/csharp/csharp_options.h>
|
|
|
| using google::protobuf::internal::scoped_ptr;
|
|
|
| @@ -49,8 +50,8 @@ namespace protobuf {
|
| namespace compiler {
|
| namespace csharp {
|
|
|
| -EnumGenerator::EnumGenerator(const EnumDescriptor* descriptor) :
|
| - SourceGeneratorBase(descriptor->file()),
|
| +EnumGenerator::EnumGenerator(const EnumDescriptor* descriptor, const Options* options) :
|
| + SourceGeneratorBase(descriptor->file(), options),
|
| descriptor_(descriptor) {
|
| }
|
|
|
| @@ -64,11 +65,24 @@ void EnumGenerator::Generate(io::Printer* printer) {
|
| "access_level", class_access_level(),
|
| "name", descriptor_->name());
|
| printer->Indent();
|
| + std::set<string> used_names;
|
| for (int i = 0; i < descriptor_->value_count(); i++) {
|
| WriteEnumValueDocComment(printer, descriptor_->value(i));
|
| - printer->Print("$name$ = $number$,\n",
|
| - "name", descriptor_->value(i)->name(),
|
| - "number", SimpleItoa(descriptor_->value(i)->number()));
|
| + string original_name = descriptor_->value(i)->name();
|
| + string name = options()->legacy_enum_values
|
| + ? descriptor_->value(i)->name()
|
| + : GetEnumValueName(descriptor_->name(), descriptor_->value(i)->name());
|
| + // Make sure we don't get any duplicate names due to prefix removal.
|
| + while (!used_names.insert(name).second) {
|
| + // It's possible we'll end up giving this warning multiple times, but that's better than not at all.
|
| + GOOGLE_LOG(WARNING) << "Duplicate enum value " << name << " (originally " << original_name
|
| + << ") in " << descriptor_->name() << "; adding underscore to distinguish";
|
| + name += "_";
|
| + }
|
| + printer->Print("[pbr::OriginalName(\"$original_name$\")] $name$ = $number$,\n",
|
| + "original_name", original_name,
|
| + "name", name,
|
| + "number", SimpleItoa(descriptor_->value(i)->number()));
|
| }
|
| printer->Outdent();
|
| printer->Print("}\n");
|
|
|