]> git.ipfire.org Git - thirdparty/ipxe.git/commitdiff
[libc] Rewrite unrelicensable portions of ctype.h
authorMichael Brown <mcb30@ipxe.org>
Mon, 2 Mar 2015 14:41:49 +0000 (14:41 +0000)
committerMichael Brown <mcb30@ipxe.org>
Mon, 2 Mar 2015 16:35:37 +0000 (16:35 +0000)
Signed-off-by: Michael Brown <mcb30@ipxe.org>
src/core/ctype.c
src/include/ctype.h

index 2941daf9d78bdcd59f914e2090fee82d8688e05b..891af71eac0267be481312c1887f5f3b524e68b0 100644 (file)
@@ -35,11 +35,12 @@ FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
 /**
  * Check to see if character is a space
  *
- * @v c                        Character
+ * @v character                Character
  * @ret isspace                Character is a space
  */
-int isspace ( int c ) {
-       switch ( c ) {
+int isspace ( int character ) {
+
+       switch ( character ) {
        case ' ' :
        case '\f' :
        case '\n' :
index e92ecb1c0b19fa958d14f9504f36c3a3fa432c20..0d79ecd195a5dc76b5bf600af0afa4ec3677d96b 100644 (file)
 /** @file
  *
  * Character types
+ *
  */
 
-FILE_LICENCE ( GPL2_OR_LATER );
+FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
 
-#define isdigit(c)     ((c) >= '0' && (c) <= '9')
-#define islower(c)     ((c) >= 'a' && (c) <= 'z')
-#define isupper(c)     ((c) >= 'A' && (c) <= 'Z')
-#define isxdigit(c)    (isdigit(c) || ((c) >= 'A' && (c) <= 'F') || ((c) >= 'a' && (c) <= 'f'))
-#define isprint(c)     ((c) >= ' ' && (c) <= '~' )
+/**
+ * Check if character is a decimal digit
+ *
+ * @v character                ASCII character
+ * @ret is_digit       Character is a decimal digit
+ */
+static inline int isdigit ( int character ) {
 
-static inline unsigned char tolower(unsigned char c)
-{
-       if (isupper(c))
-               c -= 'A'-'a';
-       return c;
+       return ( ( character >= '0' ) && ( character <= '9' ) );
 }
 
-static inline unsigned char toupper(unsigned char c)
-{
-       if (islower(c))
-               c -= 'a'-'A';
-       return c;
+/**
+ * Check if character is a hexadecimal digit
+ *
+ * @v character                ASCII character
+ * @ret is_xdigit      Character is a hexadecimal digit
+ */
+static inline int isxdigit ( int character ) {
+
+       return ( ( ( character >= '0' ) && ( character <= '9' ) ) ||
+                ( ( character >= 'A' ) && ( character <= 'F' ) ) ||
+                ( ( character >= 'a' ) && ( character <= 'f' ) ) );
+}
+
+/**
+ * Check if character is an upper-case letter
+ *
+ * @v character                ASCII character
+ * @ret is_upper       Character is an upper-case letter
+ */
+static inline int isupper ( int character ) {
+
+       return ( ( character >= 'A' ) && ( character <= 'Z' ) );
+}
+
+/**
+ * Check if character is a lower-case letter
+ *
+ * @v character                ASCII character
+ * @ret is_lower       Character is a lower-case letter
+ */
+static inline int islower ( int character ) {
+
+       return ( ( character >= 'a' ) && ( character <= 'z' ) );
+}
+
+/**
+ * Check if character is alphabetic
+ *
+ * @v character                ASCII character
+ * @ret is_alpha       Character is alphabetic
+ */
+static inline int isalpha ( int character ) {
+
+       return ( isupper ( character ) || islower ( character ) );
+}
+
+/**
+ * Check if character is alphanumeric
+ *
+ * @v character                ASCII character
+ * @ret is_alnum       Character is alphanumeric
+ */
+static inline int isalnum ( int character ) {
+
+       return ( isalpha ( character ) || isdigit ( character ) );
+}
+
+/**
+ * Check if character is printable
+ *
+ * @v character                ASCII character
+ * @ret is_print       Character is printable
+ */
+static inline int isprint ( int character ) {
+
+       return ( ( character >= ' ' ) && ( character <= '~' ) );
+}
+
+/**
+ * Convert character to lower case
+ *
+ * @v character                Character
+ * @v character                Lower-case character
+ */
+static inline int tolower ( int character ) {
+
+       return ( isupper ( character ) ?
+                ( character - 'A' + 'a' ) : character );
+}
+
+/**
+ * Convert character to upper case
+ *
+ * @v character                Character
+ * @v character                Upper-case character
+ */
+static inline int toupper ( int character ) {
+
+       return ( islower ( character ) ?
+                ( character - 'a' + 'A' ) : character );
 }
 
-extern int isspace ( int c );
+extern int isspace ( int character );
 
 #endif /* _CTYPE_H */