VirtualBox

source: vbox/trunk/include/iprt/ctype.h@ 33988

Last change on this file since 33988 was 28800, checked in by vboxsync, 15 years ago

Automated rebranding to Oracle copyright/license strings via filemuncher

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.7 KB
Line 
1/** @file
2 * IPRT - Simple character type classiciation and conversion.
3 */
4
5/*
6 * Copyright (C) 2006-2007 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___iprt_ctype_h
27#define ___iprt_ctype_h
28
29#include <iprt/types.h>
30
31/** @name C locale predicates and conversions.
32 *
33 * For most practical purposes, this can safely be used when parsing UTF-8
34 * strings. Just keep in mind that we only deal with the first 127 chars and
35 * that full correctness is only archived using the non-existing RTLocIs* API.
36 *
37 * @remarks Use the marcros, not the inlined functions.
38 *
39 * @remarks ASSUMES the source code includes the basic ASCII chars. This is a
40 * general IPRT assumption.
41 * @{ */
42#define RT_C_IS_BLANK(ch) RTLocCIsBlank((ch))
43#define RT_C_IS_ALNUM(ch) RTLocCIsAlNum((ch))
44#define RT_C_IS_ALPHA(ch) RTLocCIsAlpha((ch))
45#define RT_C_IS_CNTRL(ch) RTLocCIsCntrl((ch))
46#define RT_C_IS_DIGIT(ch) RTLocCIsDigit((ch))
47#define RT_C_IS_LOWER(ch) RTLocCIsLower((ch))
48#define RT_C_IS_GRAPH(ch) RTLocCIsGraph((ch))
49#define RT_C_IS_ODIGIT(ch) RTLocCIsODigit((ch))
50#define RT_C_IS_PRINT(ch) RTLocCIsPrint((ch))
51#define RT_C_IS_PUNCT(ch) RTLocCIsPunct((ch))
52#define RT_C_IS_SPACE(ch) RTLocCIsSpace((ch))
53#define RT_C_IS_UPPER(ch) RTLocCIsUpper((ch))
54#define RT_C_IS_XDIGIT(ch) RTLocCIsXDigit((ch))
55
56#define RT_C_TO_LOWER(ch) RTLocCToLower((ch))
57#define RT_C_TO_UPPER(ch) RTLocCToUpper((ch))
58
59/**
60 * Checks for a blank character.
61 *
62 * @returns true / false.
63 * @param ch The character to test.
64 */
65DECL_FORCE_INLINE(bool) RTLocCIsBlank(int ch)
66{
67 return ch == ' ' || ch == '\t';
68}
69
70/**
71 * Checks for a control character.
72 *
73 * @returns true / false.
74 * @param ch The character to test.
75 */
76DECL_FORCE_INLINE(bool) RTLocCIsCntrl(int ch)
77{
78 return (ch) >= 0 && (ch) < 32;
79}
80
81/**
82 * Checks for a decimal digit.
83 *
84 * @returns true / false.
85 * @param ch The character to test.
86 */
87DECL_FORCE_INLINE(bool) RTLocCIsDigit(int ch)
88{
89 return (ch) >= '0' && (ch) <= '9';
90}
91
92/**
93 * Checks for a lower case character.
94 *
95 * @returns true / false.
96 * @param ch The character to test.
97 */
98DECL_FORCE_INLINE(bool) RTLocCIsLower(int ch)
99{
100 return (ch) >= 'a' && (ch) <= 'z';
101}
102
103/**
104 * Checks for a octal digit.
105 *
106 * @returns true / false.
107 * @param ch The character to test.
108 */
109DECL_FORCE_INLINE(bool) RTLocCIsODigit(int ch)
110{
111 return (ch) >= '0' && (ch) <= '7';
112}
113
114/**
115 * Checks for a printable character (whitespace included).
116 *
117 * @returns true / false.
118 * @param ch The character to test.
119 */
120DECL_FORCE_INLINE(bool) RTLocCIsPrint(int ch)
121{
122 /** @todo quite possibly incorrect */
123 return (ch) >= 32 && (ch) < 127;
124}
125
126/**
127 * Checks for punctuation (?).
128 *
129 * @returns true / false.
130 * @param ch The character to test.
131 */
132DECL_FORCE_INLINE(bool) RTLocCIsPunct(int ch)
133{
134 /** @todo possibly incorrect */
135 return (ch) == ',' || (ch) == '.' || (ch) == ':' || (ch) == ';' || (ch) == '!' || (ch) == '?';
136}
137
138/**
139 * Checks for a white-space character.
140 *
141 * @returns true / false.
142 * @param ch The character to test.
143 */
144DECL_FORCE_INLINE(bool) RTLocCIsSpace(int ch)
145{
146 return (ch) == ' ' || ((ch) >= '\t' && (ch) <= '\f');
147}
148
149/**
150 * Checks for an upper case character.
151 *
152 * @returns true / false.
153 * @param ch The character to test.
154 */
155DECL_FORCE_INLINE(bool) RTLocCIsUpper(int ch)
156{
157 return (ch) >= 'A' && (ch) <= 'Z';
158}
159
160/**
161 * Checks for a hexadecimal digit.
162 *
163 * @returns true / false.
164 * @param ch The character to test.
165 */
166DECL_FORCE_INLINE(bool) RTLocCIsXDigit(int ch)
167{
168 return RTLocCIsDigit(ch) || ((ch) >= 'a' && (ch) <= 'f') || ((ch) >= 'A' && (ch) <= 'F');
169}
170
171/**
172 * Checks for an alphabetic character.
173 *
174 * @returns true / false.
175 * @param ch The character to test.
176 */
177DECL_FORCE_INLINE(bool) RTLocCIsAlpha(int ch)
178{
179 return RTLocCIsLower(ch) || RTLocCIsUpper(ch);
180}
181
182/**
183 * Checks for an alphanumerical character.
184 *
185 * @returns true / false.
186 * @param ch The character to test.
187 */
188DECL_FORCE_INLINE(bool) RTLocCIsAlNum(int ch)
189{
190 return RTLocCIsDigit(ch) || RTLocCIsAlpha(ch);
191}
192
193/**
194 * Checks for a printable character whitespace excluded.
195 *
196 * @returns true / false.
197 * @param ch The character to test.
198 */
199DECL_FORCE_INLINE(bool) RTLocCIsGraph(int ch)
200{
201 return RTLocCIsPrint(ch) && !RTLocCIsBlank(ch);
202}
203
204
205/**
206 * Converts the character to lower case if applictable.
207 *
208 * @returns lower cased character or ch.
209 * @param ch The character to test.
210 */
211DECL_FORCE_INLINE(int) RTLocCToLower(int ch)
212{
213 return RTLocCIsUpper(ch) ? (ch) + ('a' - 'A') : (ch);
214}
215
216/**
217 * Converts the character to upper case if applictable.
218 *
219 * @returns upper cased character or ch.
220 * @param ch The character to test.
221 */
222DECL_FORCE_INLINE(int) RTLocCToUpper(int ch)
223{
224 return RTLocCIsLower(ch) ? (ch) - ('a' - 'A') : (ch);
225}
226
227
228/** @} */
229
230#endif
231
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette