2000-02-17 20:39:52 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
FUNCTION
|
|
|
|
<<isupper>>---uppercase character predicate
|
|
|
|
|
|
|
|
INDEX
|
|
|
|
isupper
|
|
|
|
|
|
|
|
ANSI_SYNOPSIS
|
|
|
|
#include <ctype.h>
|
|
|
|
int isupper(int <[c]>);
|
|
|
|
|
|
|
|
TRAD_SYNOPSIS
|
|
|
|
#include <ctype.h>
|
|
|
|
int isupper(<[c]>);
|
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
<<isupper>> is a macro which classifies ASCII integer values by table
|
2005-10-28 23:33:23 +02:00
|
|
|
lookup. It is a predicate returning non-zero for uppercase letters
|
2000-02-17 20:39:52 +01:00
|
|
|
(<<A>>--<<Z>>), and 0 for other characters. It is defined only when
|
|
|
|
<<isascii>>(<[c]>) is true or <[c]> is EOF.
|
|
|
|
|
|
|
|
You can use a compiled subroutine instead of the macro definition by
|
|
|
|
undefining the macro using `<<#undef isupper>>'.
|
|
|
|
|
|
|
|
RETURNS
|
2005-10-28 23:33:23 +02:00
|
|
|
<<isupper>> returns non-zero if <[c]> is a uppercase letter (A-Z).
|
2000-02-17 20:39:52 +01:00
|
|
|
|
|
|
|
PORTABILITY
|
|
|
|
<<isupper>> is ANSI C.
|
|
|
|
|
|
|
|
No supporting OS subroutines are required.
|
|
|
|
*/
|
|
|
|
#include <_ansi.h>
|
|
|
|
#include <ctype.h>
|
|
|
|
|
|
|
|
#undef isupper
|
|
|
|
int
|
|
|
|
_DEFUN(isupper,(c),int c)
|
|
|
|
{
|
2016-07-13 16:51:33 +02:00
|
|
|
return ((__CTYPE_PTR[c+1] & (_U|_L)) == _U);
|
2000-02-17 20:39:52 +01:00
|
|
|
}
|
|
|
|
|