1*8f0ba417SAndroid Build Coastguard Worker /* 2*8f0ba417SAndroid Build Coastguard Worker * Copyright (C) 2019 The Android Open Source Project 3*8f0ba417SAndroid Build Coastguard Worker * 4*8f0ba417SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*8f0ba417SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*8f0ba417SAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*8f0ba417SAndroid Build Coastguard Worker * 8*8f0ba417SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*8f0ba417SAndroid Build Coastguard Worker * 10*8f0ba417SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*8f0ba417SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*8f0ba417SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*8f0ba417SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*8f0ba417SAndroid Build Coastguard Worker * limitations under the License. 15*8f0ba417SAndroid Build Coastguard Worker */ 16*8f0ba417SAndroid Build Coastguard Worker 17*8f0ba417SAndroid Build Coastguard Worker #pragma once 18*8f0ba417SAndroid Build Coastguard Worker 19*8f0ba417SAndroid Build Coastguard Worker #include <string_view> 20*8f0ba417SAndroid Build Coastguard Worker 21*8f0ba417SAndroid Build Coastguard Worker namespace android { 22*8f0ba417SAndroid Build Coastguard Worker namespace base { 23*8f0ba417SAndroid Build Coastguard Worker 24*8f0ba417SAndroid Build Coastguard Worker // Parse the given string as yes or no inactivation of some sort. Return one of the 25*8f0ba417SAndroid Build Coastguard Worker // ParseBoolResult enumeration values. 26*8f0ba417SAndroid Build Coastguard Worker // 27*8f0ba417SAndroid Build Coastguard Worker // The following values parse as true: 28*8f0ba417SAndroid Build Coastguard Worker // 29*8f0ba417SAndroid Build Coastguard Worker // 1 30*8f0ba417SAndroid Build Coastguard Worker // on 31*8f0ba417SAndroid Build Coastguard Worker // true 32*8f0ba417SAndroid Build Coastguard Worker // y 33*8f0ba417SAndroid Build Coastguard Worker // yes 34*8f0ba417SAndroid Build Coastguard Worker // 35*8f0ba417SAndroid Build Coastguard Worker // 36*8f0ba417SAndroid Build Coastguard Worker // The following values parse as false: 37*8f0ba417SAndroid Build Coastguard Worker // 38*8f0ba417SAndroid Build Coastguard Worker // 0 39*8f0ba417SAndroid Build Coastguard Worker // false 40*8f0ba417SAndroid Build Coastguard Worker // n 41*8f0ba417SAndroid Build Coastguard Worker // no 42*8f0ba417SAndroid Build Coastguard Worker // off 43*8f0ba417SAndroid Build Coastguard Worker // 44*8f0ba417SAndroid Build Coastguard Worker // Anything else is a parse error. 45*8f0ba417SAndroid Build Coastguard Worker // 46*8f0ba417SAndroid Build Coastguard Worker // The purpose of this function is to have a single canonical parser for yes-or-no indications 47*8f0ba417SAndroid Build Coastguard Worker // throughout the system. 48*8f0ba417SAndroid Build Coastguard Worker 49*8f0ba417SAndroid Build Coastguard Worker enum class ParseBoolResult { 50*8f0ba417SAndroid Build Coastguard Worker kError, 51*8f0ba417SAndroid Build Coastguard Worker kFalse, 52*8f0ba417SAndroid Build Coastguard Worker kTrue, 53*8f0ba417SAndroid Build Coastguard Worker }; 54*8f0ba417SAndroid Build Coastguard Worker 55*8f0ba417SAndroid Build Coastguard Worker ParseBoolResult ParseBool(std::string_view s); 56*8f0ba417SAndroid Build Coastguard Worker 57*8f0ba417SAndroid Build Coastguard Worker } // namespace base 58*8f0ba417SAndroid Build Coastguard Worker } // namespace android 59