Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
062d561e
Commit
062d561e
authored
Aug 07, 2013
by
Wink Saville
Committed by
Gerrit Code Review
Aug 07, 2013
Browse files
Options
Browse Files
Download
Plain Diff
Merge "Fix outer classname for javamicro/javanano."
parents
cebd784d
06eed37e
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
218 additions
and
226 deletions
+218
-226
README.txt
java/README.txt
+0
-0
NanoTest.java
java/src/test/java/com/google/protobuf/NanoTest.java
+43
-2
javanano_enum.cc
src/google/protobuf/compiler/javanano/javanano_enum.cc
+0
-16
javanano_file.cc
src/google/protobuf/compiler/javanano/javanano_file.cc
+42
-54
javanano_generator.cc
src/google/protobuf/compiler/javanano/javanano_generator.cc
+12
-10
javanano_helpers.cc
src/google/protobuf/compiler/javanano/javanano_helpers.cc
+34
-103
javanano_helpers.h
src/google/protobuf/compiler/javanano/javanano_helpers.h
+18
-8
javanano_message.cc
src/google/protobuf/compiler/javanano/javanano_message.cc
+4
-16
unittest_multiple_nameclash_nano.proto
src/google/protobuf/unittest_multiple_nameclash_nano.proto
+4
-16
unittest_multiple_nano.proto
src/google/protobuf/unittest_multiple_nano.proto
+17
-1
unittest_recursive_nano.proto
src/google/protobuf/unittest_recursive_nano.proto
+2
-0
unittest_simple_nano.proto
src/google/protobuf/unittest_simple_nano.proto
+2
-0
unittest_single_nano.proto
src/google/protobuf/unittest_single_nano.proto
+38
-0
unittest_stringutf8_nano.proto
src/google/protobuf/unittest_stringutf8_nano.proto
+2
-0
No files found.
java/README.txt
View file @
062d561e
This diff is collapsed.
Click to expand it.
java/src/test/java/com/google/protobuf/NanoTest.java
View file @
062d561e
...
@@ -33,16 +33,22 @@ package com.google.protobuf;
...
@@ -33,16 +33,22 @@ package com.google.protobuf;
import
com.google.protobuf.nano.CodedInputByteBufferNano
;
import
com.google.protobuf.nano.CodedInputByteBufferNano
;
import
com.google.protobuf.nano.Extensions
;
import
com.google.protobuf.nano.Extensions
;
import
com.google.protobuf.nano.Extensions.AnotherMessage
;
import
com.google.protobuf.nano.Extensions.AnotherMessage
;
import
com.google.protobuf.nano.FileScopeEnumRefNano
;
import
com.google.protobuf.nano.InternalNano
;
import
com.google.protobuf.nano.InternalNano
;
import
com.google.protobuf.nano.MessageNano
;
import
com.google.protobuf.nano.MessageNano
;
import
com.google.protobuf.nano.MessageScopeEnumRefNano
;
import
com.google.protobuf.nano.MultipleImportingNonMultipleNano1
;
import
com.google.protobuf.nano.MultipleImportingNonMultipleNano1
;
import
com.google.protobuf.nano.MultipleImportingNonMultipleNano2
;
import
com.google.protobuf.nano.MultipleImportingNonMultipleNano2
;
import
com.google.protobuf.nano.MultipleNameClashNano
;
import
com.google.protobuf.nano.NanoHasOuterClass.TestAllTypesNanoHas
;
import
com.google.protobuf.nano.NanoHasOuterClass.TestAllTypesNanoHas
;
import
com.google.protobuf.nano.NanoOuterClass
;
import
com.google.protobuf.nano.NanoOuterClass
;
import
com.google.protobuf.nano.NanoOuterClass.TestAllTypesNano
;
import
com.google.protobuf.nano.NanoOuterClass.TestAllTypesNano
;
import
com.google.protobuf.nano.RecursiveMessageNano
;
import
com.google.protobuf.nano.SimpleMessageNano
;
import
com.google.protobuf.nano.UnittestImportNano
;
import
com.google.protobuf.nano.UnittestImportNano
;
import
com.google.protobuf.nano.UnittestMultipleNano
;
import
com.google.protobuf.nano.UnittestRecursiveNano.RecursiveMessageNano
;
import
com.google.protobuf.nano.UnittestSimpleNano.SimpleMessageNano
;
import
com.google.protobuf.nano.UnittestSingleNano.SingleMessageNano
;
import
com.google.protobuf.nano.UnittestStringutf8Nano.StringUtf8
;
import
junit.framework.TestCase
;
import
junit.framework.TestCase
;
...
@@ -2061,6 +2067,41 @@ public class NanoTest extends TestCase {
...
@@ -2061,6 +2067,41 @@ public class NanoTest extends TestCase {
assertEquals
(
nestedMsg2
.
bb
,
newMsg
.
repeatedNestedMessage
[
2
].
bb
);
assertEquals
(
nestedMsg2
.
bb
,
newMsg
.
repeatedNestedMessage
[
2
].
bb
);
}
}
/**
* Tests that code generation correctly wraps a single message into its outer
* class. The class {@code SingleMessageNano} is imported from the outer
* class {@code UnittestSingleNano}, whose name is implicit. Any error would
* cause this method to fail compilation.
*/
public
void
testNanoSingle
()
throws
Exception
{
SingleMessageNano
msg
=
new
SingleMessageNano
();
}
/**
* Tests that code generation correctly skips generating the outer class if
* unnecessary, letting a file-scope entity have the same name. The class
* {@code MultipleNameClashNano} shares the same name with the file's outer
* class defined explicitly, but the file contains no other entities and has
* java_multiple_files set. Any error would cause this method to fail
* compilation.
*/
public
void
testNanoMultipleNameClash
()
throws
Exception
{
MultipleNameClashNano
msg
=
new
MultipleNameClashNano
();
msg
.
field
=
0
;
}
/**
* Tests that code generation correctly handles enums in different scopes in
* a source file with the option java_multiple_files set to true. Any error
* would cause this method to fail compilation.
*/
public
void
testNanoMultipleEnumScoping
()
throws
Exception
{
FileScopeEnumRefNano
msg1
=
new
FileScopeEnumRefNano
();
msg1
.
enumField
=
UnittestMultipleNano
.
ONE
;
MessageScopeEnumRefNano
msg2
=
new
MessageScopeEnumRefNano
();
msg2
.
enumField
=
MessageScopeEnumRefNano
.
TWO
;
}
/**
/**
* Tests that code generation with mixed values of the java_multiple_files
* Tests that code generation with mixed values of the java_multiple_files
* options between the main source file and the imported source files would
* options between the main source file and the imported source files would
...
...
src/google/protobuf/compiler/javanano/javanano_enum.cc
View file @
062d561e
...
@@ -69,18 +69,6 @@ EnumGenerator::~EnumGenerator() {}
...
@@ -69,18 +69,6 @@ EnumGenerator::~EnumGenerator() {}
void
EnumGenerator
::
Generate
(
io
::
Printer
*
printer
)
{
void
EnumGenerator
::
Generate
(
io
::
Printer
*
printer
)
{
printer
->
Print
(
"// enum $classname$
\n
"
,
"classname"
,
descriptor_
->
name
());
printer
->
Print
(
"// enum $classname$
\n
"
,
"classname"
,
descriptor_
->
name
());
const
string
&
file_name
=
descriptor_
->
file
()
->
name
();
bool
is_own_file
=
params_
.
java_multiple_files
(
file_name
)
||
((
descriptor_
->
containing_type
()
==
NULL
)
&&
!
params_
.
has_java_outer_classname
(
file_name
));
if
(
is_own_file
)
{
printer
->
Print
(
"public final class $classname$ {
\n
"
,
"classname"
,
descriptor_
->
name
());
printer
->
Indent
();
printer
->
Print
(
"private $classname$() {}
\n
"
,
"classname"
,
descriptor_
->
name
());
}
for
(
int
i
=
0
;
i
<
canonical_values_
.
size
();
i
++
)
{
for
(
int
i
=
0
;
i
<
canonical_values_
.
size
();
i
++
)
{
map
<
string
,
string
>
vars
;
map
<
string
,
string
>
vars
;
vars
[
"name"
]
=
RenameJavaKeywords
(
canonical_values_
[
i
]
->
name
());
vars
[
"name"
]
=
RenameJavaKeywords
(
canonical_values_
[
i
]
->
name
());
...
@@ -99,10 +87,6 @@ void EnumGenerator::Generate(io::Printer* printer) {
...
@@ -99,10 +87,6 @@ void EnumGenerator::Generate(io::Printer* printer) {
"public static final int $name$ = $canonical_name$;
\n
"
);
"public static final int $name$ = $canonical_name$;
\n
"
);
}
}
if
(
is_own_file
)
{
printer
->
Outdent
();
printer
->
Print
(
"}"
);
}
printer
->
Print
(
"
\n
"
);
printer
->
Print
(
"
\n
"
);
}
}
...
...
src/google/protobuf/compiler/javanano/javanano_file.cc
View file @
062d561e
...
@@ -32,6 +32,8 @@
...
@@ -32,6 +32,8 @@
// Based on original Protocol Buffers design by
// Based on original Protocol Buffers design by
// Sanjay Ghemawat, Jeff Dean, and others.
// Sanjay Ghemawat, Jeff Dean, and others.
#include <iostream>
#include <google/protobuf/compiler/javanano/javanano_file.h>
#include <google/protobuf/compiler/javanano/javanano_file.h>
#include <google/protobuf/compiler/javanano/javanano_enum.h>
#include <google/protobuf/compiler/javanano/javanano_enum.h>
#include <google/protobuf/compiler/javanano/javanano_extension.h>
#include <google/protobuf/compiler/javanano/javanano_extension.h>
...
@@ -103,56 +105,48 @@ bool FileGenerator::Validate(string* error) {
...
@@ -103,56 +105,48 @@ bool FileGenerator::Validate(string* error) {
return
false
;
return
false
;
}
}
// If there is no outer class name then there must be only
if
(
file_
->
service_count
()
!=
0
)
{
// message and no enums defined in the file scope.
error
->
assign
(
file_
->
name
());
if
(
!
params_
.
has_java_outer_classname
(
file_
->
name
()))
{
error
->
append
(
if
(
file_
->
message_type_count
()
!=
1
)
{
": Java NANO_RUNTIME does not support services
\"
"
);
error
->
assign
(
file_
->
name
());
return
false
;
error
->
append
(
}
": Java NANO_RUNTIME may only have 1 message if there is no 'option java_outer_classname'
\"
"
);
return
false
;
}
if
(
file_
->
enum_type_count
()
!=
0
)
{
if
(
!
IsOuterClassNeeded
(
params_
,
file_
))
{
error
->
assign
(
file_
->
name
());
return
true
;
error
->
append
(
}
": Java NANO_RUNTIME must have an 'option java_outer_classname' if file scope enums are present
\"
"
);
return
false
;
// Check whether legacy javanano generator would omit the outer class.
}
if
(
!
params_
.
has_java_outer_classname
(
file_
->
name
())
&&
file_
->
message_type_count
()
==
1
&&
file_
->
enum_type_count
()
==
0
&&
file_
->
extension_count
()
==
0
)
{
cout
<<
"INFO: "
<<
file_
->
name
()
<<
":"
<<
endl
;
cout
<<
"Javanano generator has changed to align with java generator. "
"An outer class will be created for this file and the single message "
"in the file will become a nested class. Use java_multiple_files to "
"skip generating the outer class, or set an explicit "
"java_outer_classname to suppress this message."
<<
endl
;
}
}
// Check that no class name matches the file's class name. This is a common
// Check that no class name matches the file's class name. This is a common
// problem that leads to Java compile errors that can be hard to understand.
// problem that leads to Java compile errors that can be hard to understand.
// It's especially bad when using the java_multiple_files, since we would
// It's especially bad when using the java_multiple_files, since we would
// end up overwriting the outer class with one of the inner ones.
// end up overwriting the outer class with one of the inner ones.
int
found_fileName
=
0
;
bool
found_conflict
=
false
;
for
(
int
i
=
0
;
i
<
file_
->
enum_type_count
();
i
++
)
{
for
(
int
i
=
0
;
!
found_conflict
&&
i
<
file_
->
message_type_count
();
i
++
)
{
if
(
file_
->
enum_type
(
i
)
->
name
()
==
classname_
)
{
found_fileName
+=
1
;
}
}
for
(
int
i
=
0
;
i
<
file_
->
message_type_count
();
i
++
)
{
if
(
file_
->
message_type
(
i
)
->
name
()
==
classname_
)
{
if
(
file_
->
message_type
(
i
)
->
name
()
==
classname_
)
{
found_
fileName
+=
1
;
found_
conflict
=
true
;
}
}
}
}
if
(
f
ile_
->
service_count
()
!=
0
)
{
if
(
f
ound_conflict
)
{
error
->
assign
(
file_
->
name
());
error
->
assign
(
file_
->
name
());
error
->
append
(
error
->
append
(
": Java NANO_RUNTIME does not support services
\"
"
);
": Cannot generate Java output because the file's outer class name,
\"
"
);
return
false
;
}
if
(
found_fileName
>
1
)
{
error
->
assign
(
file_
->
name
());
error
->
append
(
": Cannot generate Java output because there is more than one class name,
\"
"
);
error
->
append
(
classname_
);
error
->
append
(
classname_
);
error
->
append
(
error
->
append
(
"
\"
, matches the name of one of the types declared inside it. "
"
\"
, matches the name of one of the types declared inside it. "
"Please either rename the type or use the java_outer_classname "
"Please either rename the type or use the java_outer_classname "
"option to specify a different outer class name for the .proto file."
"option to specify a different outer class name for the .proto file."
);
" -- FIX THIS MESSAGE"
);
return
false
;
return
false
;
}
}
return
true
;
return
true
;
...
@@ -171,13 +165,11 @@ void FileGenerator::Generate(io::Printer* printer) {
...
@@ -171,13 +165,11 @@ void FileGenerator::Generate(io::Printer* printer) {
"package"
,
java_package_
);
"package"
,
java_package_
);
}
}
if
(
params_
.
has_java_outer_classname
(
file_
->
name
()))
{
printer
->
Print
(
printer
->
Print
(
"public final class $classname$ {
\n
"
"public final class $classname$ {
\n
"
" private $classname$() {}
\n
"
,
" private $classname$() {}
\n
"
,
"classname"
,
classname_
);
"classname"
,
classname_
);
printer
->
Indent
();
printer
->
Indent
();
}
// -----------------------------------------------------------------
// -----------------------------------------------------------------
...
@@ -186,10 +178,13 @@ void FileGenerator::Generate(io::Printer* printer) {
...
@@ -186,10 +178,13 @@ void FileGenerator::Generate(io::Printer* printer) {
ExtensionGenerator
(
file_
->
extension
(
i
),
params_
).
Generate
(
printer
);
ExtensionGenerator
(
file_
->
extension
(
i
),
params_
).
Generate
(
printer
);
}
}
// Enums.
for
(
int
i
=
0
;
i
<
file_
->
enum_type_count
();
i
++
)
{
EnumGenerator
(
file_
->
enum_type
(
i
),
params_
).
Generate
(
printer
);
}
// Messages.
if
(
!
params_
.
java_multiple_files
(
file_
->
name
()))
{
if
(
!
params_
.
java_multiple_files
(
file_
->
name
()))
{
for
(
int
i
=
0
;
i
<
file_
->
enum_type_count
();
i
++
)
{
EnumGenerator
(
file_
->
enum_type
(
i
),
params_
).
Generate
(
printer
);
}
for
(
int
i
=
0
;
i
<
file_
->
message_type_count
();
i
++
)
{
for
(
int
i
=
0
;
i
<
file_
->
message_type_count
();
i
++
)
{
MessageGenerator
(
file_
->
message_type
(
i
),
params_
).
Generate
(
printer
);
MessageGenerator
(
file_
->
message_type
(
i
),
params_
).
Generate
(
printer
);
}
}
...
@@ -201,11 +196,9 @@ void FileGenerator::Generate(io::Printer* printer) {
...
@@ -201,11 +196,9 @@ void FileGenerator::Generate(io::Printer* printer) {
MessageGenerator
(
file_
->
message_type
(
i
),
params_
).
GenerateStaticVariables
(
printer
);
MessageGenerator
(
file_
->
message_type
(
i
),
params_
).
GenerateStaticVariables
(
printer
);
}
}
if
(
params_
.
has_java_outer_classname
(
file_
->
name
()))
{
printer
->
Outdent
();
printer
->
Outdent
();
printer
->
Print
(
printer
->
Print
(
"}
\n
"
);
"}
\n
"
);
}
}
}
template
<
typename
GeneratorClass
,
typename
DescriptorClass
>
template
<
typename
GeneratorClass
,
typename
DescriptorClass
>
...
@@ -239,11 +232,6 @@ void FileGenerator::GenerateSiblings(const string& package_dir,
...
@@ -239,11 +232,6 @@ void FileGenerator::GenerateSiblings(const string& package_dir,
OutputDirectory
*
output_directory
,
OutputDirectory
*
output_directory
,
vector
<
string
>*
file_list
)
{
vector
<
string
>*
file_list
)
{
if
(
params_
.
java_multiple_files
(
file_
->
name
()))
{
if
(
params_
.
java_multiple_files
(
file_
->
name
()))
{
for
(
int
i
=
0
;
i
<
file_
->
enum_type_count
();
i
++
)
{
GenerateSibling
<
EnumGenerator
>
(
package_dir
,
java_package_
,
file_
->
enum_type
(
i
),
output_directory
,
file_list
,
params_
);
}
for
(
int
i
=
0
;
i
<
file_
->
message_type_count
();
i
++
)
{
for
(
int
i
=
0
;
i
<
file_
->
message_type_count
();
i
++
)
{
GenerateSibling
<
MessageGenerator
>
(
package_dir
,
java_package_
,
GenerateSibling
<
MessageGenerator
>
(
package_dir
,
java_package_
,
file_
->
message_type
(
i
),
file_
->
message_type
(
i
),
...
...
src/google/protobuf/compiler/javanano/javanano_generator.cc
View file @
062d561e
...
@@ -138,16 +138,18 @@ bool JavaNanoGenerator::Generate(const FileDescriptor* file,
...
@@ -138,16 +138,18 @@ bool JavaNanoGenerator::Generate(const FileDescriptor* file,
vector
<
string
>
all_files
;
vector
<
string
>
all_files
;
string
java_filename
=
package_dir
;
if
(
IsOuterClassNeeded
(
params
,
file
))
{
java_filename
+=
file_generator
.
classname
();
string
java_filename
=
package_dir
;
java_filename
+=
".java"
;
java_filename
+=
file_generator
.
classname
();
all_files
.
push_back
(
java_filename
);
java_filename
+=
".java"
;
all_files
.
push_back
(
java_filename
);
// Generate main java file.
scoped_ptr
<
io
::
ZeroCopyOutputStream
>
output
(
// Generate main java file.
output_directory
->
Open
(
java_filename
));
scoped_ptr
<
io
::
ZeroCopyOutputStream
>
output
(
io
::
Printer
printer
(
output
.
get
(),
'$'
);
output_directory
->
Open
(
java_filename
));
file_generator
.
Generate
(
&
printer
);
io
::
Printer
printer
(
output
.
get
(),
'$'
);
file_generator
.
Generate
(
&
printer
);
}
// Generate sibling files.
// Generate sibling files.
file_generator
.
GenerateSiblings
(
package_dir
,
output_directory
,
&
all_files
);
file_generator
.
GenerateSiblings
(
package_dir
,
output_directory
,
&
all_files
);
...
...
src/google/protobuf/compiler/javanano/javanano_helpers.cc
View file @
062d561e
...
@@ -167,31 +167,20 @@ string StripProto(const string& filename) {
...
@@ -167,31 +167,20 @@ string StripProto(const string& filename) {
}
}
string
FileClassName
(
const
Params
&
params
,
const
FileDescriptor
*
file
)
{
string
FileClassName
(
const
Params
&
params
,
const
FileDescriptor
*
file
)
{
string
name
;
if
(
params
.
has_java_outer_classname
(
file
->
name
()))
{
if
(
params
.
has_java_outer_classname
(
file
->
name
()))
{
name
=
params
.
java_outer_classname
(
file
->
name
());
return
params
.
java_outer_classname
(
file
->
name
());
}
else
{
}
else
{
if
((
file
->
message_type_count
()
==
1
)
// Use the filename itself with underscores removed
||
(
file
->
enum_type_count
()
==
0
))
{
// and a CamelCase style name.
// If no outer calls and only one message then
string
basename
;
// use the message name as the file name
string
::
size_type
last_slash
=
file
->
name
().
find_last_of
(
'/'
);
name
=
file
->
message_type
(
0
)
->
name
();
if
(
last_slash
==
string
::
npos
)
{
basename
=
file
->
name
();
}
else
{
}
else
{
// Use the filename it self with underscores removed
basename
=
file
->
name
().
substr
(
last_slash
+
1
);
// and a CamelCase style name.
string
basename
;
string
::
size_type
last_slash
=
file
->
name
().
find_last_of
(
'/'
);
if
(
last_slash
==
string
::
npos
)
{
basename
=
file
->
name
();
}
else
{
basename
=
file
->
name
().
substr
(
last_slash
+
1
);
}
name
=
UnderscoresToCamelCaseImpl
(
StripProto
(
basename
),
true
);
}
}
return
UnderscoresToCamelCaseImpl
(
StripProto
(
basename
),
true
);
}
}
return
name
;
}
}
string
FileJavaPackage
(
const
Params
&
params
,
const
FileDescriptor
*
file
)
{
string
FileJavaPackage
(
const
Params
&
params
,
const
FileDescriptor
*
file
)
{
...
@@ -207,38 +196,27 @@ string FileJavaPackage(const Params& params, const FileDescriptor* file) {
...
@@ -207,38 +196,27 @@ string FileJavaPackage(const Params& params, const FileDescriptor* file) {
}
}
}
}
string
ToJavaName
(
const
Params
&
params
,
const
string
&
full_name
,
bool
IsOuterClassNeeded
(
const
Params
&
params
,
const
FileDescriptor
*
file
)
{
const
FileDescriptor
*
file
)
{
// Enums and extensions need the outer class as the scope.
string
result
;
if
(
file
->
enum_type_count
()
!=
0
||
file
->
extension_count
()
!=
0
)
{
if
(
params
.
java_multiple_files
(
file
->
name
()))
{
return
true
;
result
=
FileJavaPackage
(
params
,
file
);
}
else
{
result
=
ClassName
(
params
,
file
);
}
}
if
(
file
->
package
().
empty
())
{
// Messages need the outer class only if java_multiple_files is false.
result
+=
'.'
;
return
!
params
.
java_multiple_files
(
file
->
name
());
result
+=
full_name
;
}
string
ToJavaName
(
const
Params
&
params
,
const
string
&
name
,
bool
is_class
,
const
Descriptor
*
parent
,
const
FileDescriptor
*
file
)
{
string
result
;
if
(
parent
!=
NULL
)
{
result
.
append
(
ClassName
(
params
,
parent
));
}
else
if
(
is_class
&&
params
.
java_multiple_files
(
file
->
name
()))
{
result
.
append
(
FileJavaPackage
(
params
,
file
));
}
else
{
}
else
{
// Strip the proto package from full_name since we've replaced it with
result
.
append
(
ClassName
(
params
,
file
));
// the Java package. If there isn't an outer classname then strip it too.
int
sizeToSkipPackageName
=
file
->
package
().
size
();
int
sizeToSkipOutClassName
;
if
(
params
.
has_java_outer_classname
(
file
->
name
()))
{
sizeToSkipOutClassName
=
0
;
}
else
{
sizeToSkipOutClassName
=
full_name
.
find_first_of
(
'.'
,
sizeToSkipPackageName
+
1
);
}
int
sizeToSkip
=
sizeToSkipOutClassName
>
0
?
sizeToSkipOutClassName
:
sizeToSkipPackageName
;
string
class_name
=
full_name
.
substr
(
sizeToSkip
+
1
);
if
(
class_name
==
FileClassName
(
params
,
file
))
{
// Done class_name is already present.
}
else
{
result
+=
'.'
;
result
+=
class_name
;
}
}
}
if
(
!
result
.
empty
())
result
.
append
(
1
,
'.'
);
result
.
append
(
RenameJavaKeywords
(
name
));
return
result
;
return
result
;
}
}
...
@@ -250,61 +228,14 @@ string ClassName(const Params& params, const FileDescriptor* descriptor) {
...
@@ -250,61 +228,14 @@ string ClassName(const Params& params, const FileDescriptor* descriptor) {
}
}
string
ClassName
(
const
Params
&
params
,
const
EnumDescriptor
*
descriptor
)
{
string
ClassName
(
const
Params
&
params
,
const
EnumDescriptor
*
descriptor
)
{
string
result
;
// An enum's class name is the enclosing message's class name or the outer
const
FileDescriptor
*
file
=
descriptor
->
file
();
// class name.
const
string
file_name
=
file
->
name
();
const
Descriptor
*
parent
=
descriptor
->
containing_type
();
const
string
full_name
=
descriptor
->
full_name
();
if
(
parent
!=
NULL
)
{
return
ClassName
(
params
,
parent
);
// Remove enum class name as we use int's for enums
}
else
{
int
last_dot_in_name
=
full_name
.
find_last_of
(
'.'
);
return
ClassName
(
params
,
descriptor
->
file
());
string
base_name
=
full_name
.
substr
(
0
,
last_dot_in_name
);
if
(
!
file
->
package
().
empty
())
{
if
(
file
->
package
()
==
base_name
.
substr
(
0
,
file
->
package
().
size
()))
{
// Remove package name leaving just the parent class of the enum
int
offset
=
file
->
package
().
size
();
if
(
base_name
.
size
()
>
offset
)
{
// Remove period between package and class name if there is a classname
offset
+=
1
;
}
base_name
=
base_name
.
substr
(
offset
);
}
else
{
GOOGLE_LOG
(
FATAL
)
<<
"Expected package name to start an enum"
;
}
}
// Construct the path name from the package and outer class
// Add the java package name if it exists
if
(
params
.
has_java_package
(
file_name
))
{
result
+=
params
.
java_package
(
file_name
);
}
// If the java_multiple_files option is present, we will generate enums into separate
// classes, each named after the original enum type. This takes precedence over
// any outer_classname.
if
(
params
.
java_multiple_files
(
file_name
)
&&
last_dot_in_name
!=
string
::
npos
)
{
string
enum_simple_name
=
full_name
.
substr
(
last_dot_in_name
+
1
);
if
(
!
result
.
empty
())
{
result
+=
"."
;
}
result
+=
enum_simple_name
;
}
else
if
(
params
.
has_java_outer_classname
(
file_name
))
{
// Add the outer classname if it exists
if
(
!
result
.
empty
())
{
result
+=
"."
;
}
result
+=
params
.
java_outer_classname
(
file_name
);
}
// Create the full class name from the base and path
if
(
!
base_name
.
empty
())
{
if
(
!
result
.
empty
())
{
result
+=
"."
;
}
result
+=
base_name
;
}
}
return
result
;
}
}
string
FieldConstantName
(
const
FieldDescriptor
*
field
)
{
string
FieldConstantName
(
const
FieldDescriptor
*
field
)
{
...
...
src/google/protobuf/compiler/javanano/javanano_helpers.h
View file @
062d561e
...
@@ -73,25 +73,35 @@ string FileClassName(const Params& params, const FileDescriptor* file);
...
@@ -73,25 +73,35 @@ string FileClassName(const Params& params, const FileDescriptor* file);
// Returns the file's Java package name.
// Returns the file's Java package name.
string
FileJavaPackage
(
const
Params
&
params
,
const
FileDescriptor
*
file
);
string
FileJavaPackage
(
const
Params
&
params
,
const
FileDescriptor
*
file
);
// Converts the given fully-qualified name in the proto namespace to its
// Returns whether the Java outer class is needed, i.e. whether the option
// fully-qualified name in the Java namespace, given that it is in the given
// java_multiple_files is false, or the proto file contains any file-scope
// file.
// enums/extensions.
string
ToJavaName
(
const
Params
&
params
,
const
string
&
full_name
,
bool
IsOuterClassNeeded
(
const
Params
&
params
,
const
FileDescriptor
*
file
);
const
FileDescriptor
*
file
);
// Converts the given simple name of a proto entity to its fully-qualified name
// in the Java namespace, given that it is in the given file enclosed in the
// given parent message (or NULL for file-scope entities). Whether the file's
// outer class name should be included in the return value depends on factors
// inferrable from the given arguments, including is_class which indicates
// whether the entity translates to a Java class.
string
ToJavaName
(
const
Params
&
params
,
const
string
&
name
,
bool
is_class
,
const
Descriptor
*
parent
,
const
FileDescriptor
*
file
);
// These return the fully-qualified class name corresponding to the given
// These return the fully-qualified class name corresponding to the given
// descriptor.
// descriptor.
inline
string
ClassName
(
const
Params
&
params
,
const
Descriptor
*
descriptor
)
{
inline
string
ClassName
(
const
Params
&
params
,
const
Descriptor
*
descriptor
)
{
return
ToJavaName
(
params
,
descriptor
->
full_name
(),
descriptor
->
file
());
return
ToJavaName
(
params
,
descriptor
->
name
(),
true
,
descriptor
->
containing_type
(),
descriptor
->
file
());
}
}
string
ClassName
(
const
Params
&
params
,
const
EnumDescriptor
*
descriptor
);
string
ClassName
(
const
Params
&
params
,
const
EnumDescriptor
*
descriptor
);
inline
string
ClassName
(
const
Params
&
params
,
inline
string
ClassName
(
const
Params
&
params
,
const
ServiceDescriptor
*
descriptor
)
{
const
ServiceDescriptor
*
descriptor
)
{
return
ToJavaName
(
params
,
descriptor
->
full_name
()
,
descriptor
->
file
());
return
ToJavaName
(
params
,
descriptor
->
name
(),
true
,
NULL
,
descriptor
->
file
());
}
}
inline
string
ExtensionIdentifierName
(
const
Params
&
params
,
inline
string
ExtensionIdentifierName
(
const
Params
&
params
,
const
FieldDescriptor
*
descriptor
)
{
const
FieldDescriptor
*
descriptor
)
{
return
ToJavaName
(
params
,
descriptor
->
full_name
(),
descriptor
->
file
());
return
ToJavaName
(
params
,
descriptor
->
name
(),
false
,
descriptor
->
extension_scope
(),
descriptor
->
file
());
}
}
string
ClassName
(
const
Params
&
params
,
const
FileDescriptor
*
descriptor
);
string
ClassName
(
const
Params
&
params
,
const
FileDescriptor
*
descriptor
);
...
...
src/google/protobuf/compiler/javanano/javanano_message.cc
View file @
062d561e
...
@@ -114,7 +114,7 @@ void MessageGenerator::GenerateStaticVariableInitializers(
...
@@ -114,7 +114,7 @@ void MessageGenerator::GenerateStaticVariableInitializers(
io
::
Printer
*
printer
)
{
io
::
Printer
*
printer
)
{
// Generate static member initializers for all nested types.
// Generate static member initializers for all nested types.
for
(
int
i
=
0
;
i
<
descriptor_
->
nested_type_count
();
i
++
)
{
for
(
int
i
=
0
;
i
<
descriptor_
->
nested_type_count
();
i
++
)
{
// TODO(kenton): Reuse MessageGenerator objects?
// TODO(kenton): Reuse MessageGenerator objects?
MessageGenerator
(
descriptor_
->
nested_type
(
i
),
params_
)
MessageGenerator
(
descriptor_
->
nested_type
(
i
),
params_
)
.
GenerateStaticVariableInitializers
(
printer
);
.
GenerateStaticVariableInitializers
(
printer
);
}
}
...
@@ -124,15 +124,7 @@ void MessageGenerator::Generate(io::Printer* printer) {
...
@@ -124,15 +124,7 @@ void MessageGenerator::Generate(io::Printer* printer) {
const
string
&
file_name
=
descriptor_
->
file
()
->
name
();
const
string
&
file_name
=
descriptor_
->
file
()
->
name
();
bool
is_own_file
=
bool
is_own_file
=
params_
.
java_multiple_files
(
file_name
)
params_
.
java_multiple_files
(
file_name
)
||
((
descriptor_
->
containing_type
()
==
NULL
)
&&
descriptor_
->
containing_type
()
==
NULL
;
&&
!
params_
.
has_java_outer_classname
(
file_name
));
#if 0
GOOGLE_LOG(INFO) << "is_own_file=" << is_own_file;
GOOGLE_LOG(INFO) << "containing_type()=" << ((descriptor_->containing_type() == NULL) ? "NULL" : "not null");
GOOGLE_LOG(INFO) << "java_multiple_files()=" << params_.java_multiple_files();
GOOGLE_LOG(INFO) << "has_java_outer_classname()=" << params_.has_java_outer_classname(file_->name());
#endif
if
(
!
params_
.
store_unknown_fields
()
&&
if
(
!
params_
.
store_unknown_fields
()
&&
(
descriptor_
->
extension_count
()
!=
0
||
descriptor_
->
extension_range_count
()
!=
0
))
{
(
descriptor_
->
extension_count
()
!=
0
||
descriptor_
->
extension_range_count
()
!=
0
))
{
...
@@ -355,25 +347,21 @@ void MessageGenerator::GenerateMergeFromMethods(io::Printer* printer) {
...
@@ -355,25 +347,21 @@ void MessageGenerator::GenerateMergeFromMethods(io::Printer* printer) {
void
MessageGenerator
::
void
MessageGenerator
::
GenerateParseFromMethods
(
io
::
Printer
*
printer
)
{
GenerateParseFromMethods
(
io
::
Printer
*
printer
)
{
bool
is_own_file
=
descriptor_
->
containing_type
()
==
NULL
;
// Note: These are separate from GenerateMessageSerializationMethods()
// Note: These are separate from GenerateMessageSerializationMethods()
// because they need to be generated even for messages that are optimized
// because they need to be generated even for messages that are optimized
// for code size.
// for code size.
printer
->
Print
(
printer
->
Print
(
"public
$static$
$classname$ parseFrom(byte[] data)
\n
"
"public
static
$classname$ parseFrom(byte[] data)
\n
"
" throws com.google.protobuf.nano.InvalidProtocolBufferNanoException {
\n
"
" throws com.google.protobuf.nano.InvalidProtocolBufferNanoException {
\n
"
" return com.google.protobuf.nano.MessageNano.mergeFrom(new $classname$(), data);
\n
"
" return com.google.protobuf.nano.MessageNano.mergeFrom(new $classname$(), data);
\n
"
"}
\n
"
"}
\n
"
"
\n
"
"
\n
"
"public
$static$
$classname$ parseFrom(
\n
"
"public
static
$classname$ parseFrom(
\n
"
" com.google.protobuf.nano.CodedInputByteBufferNano input)
\n
"
" com.google.protobuf.nano.CodedInputByteBufferNano input)
\n
"
" throws java.io.IOException {
\n
"
" throws java.io.IOException {
\n
"
" return new $classname$().mergeFrom(input);
\n
"
" return new $classname$().mergeFrom(input);
\n
"
"}
\n
"
"}
\n
"
"
\n
"
,
"
\n
"
,
"static"
,
(
is_own_file
?
"static"
:
""
),
"classname"
,
descriptor_
->
name
());
"classname"
,
descriptor_
->
name
());
}
}
...
...
src/google/protobuf/unittest_
enum_multiplejava
_nano.proto
→
src/google/protobuf/unittest_
multiple_nameclash
_nano.proto
View file @
062d561e
...
@@ -28,26 +28,14 @@
...
@@ -28,26 +28,14 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Author: bduff@google.com (Brian Duff)
// Author: maxtroy@google.com (Max Cai)
//
package
protobuf_unittest_import
;
package
protobuf_unittest_import
;
option
java_package
=
"com.google.protobuf.nano"
;
option
java_package
=
"com.google.protobuf.nano"
;
option
java_outer_classname
=
"
NanoEnumsWithMultipleFiles
"
;
option
java_outer_classname
=
"
MultipleNameClashNano
"
;
option
java_multiple_files
=
true
;
option
java_multiple_files
=
true
;
enum
FirstTopLevelEnum
{
message
MultipleNameClashNano
{
FIRST_TOP_LEVEL_FIRST
=
1
;
optional
int32
field
=
1
;
FIRST_TOP_LEVEL_SECOND
=
2
;
}
enum
SecondTopLevelEnum
{
SECOND_TOP_LEVEL_FIRST
=
1
;
SECOND_TOP_LEVEL_SECOND
=
2
;
}
message
SomeMessage
{
optional
FirstTopLevelEnum
first
=
1
;
optional
SecondTopLevelEnum
second
=
2
;
}
}
src/google/protobuf/unittest_multiple_nano.proto
View file @
062d561e
...
@@ -35,9 +35,25 @@ package protobuf_unittest_import;
...
@@ -35,9 +35,25 @@ package protobuf_unittest_import;
import
"google/protobuf/unittest_import_nano.proto"
;
import
"google/protobuf/unittest_import_nano.proto"
;
option
java_package
=
"com.google.protobuf.nano"
;
option
java_package
=
"com.google.protobuf.nano"
;
option
java_outer_classname
=
"NanoMultipleImportingNonMultiple"
;
option
java_multiple_files
=
true
;
option
java_multiple_files
=
true
;
enum
FileScopeEnum
{
ONE
=
1
;
TWO
=
2
;
}
message
FileScopeEnumRefNano
{
optional
FileScopeEnum
enum_field
=
1
;
}
message
MessageScopeEnumRefNano
{
enum
MessageScopeEnum
{
ONE
=
1
;
TWO
=
2
;
}
optional
MessageScopeEnum
enum_field
=
1
;
}
message
MultipleImportingNonMultipleNano1
{
message
MultipleImportingNonMultipleNano1
{
optional
ImportMessageNano
field
=
1
;
optional
ImportMessageNano
field
=
1
;
}
}
...
...
src/google/protobuf/unittest_recursive_nano.proto
View file @
062d561e
...
@@ -34,6 +34,8 @@
...
@@ -34,6 +34,8 @@
package
protobuf_unittest_import
;
package
protobuf_unittest_import
;
option
java_package
=
"com.google.protobuf.nano"
;
option
java_package
=
"com.google.protobuf.nano"
;
// Explicit outer classname to suppress legacy info.
option
java_outer_classname
=
"UnittestRecursiveNano"
;
message
RecursiveMessageNano
{
message
RecursiveMessageNano
{
message
NestedMessage
{
message
NestedMessage
{
...
...
src/google/protobuf/unittest_simple_nano.proto
View file @
062d561e
...
@@ -34,6 +34,8 @@
...
@@ -34,6 +34,8 @@
package
protobuf_unittest_import
;
package
protobuf_unittest_import
;
option
java_package
=
"com.google.protobuf.nano"
;
option
java_package
=
"com.google.protobuf.nano"
;
// Explicit outer classname to suppress legacy info.
option
java_outer_classname
=
"UnittestSimpleNano"
;
message
SimpleMessageNano
{
message
SimpleMessageNano
{
message
NestedMessage
{
message
NestedMessage
{
...
...
src/google/protobuf/unittest_single_nano.proto
0 → 100644
View file @
062d561e
// Protocol Buffers - Google's data interchange format
// Copyright 2008 Google Inc. All rights reserved.
// http://code.google.com/p/protobuf/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Author: maxtroy@google.com (Max Cai)
package
protobuf_unittest_import
;
option
java_package
=
"com.google.protobuf.nano"
;
message
SingleMessageNano
{
}
src/google/protobuf/unittest_stringutf8_nano.proto
View file @
062d561e
...
@@ -34,6 +34,8 @@
...
@@ -34,6 +34,8 @@
package
protobuf_unittest_import
;
package
protobuf_unittest_import
;
option
java_package
=
"com.google.protobuf.nano"
;
option
java_package
=
"com.google.protobuf.nano"
;
// Explicit outer classname to suppress legacy info.
option
java_outer_classname
=
"UnittestStringutf8Nano"
;
message
StringUtf8
{
message
StringUtf8
{
optional
string
id
=
1
;
optional
string
id
=
1
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment