blob: 4cad69ad5fe8ffcf6043dc6459438336dbaf0d55 [file] [log] [blame]
Mårten Kongstad867a3492023-04-25 15:06:30 +02001// Copyright (C) 2023 The Android Open Source Project
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License
14
Mårten Kongstadfa23d292023-05-11 14:47:02 +020015// This is the schema definition for aconfig files. Modifications need to be
16// either backwards compatible, or include updates to all aconfig files in the
Mårten Kongstadbb520722023-04-26 13:16:41 +020017// Android tree.
Mårten Kongstad867a3492023-04-25 15:06:30 +020018
Mårten Kongstadbb520722023-04-26 13:16:41 +020019syntax = "proto2";
Mårten Kongstad867a3492023-04-25 15:06:30 +020020
21package android.aconfig;
22
Mårten Kongstad30950782023-05-09 13:31:29 +020023// messages used in both aconfig input and output
24
Mårten Kongstadc68c4ea2023-05-05 16:20:09 +020025enum flag_state {
26 ENABLED = 1;
27 DISABLED = 2;
28}
29
Mårten Kongstad30950782023-05-09 13:31:29 +020030enum flag_permission {
Mårten Kongstad416330b2023-05-05 11:10:01 +020031 READ_ONLY = 1;
32 READ_WRITE = 2;
33}
34
Mårten Kongstadfa23d292023-05-11 14:47:02 +020035// aconfig input messages: flag declarations and values
Mårten Kongstad30950782023-05-09 13:31:29 +020036
Mårten Kongstadfa23d292023-05-11 14:47:02 +020037message flag_declaration {
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020038 optional string name = 1;
39 optional string namespace = 2;
40 optional string description = 3;
Mårten Kongstad1b8636b2023-06-22 10:12:24 +020041 repeated string bug = 4;
Mårten Kongstadbb520722023-04-26 13:16:41 +020042};
43
Mårten Kongstadfa23d292023-05-11 14:47:02 +020044message flag_declarations {
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020045 optional string package = 1;
Mårten Kongstadfa23d292023-05-11 14:47:02 +020046 repeated flag_declaration flag = 2;
Mårten Kongstadbb520722023-04-26 13:16:41 +020047};
48
Mårten Kongstadfa23d292023-05-11 14:47:02 +020049message flag_value {
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020050 optional string package = 1;
51 optional string name = 2;
52 optional flag_state state = 3;
53 optional flag_permission permission = 4;
Mårten Kongstadbb520722023-04-26 13:16:41 +020054};
55
Mårten Kongstadfa23d292023-05-11 14:47:02 +020056message flag_values {
57 repeated flag_value flag_value = 1;
Mårten Kongstadbb520722023-04-26 13:16:41 +020058};
Mårten Kongstada1029092023-05-08 11:51:59 +020059
Mårten Kongstadfa23d292023-05-11 14:47:02 +020060// aconfig output messages: parsed and verified flag declarations and values
Mårten Kongstada1029092023-05-08 11:51:59 +020061
Mårten Kongstad30950782023-05-09 13:31:29 +020062message tracepoint {
Mårten Kongstadfa23d292023-05-11 14:47:02 +020063 // path to declaration or value file relative to $TOP
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020064 optional string source = 1;
65 optional flag_state state = 2;
66 optional flag_permission permission = 3;
Mårten Kongstada1029092023-05-08 11:51:59 +020067}
68
Mårten Kongstad30950782023-05-09 13:31:29 +020069message parsed_flag {
Mårten Kongstada2e5ab82023-06-19 16:28:54 +020070 optional string package = 1;
71 optional string name = 2;
72 optional string namespace = 3;
73 optional string description = 4;
Mårten Kongstad1b8636b2023-06-22 10:12:24 +020074 repeated string bug = 5;
75 optional flag_state state = 6;
76 optional flag_permission permission = 7;
77 repeated tracepoint trace = 8;
Mårten Kongstad30950782023-05-09 13:31:29 +020078}
79
80message parsed_flags {
81 repeated parsed_flag parsed_flag = 1;
Mårten Kongstada1029092023-05-08 11:51:59 +020082}