Implement ctype.h functions as inline if possible. cctype can then properly select namespace.
This commit is contained in:
parent
1e40e03c7f
commit
c08cb7ddea
149
include/ctype.h
149
include/ctype.h
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* include/ctype.h
|
* include/ctype.h
|
||||||
*
|
*
|
||||||
* Copyright (C) 2007-2009, 2011, 2014 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2007-2009, 2011, 2014, 2016 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -45,6 +45,8 @@
|
|||||||
* Included Files
|
* Included Files
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/compiler.h>
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Pre-processor Definitions
|
* Pre-processor Definitions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -59,9 +61,17 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isspace(c) \
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
((c) == ' ' || (c) == '\t' || (c) == '\n' || \
|
static inline int isspace(int c)
|
||||||
(c) == '\r' || (c) == '\f' || c== '\v')
|
{
|
||||||
|
return c == ' ' || c == '\t' || c == '\n' || c == '\r' ||
|
||||||
|
c == '\f' || c == '\v';
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isspace(c) \
|
||||||
|
((c) == ' ' || (c) == '\t' || (c) == '\n' || (c) == '\r' || \
|
||||||
|
(c) == '\f' || c== '\v')
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isascii
|
* Name: isascii
|
||||||
@ -72,7 +82,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isascii(c) ((c) >= 0 && (c) <= 0x7f)
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isascii(int c)
|
||||||
|
{
|
||||||
|
return c >= 0 && c <= 0x7f;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isascii(c) ((c) >= 0 && (c) <= 0x7f)
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isprint
|
* Name: isprint
|
||||||
@ -82,7 +99,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isprint(c) ((c) >= 0x20 && (c) < 0x7f)
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isprint(int c)
|
||||||
|
{
|
||||||
|
return c >= 0x20 && c < 0x7f;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isprint(c) ((c) >= 0x20 && (c) < 0x7f)
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isgraph
|
* Name: isgraph
|
||||||
@ -92,7 +116,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isgraph(c) ((c) > 0x20 && (c) < 0x7f)
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isgraph(int c)
|
||||||
|
{
|
||||||
|
return c > 0x20 && c < 0x7f;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isgraph(c) ((c) > 0x20 && (c) < 0x7f)
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: iscntrl
|
* Name: iscntrl
|
||||||
@ -102,7 +133,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define iscntrl(c) (!isprint(c))
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int iscntrl(int c)
|
||||||
|
{
|
||||||
|
return !isprint(c);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define iscntrl(c) (!isprint(c))
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: islower
|
* Name: islower
|
||||||
@ -112,7 +150,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define islower(c) ((c) >= 'a' && (c) <= 'z')
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int islower(int c)
|
||||||
|
{
|
||||||
|
return c >= 'a' && c <= 'z';
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define islower(c) ((c) >= 'a' && (c) <= 'z')
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isupper
|
* Name: isupper
|
||||||
@ -122,7 +167,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isupper(c) ((c) >= 'A' && (c) <= 'Z')
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isupper(int c)
|
||||||
|
{
|
||||||
|
return c >= 'A' && c <= 'Z';
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isupper(c) ((c) >= 'A' && (c) <= 'Z')
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isalpha
|
* Name: isalpha
|
||||||
@ -132,17 +184,31 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isalpha(c) (islower(c) || isupper(c))
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isalpha(int c)
|
||||||
|
{
|
||||||
|
return islower(c) || isupper(c);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isalpha(c) (islower(c) || isupper(c))
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isblank
|
* Name: isblank
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Checks for blank characters (space or tab)
|
* Checks for blank characters (space or tab). C++11
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isblank(c) (isspace(c) || (c) == '\t')
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isblank(int c)
|
||||||
|
{
|
||||||
|
return c == ' ' || c == '\t';
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isblank(c) ((c) == ' ' || (c) == '\t')
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isdigit
|
* Name: isdigit
|
||||||
@ -152,7 +218,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isdigit(c) ((c) >= '0' && (c) <= '9')
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isdigit(int c)
|
||||||
|
{
|
||||||
|
return c >= '0' && c <= '9';
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isdigit(c) ((c) >= '0' && (c) <= '9')
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isalnum
|
* Name: isalnum
|
||||||
@ -162,7 +235,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isalnum(c) (isalpha(c) || isdigit(c))
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isalnum(int c)
|
||||||
|
{
|
||||||
|
return isalpha(c) || isdigit(c);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isalnum(c) (isalpha(c) || isdigit(c))
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: ispunct
|
* Name: ispunct
|
||||||
@ -173,7 +253,14 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define ispunct(c) (isgraph(c) && !isalnum(c))
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int ispunct(int c)
|
||||||
|
{
|
||||||
|
return isgraph(c) && !isalnum(c);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define ispunct(c) (isgraph(c) && !isalnum(c))
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isxdigit
|
* Name: isxdigit
|
||||||
@ -183,10 +270,19 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define isxdigit(c) \
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int isxdigit(int c)
|
||||||
|
{
|
||||||
|
return (c >= '0' && c <= '9') ||
|
||||||
|
(c >= 'a' && c <= 'f') ||
|
||||||
|
(c >= 'A' && c <= 'F');
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define isxdigit(c) \
|
||||||
(((c) >= '0' && (c) <= '9') || \
|
(((c) >= '0' && (c) <= '9') || \
|
||||||
((c) >= 'a' && (c) <= 'f') || \
|
((c) >= 'a' && (c) <= 'f') || \
|
||||||
((c) >= 'A' && (c) <= 'F'))
|
((c) >= 'A' && (c) <= 'F'))
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: toupper
|
* Name: toupper
|
||||||
@ -196,8 +292,15 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define toupper(c) \
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int toupper(int c)
|
||||||
|
{
|
||||||
|
return (c >= 'a' && c <= 'z') ? c - 'a' + 'A' : c;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define toupper(c) \
|
||||||
(((c) >= 'a' && (c) <= 'z') ? ((c) - 'a' + 'A') : (c))
|
(((c) >= 'a' && (c) <= 'z') ? ((c) - 'a' + 'A') : (c))
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: tolower
|
* Name: tolower
|
||||||
@ -207,8 +310,16 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#define tolower(c) \
|
#if defined(CONFIG_HAVE_INLINE) || defined(__cplusplus)
|
||||||
|
static inline int tolower(int c)
|
||||||
|
{
|
||||||
|
return (c >= 'A' && c <= 'Z') ? (c - 'A' + 'a') : c;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
# define tolower(c) \
|
||||||
(((c) >= 'A' && (c) <= 'Z') ? ((c) - 'A' + 'a') : (c))
|
(((c) >= 'A' && (c) <= 'Z') ? ((c) - 'A' + 'a') : (c))
|
||||||
|
# define
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Type Definitions
|
* Public Type Definitions
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
//***************************************************************************
|
//***************************************************************************
|
||||||
// include/cxx/cctype
|
// include/cxx/cctype
|
||||||
//
|
//
|
||||||
// Copyright (C) 2009 Gregory Nutt. All rights reserved.
|
// Copyright (C) 2009, 2016 Gregory Nutt. All rights reserved.
|
||||||
// Author: Gregory Nutt <gnutt@nuttx.org>
|
// Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
//
|
//
|
||||||
// Redistribution and use in source and binary forms, with or without
|
// Redistribution and use in source and binary forms, with or without
|
||||||
@ -42,29 +42,27 @@
|
|||||||
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
// Remove macros in favor of builtin implementations
|
|
||||||
|
|
||||||
#if !defined(CONFIG_UCLIBCXX)
|
|
||||||
|
|
||||||
#undef isalnum
|
|
||||||
#undef isalpha
|
|
||||||
#undef iscntrl
|
|
||||||
#undef isdigit
|
|
||||||
#undef isgraph
|
|
||||||
#undef islower
|
|
||||||
#undef isprint
|
|
||||||
#undef ispunct
|
|
||||||
#undef isspace
|
|
||||||
#undef isblank
|
|
||||||
#undef isupper
|
|
||||||
#undef isxdigit
|
|
||||||
#undef tolower
|
|
||||||
#undef toupper
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//***************************************************************************
|
//***************************************************************************
|
||||||
// Namespace
|
// Namespace
|
||||||
//***************************************************************************
|
//***************************************************************************
|
||||||
|
|
||||||
|
namespace std
|
||||||
|
{
|
||||||
|
using ::isspace;
|
||||||
|
using ::isascii;
|
||||||
|
using ::isprint;
|
||||||
|
using ::isgraph;
|
||||||
|
using ::iscntrl;
|
||||||
|
using ::islower;
|
||||||
|
using ::isupper;
|
||||||
|
using ::isalpha;
|
||||||
|
using ::isblank;
|
||||||
|
using ::isdigit;
|
||||||
|
using ::isalnum;
|
||||||
|
using ::ispunct;
|
||||||
|
using ::isxdigit;
|
||||||
|
using ::toupper;
|
||||||
|
using ::tolower;
|
||||||
|
}
|
||||||
|
|
||||||
#endif // __INCLUDE_CXX_CCTYPE
|
#endif // __INCLUDE_CXX_CCTYPE
|
||||||
|
Loading…
Reference in New Issue
Block a user