xref: /aosp_15_r20/platform_testing/utils/shell-as/string-utils.h (revision dd0948b35e70be4c0246aabd6c72554a5eb8b22a)
1*dd0948b3SAndroid Build Coastguard Worker /*
2*dd0948b3SAndroid Build Coastguard Worker  * Copyright (C) 2023 The Android Open Source Project
3*dd0948b3SAndroid Build Coastguard Worker  *
4*dd0948b3SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*dd0948b3SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*dd0948b3SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*dd0948b3SAndroid Build Coastguard Worker  *
8*dd0948b3SAndroid Build Coastguard Worker  *     http://www.apache.org/licenses/LICENSE-2.0
9*dd0948b3SAndroid Build Coastguard Worker  *
10*dd0948b3SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*dd0948b3SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*dd0948b3SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*dd0948b3SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*dd0948b3SAndroid Build Coastguard Worker  * limitations under the License.
15*dd0948b3SAndroid Build Coastguard Worker  */
16*dd0948b3SAndroid Build Coastguard Worker 
17*dd0948b3SAndroid Build Coastguard Worker #ifndef SHELL_AS_STRING_UTILS_H_
18*dd0948b3SAndroid Build Coastguard Worker #define SHELL_AS_STRING_UTILS_H_
19*dd0948b3SAndroid Build Coastguard Worker 
20*dd0948b3SAndroid Build Coastguard Worker #include <unistd.h>
21*dd0948b3SAndroid Build Coastguard Worker 
22*dd0948b3SAndroid Build Coastguard Worker #include <vector>
23*dd0948b3SAndroid Build Coastguard Worker 
24*dd0948b3SAndroid Build Coastguard Worker namespace shell_as {
25*dd0948b3SAndroid Build Coastguard Worker 
26*dd0948b3SAndroid Build Coastguard Worker // Parses a string into an unsigned 32bit int value. Returns true on success and
27*dd0948b3SAndroid Build Coastguard Worker // false otherwise.
28*dd0948b3SAndroid Build Coastguard Worker bool StringToUInt32(const char* s, uint32_t* i);
29*dd0948b3SAndroid Build Coastguard Worker 
30*dd0948b3SAndroid Build Coastguard Worker // Parses a string into a unsigned 64bit int value. Returns true on success and
31*dd0948b3SAndroid Build Coastguard Worker // false otherwise.
32*dd0948b3SAndroid Build Coastguard Worker bool StringToUInt64(const char* s, uint64_t* i);
33*dd0948b3SAndroid Build Coastguard Worker 
34*dd0948b3SAndroid Build Coastguard Worker // Splits a line of uid_t/guid_t values by a given separator and returns the
35*dd0948b3SAndroid Build Coastguard Worker // integer values in a vector.
36*dd0948b3SAndroid Build Coastguard Worker //
37*dd0948b3SAndroid Build Coastguard Worker // The separators string may contain multiple characters and is treated as a set
38*dd0948b3SAndroid Build Coastguard Worker // of possible separating characters.
39*dd0948b3SAndroid Build Coastguard Worker //
40*dd0948b3SAndroid Build Coastguard Worker // If num_to_skip is non-zero, then that many entries will be skipped after
41*dd0948b3SAndroid Build Coastguard Worker // splitting the line and before parsing the values as integers. This is useful
42*dd0948b3SAndroid Build Coastguard Worker // if the line has a prefix such as "Gid: 1 2 3 4".
43*dd0948b3SAndroid Build Coastguard Worker //
44*dd0948b3SAndroid Build Coastguard Worker // Returns true on success and false otherwise.
45*dd0948b3SAndroid Build Coastguard Worker bool SplitIdsAndSkip(char* line, const char* separators, int num_to_skip,
46*dd0948b3SAndroid Build Coastguard Worker                      std::vector<uid_t>* ids);
47*dd0948b3SAndroid Build Coastguard Worker 
48*dd0948b3SAndroid Build Coastguard Worker }  // namespace shell_as
49*dd0948b3SAndroid Build Coastguard Worker 
50*dd0948b3SAndroid Build Coastguard Worker #endif  // SHELL_AS_STRING_UTILS_H_
51