2000-02-17 20:39:52 +01:00
|
|
|
/*
|
|
|
|
FUNCTION
|
2016-08-15 14:21:52 +02:00
|
|
|
<<ispunct>>, <<ispunct_l>>---punctuation character predicate
|
|
|
|
|
|
|
|
INDEX
|
|
|
|
ispunct
|
2000-02-17 20:39:52 +01:00
|
|
|
|
|
|
|
INDEX
|
2016-08-15 14:21:52 +02:00
|
|
|
ispunct_l
|
2000-02-17 20:39:52 +01:00
|
|
|
|
2017-11-30 08:17:11 +01:00
|
|
|
SYNOPSIS
|
2016-08-15 14:21:52 +02:00
|
|
|
#include <ctype.h>
|
|
|
|
int ispunct(int <[c]>);
|
|
|
|
|
|
|
|
#include <ctype.h>
|
|
|
|
int ispunct_l(int <[c]>, locale_t <[locale]>);
|
2000-02-17 20:39:52 +01:00
|
|
|
|
|
|
|
DESCRIPTION
|
2016-08-15 14:21:52 +02:00
|
|
|
<<ispunct>> is a macro which classifies singlebyte charset values by table
|
2000-02-17 20:39:52 +01:00
|
|
|
lookup. It is a predicate returning non-zero for printable
|
2013-05-23 16:46:51 +02:00
|
|
|
punctuation characters, and 0 for other characters. It is defined only
|
|
|
|
if <[c]> is representable as an unsigned char or if <[c]> is EOF.
|
2000-02-17 20:39:52 +01:00
|
|
|
|
2016-08-15 14:21:52 +02:00
|
|
|
<<ispunct_l>> is like <<ispunct>> but performs the check based on the
|
|
|
|
locale specified by the locale object locale. If <[locale]> is
|
|
|
|
LC_GLOBAL_LOCALE or not a valid locale object, the behaviour is undefined.
|
|
|
|
|
2000-02-17 20:39:52 +01:00
|
|
|
You can use a compiled subroutine instead of the macro definition by
|
2016-08-15 14:21:52 +02:00
|
|
|
undefining the macro using `<<#undef ispunct>>' or `<<#undef ispunct_l>>'.
|
2000-02-17 20:39:52 +01:00
|
|
|
|
|
|
|
RETURNS
|
2016-08-15 14:21:52 +02:00
|
|
|
<<ispunct>>, <<ispunct_l>> return non-zero if <[c]> is a printable
|
|
|
|
punctuation character.
|
2000-02-17 20:39:52 +01:00
|
|
|
|
|
|
|
PORTABILITY
|
|
|
|
<<ispunct>> is ANSI C.
|
2016-08-15 14:21:52 +02:00
|
|
|
<<ispunct_l>> is POSIX-1.2008.
|
2000-02-17 20:39:52 +01:00
|
|
|
|
|
|
|
No supporting OS subroutines are required.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <_ansi.h>
|
|
|
|
#include <ctype.h>
|
|
|
|
|
|
|
|
|
|
|
|
#undef ispunct
|
|
|
|
int
|
2017-12-04 04:43:30 +01:00
|
|
|
ispunct (int c)
|
2000-02-17 20:39:52 +01:00
|
|
|
{
|
2016-07-13 16:51:33 +02:00
|
|
|
return(__CTYPE_PTR[c+1] & _P);
|
2000-02-17 20:39:52 +01:00
|
|
|
}
|