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