std::ispunct
<cctype> 
 Checks if the given character is a punctuation character as classified by the current C locale. The default C locale classifies the characters (!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~) as punctuation.
The behavior is undefined if the value of ch is not representable as unsigned char and is not equal to EOF .
Contents
[edit] Parameters
[edit] Return value
Non-zero value if the character is a punctuation character, zero otherwise.
[edit] Notes
Like all other functions from <cctype>, the behavior of std::ispunct is undefined if the argument's value is neither representable as unsigned char nor equal to EOF . To use these functions safely with plain chars (or signed chars), the argument should first be converted to unsigned char:
bool my_ispunct(char ch) { return std::ispunct(static_cast<unsigned char>(ch)); }
Similarly, they should not be directly used with standard algorithms when the iterator's value type is char or signed char. Instead, convert the value to unsigned char first:
int count_puncts(const std::string & s) { return std::count_if (s.begin(), s.end(), // static_cast<int(*)(int)>(std::ispunct) // wrong // [](int c){ return std::ispunct(c); } // wrong // [](char c){ return std::ispunct(c); } // wrong [](unsigned char c){ return std::ispunct(c); } // correct ); }
[edit] Example
#include <cctype> #include <clocale> #include <iostream> int main() { unsigned char c = '\xd7'; // the character ×ばつ (multiplication sign) in ISO-8859-1 std::cout << "ispunct(\'\\xd7\', default C locale) returned " << std::boolalpha << (bool)std::ispunct(c) << '\n'; std::setlocale (LC_ALL, "en_GB.iso88591"); std::cout << "ispunct(\'\\xd7\', ISO-8859-1 locale) returned " << std::boolalpha << (bool)std::ispunct(c) << '\n'; }
Possible output:
ispunct('\xd7', default C locale) returned false
ispunct('\xd7', ISO-8859-1 locale) returned true[edit] See also
| ASCII values | characters | ispunct | |||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| decimal | hexadecimal | octal | |||||||||||||
| 0–8 | \x0–\x8 | 0円–10円 | control codes ( NUL, etc.) | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 9 | \x9 | 11円 | tab ( \t) | ≠0 | 0 | ≠0 | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 10–13 | \xA–\xD | 12円–15円 | whitespaces ( \n,\v,\f,\r) | ≠0 | 0 | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 14–31 | \xE–\x1F | 16円–37円 | control codes | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 32 | \x20 | 40円 | space | 0 | ≠0 | ≠0 | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 33–47 | \x21–\x2F | 41円–57円 | !"#$%&'()*+,-./ | 0 | ≠0 | 0 | 0 | ≠0 | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 48–57 | \x30–\x39 | 60円–71円 | 0123456789 | 0 | ≠0 | 0 | 0 | ≠0 | 0 | ≠0 | 0 | 0 | 0 | ≠0 | ≠0 | 
| 58–64 | \x3A–\x40 | 72円–100円 | :;<=>?@ | 0 | ≠0 | 0 | 0 | ≠0 | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 65–70 | \x41–\x46 | 101円–106円 | ABCDEF | 0 | ≠0 | 0 | 0 | ≠0 | 0 | ≠0 | ≠0 | ≠0 | 0 | 0 | ≠0 | 
| 71–90 | \x47–\x5A | 107円–132円 | GHIJKLMNOPQRSTUVWXYZ | 0 | ≠0 | 0 | 0 | ≠0 | 0 | ≠0 | ≠0 | ≠0 | 0 | 0 | 0 | 
| 91–96 | \x5B–\x60 | 133円–140円 | [\]^_` | 0 | ≠0 | 0 | 0 | ≠0 | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 97–102 | \x61–\x66 | 141円–146円 | abcdef | 0 | ≠0 | 0 | 0 | ≠0 | 0 | ≠0 | ≠0 | 0 | ≠0 | 0 | ≠0 | 
| 103–122 | \x67–\x7A | 147円–172円 | ghijklmnopqrstuvwxyz | 0 | ≠0 | 0 | 0 | ≠0 | 0 | ≠0 | ≠0 | 0 | ≠0 | 0 | 0 | 
| 123–126 | \x7B–\x7E | 172円–176円 | {|}~ | 0 | ≠0 | 0 | 0 | ≠0 | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| 127 | \x7F | 177円 | backspace character ( DEL) | ≠0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |