1) Bring '!!' back since we wan't overflow even a char

2) Revive __maskrune, just return mask now
3) Express __istype via !!__maskrune
4) Use __maskrune in digittoint
This commit is contained in:
Andrey A. Chernov 1997-09-27 04:22:47 +00:00
parent 920de53083
commit 917065108a
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=29883
2 changed files with 38 additions and 34 deletions

View File

@ -88,17 +88,19 @@ int digittoint __P((int));
#endif #endif
__END_DECLS __END_DECLS
#define isalnum(c) __istype((c), (_A|_D)) #define __istype(c,f) (!!__maskrune((c),(f))
#define isalpha(c) __istype((c), _A)
#define iscntrl(c) __istype((c), _C) #define isalnum(c) __istype((c), _A|_D)
#define isdigit(c) __isctype((c), _D) /* ANSI -- locale independent */ #define isalpha(c) __istype((c), _A)
#define isgraph(c) __istype((c), _G) #define iscntrl(c) __istype((c), _C)
#define islower(c) __istype((c), _L) #define isdigit(c) __isctype((c), _D) /* ANSI -- locale independent */
#define isprint(c) __istype((c), _R) #define isgraph(c) __istype((c), _G)
#define ispunct(c) __istype((c), _P) #define islower(c) __istype((c), _L)
#define isspace(c) __istype((c), _S) #define isprint(c) __istype((c), _R)
#define isupper(c) __istype((c), _U) #define ispunct(c) __istype((c), _P)
#define isxdigit(c) __isctype((c), _X) /* ANSI -- locale independent */ #define isspace(c) __istype((c), _S)
#define isupper(c) __istype((c), _U)
#define isxdigit(c) __isctype((c), _X) /* ANSI -- locale independent */
#define tolower(c) __tolower(c) #define tolower(c) __tolower(c)
#define toupper(c) __toupper(c) #define toupper(c) __toupper(c)
@ -106,15 +108,15 @@ __END_DECLS
#define isascii(c) (((c) & ~0x7F) == 0) #define isascii(c) (((c) & ~0x7F) == 0)
#define isblank(c) __istype((c), _B) #define isblank(c) __istype((c), _B)
#define toascii(c) ((c) & 0x7F) #define toascii(c) ((c) & 0x7F)
#define digittoint(c) __istype((c), 0xFF) #define digittoint(c) __maskrune((c), 0xFF)
/* XXX the following macros are not backed up by functions. */ /* XXX the following macros are not backed up by functions. */
#define ishexnumber(c) __istype((c), _X) #define ishexnumber(c) __istype((c), _X)
#define isideogram(c) __istype((c), _I) #define isideogram(c) __istype((c), _I)
#define isnumber(c) __istype((c), _D) #define isnumber(c) __istype((c), _D)
#define isphonogram(c) __istype((c), _Q) #define isphonogram(c) __istype((c), _Q)
#define isrune(c) __istype((c), 0xFFFFFF00L) #define isrune(c) __istype((c), 0xFFFFFF00L)
#define isspecial(c) __istype((c), _T) #define isspecial(c) __istype((c), _T)
#endif #endif
/* See comments in <machine/ansi.h> about _BSD_CT_RUNE_T_. */ /* See comments in <machine/ansi.h> about _BSD_CT_RUNE_T_. */
@ -140,7 +142,7 @@ __END_DECLS
#if !defined(_DONT_USE_CTYPE_INLINE_) && \ #if !defined(_DONT_USE_CTYPE_INLINE_) && \
(defined(_USE_CTYPE_INLINE_) || defined(__GNUC__) || defined(__cplusplus)) (defined(_USE_CTYPE_INLINE_) || defined(__GNUC__) || defined(__cplusplus))
static __inline int static __inline int
__istype(_BSD_CT_RUNE_T_ _c, unsigned long _f) __maskrune(_BSD_CT_RUNE_T_ _c, unsigned long _f)
{ {
return ((_c < 0 || _c >= _CACHED_RUNES) ? ___runetype(_c) : return ((_c < 0 || _c >= _CACHED_RUNES) ? ___runetype(_c) :
_CurrentRuneLocale->runetype[_c]) & _f; _CurrentRuneLocale->runetype[_c]) & _f;
@ -150,7 +152,7 @@ static __inline int
__isctype(_BSD_CT_RUNE_T_ _c, unsigned long _f) __isctype(_BSD_CT_RUNE_T_ _c, unsigned long _f)
{ {
return (_c < 0 || _c >= _CACHED_RUNES) ? 0 : return (_c < 0 || _c >= _CACHED_RUNES) ? 0 :
(_DefaultRuneLocale.runetype[_c] & _f); !!(_DefaultRuneLocale.runetype[_c] & _f);
} }
static __inline _BSD_CT_RUNE_T_ static __inline _BSD_CT_RUNE_T_
@ -170,7 +172,7 @@ __tolower(_BSD_CT_RUNE_T_ _c)
#else /* not using inlines */ #else /* not using inlines */
__BEGIN_DECLS __BEGIN_DECLS
int __istype __P((_BSD_CT_RUNE_T_, unsigned long)); int __maskrune __P((_BSD_CT_RUNE_T_, unsigned long));
int __isctype __P((_BSD_CT_RUNE_T_, unsigned long)); int __isctype __P((_BSD_CT_RUNE_T_, unsigned long));
_BSD_CT_RUNE_T_ __toupper __P((_BSD_CT_RUNE_T_)); _BSD_CT_RUNE_T_ __toupper __P((_BSD_CT_RUNE_T_));
_BSD_CT_RUNE_T_ __tolower __P((_BSD_CT_RUNE_T_)); _BSD_CT_RUNE_T_ __tolower __P((_BSD_CT_RUNE_T_));

View File

@ -88,17 +88,19 @@ int digittoint __P((int));
#endif #endif
__END_DECLS __END_DECLS
#define isalnum(c) __istype((c), (_A|_D)) #define __istype(c,f) (!!__maskrune((c),(f))
#define isalpha(c) __istype((c), _A)
#define iscntrl(c) __istype((c), _C) #define isalnum(c) __istype((c), _A|_D)
#define isdigit(c) __isctype((c), _D) /* ANSI -- locale independent */ #define isalpha(c) __istype((c), _A)
#define isgraph(c) __istype((c), _G) #define iscntrl(c) __istype((c), _C)
#define islower(c) __istype((c), _L) #define isdigit(c) __isctype((c), _D) /* ANSI -- locale independent */
#define isprint(c) __istype((c), _R) #define isgraph(c) __istype((c), _G)
#define ispunct(c) __istype((c), _P) #define islower(c) __istype((c), _L)
#define isspace(c) __istype((c), _S) #define isprint(c) __istype((c), _R)
#define isupper(c) __istype((c), _U) #define ispunct(c) __istype((c), _P)
#define isxdigit(c) __isctype((c), _X) /* ANSI -- locale independent */ #define isspace(c) __istype((c), _S)
#define isupper(c) __istype((c), _U)
#define isxdigit(c) __isctype((c), _X) /* ANSI -- locale independent */
#define tolower(c) __tolower(c) #define tolower(c) __tolower(c)
#define toupper(c) __toupper(c) #define toupper(c) __toupper(c)
@ -106,15 +108,15 @@ __END_DECLS
#define isascii(c) (((c) & ~0x7F) == 0) #define isascii(c) (((c) & ~0x7F) == 0)
#define isblank(c) __istype((c), _B) #define isblank(c) __istype((c), _B)
#define toascii(c) ((c) & 0x7F) #define toascii(c) ((c) & 0x7F)
#define digittoint(c) __istype((c), 0xFF) #define digittoint(c) __maskrune((c), 0xFF)
/* XXX the following macros are not backed up by functions. */ /* XXX the following macros are not backed up by functions. */
#define ishexnumber(c) __istype((c), _X) #define ishexnumber(c) __istype((c), _X)
#define isideogram(c) __istype((c), _I) #define isideogram(c) __istype((c), _I)
#define isnumber(c) __istype((c), _D) #define isnumber(c) __istype((c), _D)
#define isphonogram(c) __istype((c), _Q) #define isphonogram(c) __istype((c), _Q)
#define isrune(c) __istype((c), 0xFFFFFF00L) #define isrune(c) __istype((c), 0xFFFFFF00L)
#define isspecial(c) __istype((c), _T) #define isspecial(c) __istype((c), _T)
#endif #endif
/* See comments in <machine/ansi.h> about _BSD_CT_RUNE_T_. */ /* See comments in <machine/ansi.h> about _BSD_CT_RUNE_T_. */
@ -140,7 +142,7 @@ __END_DECLS
#if !defined(_DONT_USE_CTYPE_INLINE_) && \ #if !defined(_DONT_USE_CTYPE_INLINE_) && \
(defined(_USE_CTYPE_INLINE_) || defined(__GNUC__) || defined(__cplusplus)) (defined(_USE_CTYPE_INLINE_) || defined(__GNUC__) || defined(__cplusplus))
static __inline int static __inline int
__istype(_BSD_CT_RUNE_T_ _c, unsigned long _f) __maskrune(_BSD_CT_RUNE_T_ _c, unsigned long _f)
{ {
return ((_c < 0 || _c >= _CACHED_RUNES) ? ___runetype(_c) : return ((_c < 0 || _c >= _CACHED_RUNES) ? ___runetype(_c) :
_CurrentRuneLocale->runetype[_c]) & _f; _CurrentRuneLocale->runetype[_c]) & _f;
@ -150,7 +152,7 @@ static __inline int
__isctype(_BSD_CT_RUNE_T_ _c, unsigned long _f) __isctype(_BSD_CT_RUNE_T_ _c, unsigned long _f)
{ {
return (_c < 0 || _c >= _CACHED_RUNES) ? 0 : return (_c < 0 || _c >= _CACHED_RUNES) ? 0 :
(_DefaultRuneLocale.runetype[_c] & _f); !!(_DefaultRuneLocale.runetype[_c] & _f);
} }
static __inline _BSD_CT_RUNE_T_ static __inline _BSD_CT_RUNE_T_
@ -170,7 +172,7 @@ __tolower(_BSD_CT_RUNE_T_ _c)
#else /* not using inlines */ #else /* not using inlines */
__BEGIN_DECLS __BEGIN_DECLS
int __istype __P((_BSD_CT_RUNE_T_, unsigned long)); int __maskrune __P((_BSD_CT_RUNE_T_, unsigned long));
int __isctype __P((_BSD_CT_RUNE_T_, unsigned long)); int __isctype __P((_BSD_CT_RUNE_T_, unsigned long));
_BSD_CT_RUNE_T_ __toupper __P((_BSD_CT_RUNE_T_)); _BSD_CT_RUNE_T_ __toupper __P((_BSD_CT_RUNE_T_));
_BSD_CT_RUNE_T_ __tolower __P((_BSD_CT_RUNE_T_)); _BSD_CT_RUNE_T_ __tolower __P((_BSD_CT_RUNE_T_));