Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(521)

Side by Side Diff: third_party/protobuf/java/core/src/test/proto/com/google/protobuf/map_for_proto2_test.proto

Issue 2495533002: third_party/protobuf: Update to HEAD (83d681ee2c) (Closed)
Patch Set: Make chrome settings proto generated file a component Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Protocol Buffers - Google's data interchange format 1 // Protocol Buffers - Google's data interchange format
2 // Copyright 2008 Google Inc. All rights reserved. 2 // Copyright 2008 Google Inc. All rights reserved.
3 // https://developers.google.com/protocol-buffers/ 3 // https://developers.google.com/protocol-buffers/
4 // 4 //
5 // Redistribution and use in source and binary forms, with or without 5 // Redistribution and use in source and binary forms, with or without
6 // modification, are permitted provided that the following conditions are 6 // modification, are permitted provided that the following conditions are
7 // met: 7 // met:
8 // 8 //
9 // * Redistributions of source code must retain the above copyright 9 // * Redistributions of source code must retain the above copyright
10 // notice, this list of conditions and the following disclaimer. 10 // notice, this list of conditions and the following disclaimer.
(...skipping 16 matching lines...) Expand all
27 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 27 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 28 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 29 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 30
31 syntax = "proto2"; 31 syntax = "proto2";
32 32
33 package map_for_proto2_test; 33 package map_for_proto2_test;
34 34
35 option java_package = "map_test"; 35 option java_package = "map_test";
36 option java_outer_classname = "MapForProto2TestProto"; 36 option java_outer_classname = "MapForProto2TestProto";
37 option java_generate_equals_and_hash = true;
38 37
39 message TestMap { 38 message TestMap {
40 message MessageValue { 39 message MessageValue {
41 optional int32 value = 1; 40 optional int32 value = 1;
42 } 41 }
43 enum EnumValue { 42 enum EnumValue {
44 FOO = 0; 43 FOO = 0;
45 BAR = 1; 44 BAR = 1;
46 BAZ = 2; 45 BAZ = 2;
47 QUX = 3; 46 QUX = 3;
(...skipping 17 matching lines...) Expand all
65 // parsing behavior of TestMap regarding unknown enum values. 64 // parsing behavior of TestMap regarding unknown enum values.
66 map<int32, int32> int32_to_int32_field = 4; 65 map<int32, int32> int32_to_int32_field = 4;
67 } 66 }
68 67
69 // Test that the maps initialization code works correctly when the map field 68 // Test that the maps initialization code works correctly when the map field
70 // references the containing message. 69 // references the containing message.
71 message TestRecursiveMap { 70 message TestRecursiveMap {
72 optional int32 value = 1; 71 optional int32 value = 1;
73 map<int32, TestRecursiveMap> recursive_map_field = 2; 72 map<int32, TestRecursiveMap> recursive_map_field = 2;
74 } 73 }
74
75
76 // a decoy of TestMap for testing parsing errors
77 message BizarroTestMap {
78 map<int32, bytes> int32_to_int32_field = 1; // same key type, different value
79 map<string, int32> int32_to_string_field = 2; // different key and value types
80 map<string, int32> int32_to_bytes_field = 3; // different key types, same valu e
81 map<string, bytes> int32_to_enum_field = 4; // different key and value types
82 map<string, bytes> int32_to_message_field = 5; // different key and value type s
83 map<string, bytes> string_to_int32_field = 6; // same key type, different val ue
84 }
85
86 // Used to test that java reserved words can be used as protobuf field names
87 // Not all reserved words are tested (to avoid bloat) but instead an arbitrary
88 // subset of them chosen to cover various keyword categories like
89 // type, modifier, declaration, etc.
90 message ReservedAsMapField {
91 map<string, uint32> if = 1;
92 map<string, uint32> const = 2;
93 map<string, uint32> private = 3;
94 map<string, uint32> class = 4;
95 map<string, uint32> int = 5;
96 map<string, uint32> void = 6;
97 map<string, uint32> string = 7; // These are also proto keywords
98 map<string, uint32> package = 8;
99 map<string, uint32> enum = 9; // Most recent Java reserved word
100 map<string, uint32> null = 10;
101 // null is not a 'reserved word' per se but as a literal needs similar care
102 }
103
104 message ReservedAsMapFieldWithEnumValue {
105 enum SampleEnum {
106 A = 0;
107 B = 1;
108 }
109 map<string, SampleEnum> if = 1;
110 map<string, SampleEnum> const = 2;
111 map<string, SampleEnum> private = 3;
112 map<string, SampleEnum> class = 4;
113 map<string, SampleEnum> int = 5;
114 map<string, SampleEnum> void = 6;
115 map<string, SampleEnum> string = 7; // These are also proto keywords
116 map<string, SampleEnum> package = 8;
117 map<string, SampleEnum> enum = 9; // Most recent Java reserved word
118 map<string, SampleEnum> null = 10;
119 // null is not a 'reserved word' per se but as a literal needs similar care
120 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698