xref: /aosp_15_r20/external/protobuf/benchmarks/benchmarks.proto (revision 1b3f573f81763fcece89efc2b6a5209149e44ab8)
1*1b3f573fSAndroid Build Coastguard Worker// Protocol Buffers - Google's data interchange format
2*1b3f573fSAndroid Build Coastguard Worker// Copyright 2008 Google Inc.  All rights reserved.
3*1b3f573fSAndroid Build Coastguard Worker// https://developers.google.com/protocol-buffers/
4*1b3f573fSAndroid Build Coastguard Worker//
5*1b3f573fSAndroid Build Coastguard Worker// Redistribution and use in source and binary forms, with or without
6*1b3f573fSAndroid Build Coastguard Worker// modification, are permitted provided that the following conditions are
7*1b3f573fSAndroid Build Coastguard Worker// met:
8*1b3f573fSAndroid Build Coastguard Worker//
9*1b3f573fSAndroid Build Coastguard Worker//     * Redistributions of source code must retain the above copyright
10*1b3f573fSAndroid Build Coastguard Worker// notice, this list of conditions and the following disclaimer.
11*1b3f573fSAndroid Build Coastguard Worker//     * Redistributions in binary form must reproduce the above
12*1b3f573fSAndroid Build Coastguard Worker// copyright notice, this list of conditions and the following disclaimer
13*1b3f573fSAndroid Build Coastguard Worker// in the documentation and/or other materials provided with the
14*1b3f573fSAndroid Build Coastguard Worker// distribution.
15*1b3f573fSAndroid Build Coastguard Worker//     * Neither the name of Google Inc. nor the names of its
16*1b3f573fSAndroid Build Coastguard Worker// contributors may be used to endorse or promote products derived from
17*1b3f573fSAndroid Build Coastguard Worker// this software without specific prior written permission.
18*1b3f573fSAndroid Build Coastguard Worker//
19*1b3f573fSAndroid Build Coastguard Worker// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20*1b3f573fSAndroid Build Coastguard Worker// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21*1b3f573fSAndroid Build Coastguard Worker// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22*1b3f573fSAndroid Build Coastguard Worker// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23*1b3f573fSAndroid Build Coastguard Worker// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24*1b3f573fSAndroid Build Coastguard Worker// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25*1b3f573fSAndroid Build Coastguard Worker// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26*1b3f573fSAndroid Build Coastguard Worker// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27*1b3f573fSAndroid Build Coastguard Worker// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28*1b3f573fSAndroid Build Coastguard Worker// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29*1b3f573fSAndroid Build Coastguard Worker// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30*1b3f573fSAndroid Build Coastguard Worker
31*1b3f573fSAndroid Build Coastguard Workersyntax = "proto3";
32*1b3f573fSAndroid Build Coastguard Workerpackage benchmarks;
33*1b3f573fSAndroid Build Coastguard Workeroption java_package = "com.google.protobuf.benchmarks";
34*1b3f573fSAndroid Build Coastguard Worker
35*1b3f573fSAndroid Build Coastguard Workermessage BenchmarkDataset {
36*1b3f573fSAndroid Build Coastguard Worker  // Name of the benchmark dataset.  This should be unique across all datasets.
37*1b3f573fSAndroid Build Coastguard Worker  // Should only contain word characters: [a-zA-Z0-9_]
38*1b3f573fSAndroid Build Coastguard Worker  string name = 1;
39*1b3f573fSAndroid Build Coastguard Worker
40*1b3f573fSAndroid Build Coastguard Worker  // Fully-qualified name of the protobuf message for this dataset.
41*1b3f573fSAndroid Build Coastguard Worker  // It will be one of the messages defined benchmark_messages_proto2.proto
42*1b3f573fSAndroid Build Coastguard Worker  // or benchmark_messages_proto3.proto.
43*1b3f573fSAndroid Build Coastguard Worker  //
44*1b3f573fSAndroid Build Coastguard Worker  // Implementations that do not support reflection can implement this with
45*1b3f573fSAndroid Build Coastguard Worker  // an explicit "if/else" chain that lists every known message defined
46*1b3f573fSAndroid Build Coastguard Worker  // in those files.
47*1b3f573fSAndroid Build Coastguard Worker  string message_name = 2;
48*1b3f573fSAndroid Build Coastguard Worker
49*1b3f573fSAndroid Build Coastguard Worker  // The payload(s) for this dataset.  They should be parsed or serialized
50*1b3f573fSAndroid Build Coastguard Worker  // in sequence, in a loop, ie.
51*1b3f573fSAndroid Build Coastguard Worker  //
52*1b3f573fSAndroid Build Coastguard Worker  //  while (!benchmarkDone) {  // Benchmark runner decides when to exit.
53*1b3f573fSAndroid Build Coastguard Worker  //    for (i = 0; i < benchmark.payload.length; i++) {
54*1b3f573fSAndroid Build Coastguard Worker  //      parse(benchmark.payload[i])
55*1b3f573fSAndroid Build Coastguard Worker  //    }
56*1b3f573fSAndroid Build Coastguard Worker  //  }
57*1b3f573fSAndroid Build Coastguard Worker  //
58*1b3f573fSAndroid Build Coastguard Worker  // This is intended to let datasets include a variety of data to provide
59*1b3f573fSAndroid Build Coastguard Worker  // potentially more realistic results than just parsing the same message
60*1b3f573fSAndroid Build Coastguard Worker  // over and over.  A single message parsed repeatedly could yield unusually
61*1b3f573fSAndroid Build Coastguard Worker  // good branch prediction performance.
62*1b3f573fSAndroid Build Coastguard Worker  repeated bytes payload = 3;
63*1b3f573fSAndroid Build Coastguard Worker}
64