xref: /aosp_15_r20/frameworks/base/tools/aapt2/text/Unicode.h (revision d57664e9bc4670b3ecf6748a746a57c557b6bc9e)
1*d57664e9SAndroid Build Coastguard Worker /*
2*d57664e9SAndroid Build Coastguard Worker  * Copyright (C) 2017 The Android Open Source Project
3*d57664e9SAndroid Build Coastguard Worker  *
4*d57664e9SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*d57664e9SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*d57664e9SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*d57664e9SAndroid Build Coastguard Worker  *
8*d57664e9SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*d57664e9SAndroid Build Coastguard Worker  *
10*d57664e9SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*d57664e9SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*d57664e9SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*d57664e9SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*d57664e9SAndroid Build Coastguard Worker  * limitations under the License.
15*d57664e9SAndroid Build Coastguard Worker  */
16*d57664e9SAndroid Build Coastguard Worker 
17*d57664e9SAndroid Build Coastguard Worker #ifndef AAPT_TEXT_UNICODE_H
18*d57664e9SAndroid Build Coastguard Worker #define AAPT_TEXT_UNICODE_H
19*d57664e9SAndroid Build Coastguard Worker 
20*d57664e9SAndroid Build Coastguard Worker #include "androidfw/StringPiece.h"
21*d57664e9SAndroid Build Coastguard Worker 
22*d57664e9SAndroid Build Coastguard Worker namespace aapt {
23*d57664e9SAndroid Build Coastguard Worker namespace text {
24*d57664e9SAndroid Build Coastguard Worker 
25*d57664e9SAndroid Build Coastguard Worker // Returns true if the Unicode codepoint has the XID_Start property, meaning it can be used as the
26*d57664e9SAndroid Build Coastguard Worker // first character of a programming language identifier.
27*d57664e9SAndroid Build Coastguard Worker // http://unicode.org/reports/tr31/#Default_Identifier_Syntax
28*d57664e9SAndroid Build Coastguard Worker //
29*d57664e9SAndroid Build Coastguard Worker // XID_Start is a Unicode Derived Core Property. It is a variation of the ID_Start
30*d57664e9SAndroid Build Coastguard Worker // Derived Core Property, accounting for a few characters that, when normalized, yield valid
31*d57664e9SAndroid Build Coastguard Worker // characters in the ID_Start set.
32*d57664e9SAndroid Build Coastguard Worker bool IsXidStart(char32_t codepoint);
33*d57664e9SAndroid Build Coastguard Worker 
34*d57664e9SAndroid Build Coastguard Worker // Returns true if the Unicode codepoint has the XID_Continue property, meaning it can be used in
35*d57664e9SAndroid Build Coastguard Worker // any position of a programming language identifier, except the first.
36*d57664e9SAndroid Build Coastguard Worker // http://unicode.org/reports/tr31/#Default_Identifier_Syntax
37*d57664e9SAndroid Build Coastguard Worker //
38*d57664e9SAndroid Build Coastguard Worker // XID_Continue is a Unicode Derived Core Property. It is a variation of the ID_Continue
39*d57664e9SAndroid Build Coastguard Worker // Derived Core Property, accounting for a few characters that, when normalized, yield valid
40*d57664e9SAndroid Build Coastguard Worker // characters in the ID_Continue set.
41*d57664e9SAndroid Build Coastguard Worker bool IsXidContinue(char32_t codepoint);
42*d57664e9SAndroid Build Coastguard Worker 
43*d57664e9SAndroid Build Coastguard Worker // Returns true if the Unicode codepoint has the White_Space property.
44*d57664e9SAndroid Build Coastguard Worker // http://unicode.org/reports/tr44/#White_Space
45*d57664e9SAndroid Build Coastguard Worker bool IsWhitespace(char32_t codepoint);
46*d57664e9SAndroid Build Coastguard Worker 
47*d57664e9SAndroid Build Coastguard Worker // Returns true if the UTF8 string can be used as a Java identifier.
48*d57664e9SAndroid Build Coastguard Worker // NOTE: This does not check against the set of reserved Java keywords.
49*d57664e9SAndroid Build Coastguard Worker bool IsJavaIdentifier(android::StringPiece str);
50*d57664e9SAndroid Build Coastguard Worker 
51*d57664e9SAndroid Build Coastguard Worker // Returns true if the UTF8 string can be used as the entry name of a resource name.
52*d57664e9SAndroid Build Coastguard Worker // This is the `entry` part of package:type/entry.
53*d57664e9SAndroid Build Coastguard Worker bool IsValidResourceEntryName(android::StringPiece str);
54*d57664e9SAndroid Build Coastguard Worker 
55*d57664e9SAndroid Build Coastguard Worker }  // namespace text
56*d57664e9SAndroid Build Coastguard Worker }  // namespace aapt
57*d57664e9SAndroid Build Coastguard Worker 
58*d57664e9SAndroid Build Coastguard Worker #endif  // AAPT_TEXT_UNICODE_H
59