1// Protocol Buffers - Google's data interchange format
2// Copyright 2008 Google Inc.  All rights reserved.
3// http://code.google.com/p/protobuf/
4//
5// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions are
7// met:
8//
9//     * Redistributions of source code must retain the above copyright
10// notice, this list of conditions and the following disclaimer.
11//     * Redistributions in binary form must reproduce the above
12// copyright notice, this list of conditions and the following disclaimer
13// in the documentation and/or other materials provided with the
14// distribution.
15//     * Neither the name of Google Inc. nor the names of its
16// contributors may be used to endorse or promote products derived from
17// this software without specific prior written permission.
18//
19// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
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.
30
31// Author: maxtroy@google.com (Max Cai)
32
33package protobuf_unittest;
34
35option java_package = "com.google.protobuf.nano";
36option java_outer_classname = "NanoAccessorsOuterClass";
37
38message TestNanoAccessors {
39
40  message NestedMessage {
41    optional int32 bb = 1;
42  }
43
44  enum NestedEnum {
45    FOO = 1;
46    BAR = 2;
47    BAZ = 3;
48  }
49
50  // Singular
51  optional int32  optional_int32    =  1;
52  optional float  optional_float    = 11;
53  optional double optional_double   = 12;
54  optional string optional_string   = 14;
55  optional bytes  optional_bytes    = 15;
56
57  optional NestedMessage optional_nested_message = 18;
58
59  optional NestedEnum optional_nested_enum = 21;
60
61  // Repeated
62  repeated int32  repeated_int32    = 31;
63  repeated string repeated_string   = 44;
64  repeated bytes  repeated_bytes    = 45;
65
66  repeated NestedMessage repeated_nested_message  = 48;
67
68  repeated NestedEnum repeated_nested_enum  = 51;
69
70  // Singular with defaults
71  optional int32  default_int32    = 61 [default =  41    ];
72  optional string default_string   = 74 [default = "hello"];
73  optional bytes  default_bytes    = 75 [default = "world"];
74
75  optional float default_float_nan = 99  [default =  nan];
76
77  optional NestedEnum default_nested_enum = 81 [default = BAR];
78
79  // Required
80  required int32 id = 86;
81
82  // Add enough optional fields to make 2 bit fields in total
83  optional int32 filler100 = 100;
84  optional int32 filler101 = 101;
85  optional int32 filler102 = 102;
86  optional int32 filler103 = 103;
87  optional int32 filler104 = 104;
88  optional int32 filler105 = 105;
89  optional int32 filler106 = 106;
90  optional int32 filler107 = 107;
91  optional int32 filler108 = 108;
92  optional int32 filler109 = 109;
93  optional int32 filler110 = 110;
94  optional int32 filler111 = 111;
95  optional int32 filler112 = 112;
96  optional int32 filler113 = 113;
97  optional int32 filler114 = 114;
98  optional int32 filler115 = 115;
99  optional int32 filler116 = 116;
100  optional int32 filler117 = 117;
101  optional int32 filler118 = 118;
102  optional int32 filler119 = 119;
103  optional int32 filler120 = 120;
104  optional int32 filler121 = 121;
105  optional int32 filler122 = 122;
106  optional int32 filler123 = 123;
107  optional int32 filler124 = 124;
108  optional int32 filler125 = 125;
109  optional int32 filler126 = 126;
110  optional int32 filler127 = 127;
111  optional int32 filler128 = 128;
112  optional int32 filler129 = 129;
113  optional int32 filler130 = 130;
114
115  optional int32 before_bit_field_check = 139;
116  optional int32 bit_field_check = 140;
117  optional int32 after_bit_field_check = 141;
118}
119