1 /******************************************************************************
2  *
3  *  Copyright 2003-2012 Broadcom Corporation
4  *
5  *  Licensed under the Apache License, Version 2.0 (the "License");
6  *  you may not use this file except in compliance with the License.
7  *  You may obtain a copy of the License at:
8  *
9  *  http://www.apache.org/licenses/LICENSE-2.0
10  *
11  *  Unless required by applicable law or agreed to in writing, software
12  *  distributed under the License is distributed on an "AS IS" BASIS,
13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  *  See the License for the specific language governing permissions and
15  *  limitations under the License.
16  *
17  ******************************************************************************/
18 
19 /******************************************************************************
20  *
21  *  Basic utility functions.
22  *
23  ******************************************************************************/
24 #ifndef UTL_H
25 #define UTL_H
26 
27 #include <cstdint>
28 
29 /*****************************************************************************
30  *  Constants
31  ****************************************************************************/
32 /*** class of device settings ***/
33 #define BTA_UTL_SET_COD_MAJOR_MINOR 0x01
34 #define BTA_UTL_SET_COD_SERVICE_CLASS    \
35   0x02 /* only set the bits in the input \
36           */
37 #define BTA_UTL_CLR_COD_SERVICE_CLASS 0x04
38 #define BTA_UTL_SET_COD_ALL \
39   0x08 /* take service class as the input (may clear some set bits!!) */
40 #define BTA_UTL_INIT_COD 0x0a
41 
42 /*****************************************************************************
43  *  Type Definitions
44  ****************************************************************************/
45 
46 /** for utl_set_device_class() **/
47 typedef struct {
48   uint8_t minor;
49   uint8_t major;
50   uint16_t service;
51 } tBTA_UTL_COD;
52 
53 /*****************************************************************************
54  *  External Function Declarations
55  ****************************************************************************/
56 
57 /*******************************************************************************
58  *
59  * Function         utl_str2int
60  *
61  * Description      This utility function converts a character string to an
62  *                  integer.  Acceptable values in string are 0-9.  If invalid
63  *                  string or string value too large, -1 is returned.
64  *
65  *
66  * Returns          Integer value or -1 on error.
67  *
68  ******************************************************************************/
69 int16_t utl_str2int(const char* p_s);
70 
71 /*******************************************************************************
72  *
73  * Function         utl_strucmp
74  *
75  * Description      This utility function compares two strings in uppercase.
76  *                  String p_s must be uppercase.  String p_t is converted to
77  *                  uppercase if lowercase.  If p_s ends first, the substring
78  *                  match is counted as a match.
79  *
80  *
81  * Returns          0 if strings match, nonzero otherwise.
82  *
83  ******************************************************************************/
84 int utl_strucmp(const char* p_s, const char* p_t);
85 
86 /*******************************************************************************
87  *
88  * Function         utl_itoa
89  *
90  * Description      This utility function converts a uint16_t to a string.  The
91  *                  string is NULL-terminated.  The length of the string is
92  *                  returned.
93  *
94  *
95  * Returns          Length of string.
96  *
97  ******************************************************************************/
98 uint8_t utl_itoa(uint16_t i, char* p_s);
99 
100 /*******************************************************************************
101  *
102  * Function         utl_set_device_class
103  *
104  * Description      This function updates the local Device Class.
105  *
106  * Parameters:
107  *                  p_cod   - Pointer to the device class to set to
108  *
109  *                  cmd     - the fields of the device class to update.
110  *                            BTA_UTL_SET_COD_MAJOR_MINOR, - overwrite major,
111  *                                                           minor class
112  *                            BTA_UTL_SET_COD_SERVICE_CLASS - set the bits in
113  *                                                            the input
114  *                            BTA_UTL_CLR_COD_SERVICE_CLASS - clear the bits in
115  *                                                            the input
116  *                            BTA_UTL_SET_COD_ALL - overwrite major, minor, set
117  *                                                  the bits in service class
118  *                            BTA_UTL_INIT_COD - overwrite major, minor, and
119  *                                               service class
120  *
121  * Returns          true if successful, Otherwise false
122  *
123  ******************************************************************************/
124 bool utl_set_device_class(tBTA_UTL_COD* p_cod, uint8_t cmd);
125 
126 /*******************************************************************************
127  *
128  * Function         utl_isintstr
129  *
130  * Description      This utility function checks if the given string is an
131  *                  integer string or not
132  *
133  *
134  * Returns          true if successful, Otherwise false
135  *
136  ******************************************************************************/
137 bool utl_isintstr(const char* p_s);
138 
139 /*******************************************************************************
140  *
141  * Function         utl_isdialchar
142  *
143  * Description      This utility function checks if the given character
144  *                  is an acceptable dial digit
145  *
146  * Returns          true if successful, Otherwise false
147  *
148  ******************************************************************************/
149 bool utl_isdialchar(const char d);
150 
151 /*******************************************************************************
152  *
153  * Function         utl_isdialstr
154  *
155  * Description      This utility function checks if the given string contains
156  *                  only dial digits or not
157  *
158  *
159  * Returns          true if successful, Otherwise false
160  *
161  ******************************************************************************/
162 bool utl_isdialstr(const char* p_s);
163 
164 #endif /* UTL_H */
165