Commit 24f8626c authored by Jon Skeet's avatar Jon Skeet

Merge pull request #583 from jskeet/issue312

Pascal-case namespace automatically in C# codegen
parents 9440a2ab 8482b6c4
...@@ -113,7 +113,7 @@ std::string GetFileNamespace(const FileDescriptor* descriptor) { ...@@ -113,7 +113,7 @@ std::string GetFileNamespace(const FileDescriptor* descriptor) {
if (descriptor->options().has_csharp_namespace()) { if (descriptor->options().has_csharp_namespace()) {
return descriptor->options().csharp_namespace(); return descriptor->options().csharp_namespace();
} }
return descriptor->package(); return UnderscoresToCamelCase(descriptor->package(), true, true);
} }
std::string GetUmbrellaClassNameInternal(const std::string& proto_file) { std::string GetUmbrellaClassNameInternal(const std::string& proto_file) {
...@@ -154,7 +154,8 @@ std::string GetFileUmbrellaNamespace(const FileDescriptor* descriptor) { ...@@ -154,7 +154,8 @@ std::string GetFileUmbrellaNamespace(const FileDescriptor* descriptor) {
// TODO(jtattermusch): can we reuse a utility function? // TODO(jtattermusch): can we reuse a utility function?
std::string UnderscoresToCamelCase(const std::string& input, std::string UnderscoresToCamelCase(const std::string& input,
bool cap_next_letter) { bool cap_next_letter,
bool preserve_period) {
string result; string result;
// Note: I distrust ctype.h due to locales. // Note: I distrust ctype.h due to locales.
for (int i = 0; i < input.size(); i++) { for (int i = 0; i < input.size(); i++) {
...@@ -180,6 +181,9 @@ std::string UnderscoresToCamelCase(const std::string& input, ...@@ -180,6 +181,9 @@ std::string UnderscoresToCamelCase(const std::string& input,
cap_next_letter = true; cap_next_letter = true;
} else { } else {
cap_next_letter = true; cap_next_letter = true;
if (input[i] == '.' && preserve_period) {
result += '.';
}
} }
} }
// Add a trailing "_" if the name should be altered. // Add a trailing "_" if the name should be altered.
......
...@@ -88,7 +88,11 @@ std::string GetPropertyName(const FieldDescriptor* descriptor); ...@@ -88,7 +88,11 @@ std::string GetPropertyName(const FieldDescriptor* descriptor);
int GetFixedSize(FieldDescriptor::Type type); int GetFixedSize(FieldDescriptor::Type type);
std::string UnderscoresToCamelCase(const std::string& input, bool cap_next_letter); std::string UnderscoresToCamelCase(const std::string& input, bool cap_next_letter, bool preserve_period);
inline std::string UnderscoresToCamelCase(const std::string& input, bool cap_next_letter) {
return UnderscoresToCamelCase(input, cap_next_letter, false);
}
std::string UnderscoresToPascalCase(const std::string& input); std::string UnderscoresToPascalCase(const std::string& input);
......
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