wctob
Defined in header <wchar.h> | ||
|---|---|---|
int wctob( wint_t c ); | (since C95) |
Narrows a wide character c if its multibyte character equivalent in the initial shift state is a single byte.
This is typically possible for the characters from the ASCII character set, since most multibyte encodings (such as UTF-8) use single bytes to encode those characters.
Parameters
| c | - | wide character to narrow |
Return value
EOF if c does not represent a multibyte character with length 1 in initial shift state.
otherwise, the single-byte representation of c as unsigned char converted to int.
Example
#include <locale.h>
#include <wchar.h>
#include <stdio.h>
#include <assert.h>
void try_narrowing(wchar_t c)
{
int cn = wctob(c);
if(cn != EOF)
printf("%#x narrowed to %#x\n", c, cn);
else
printf("%#x could not be narrowed\n", c);
}
int main(void)
{
char* utf_locale_present = setlocale(LC_ALL, "th_TH.utf8");
assert(utf_locale_present);
puts("In Thai UTF-8 locale:");
try_narrowing(L'a');
try_narrowing(L'๛');
char* tis_locale_present = setlocale(LC_ALL, "th_TH.tis620");
assert(tis_locale_present);
puts("In Thai TIS-620 locale:");
try_narrowing(L'a');
try_narrowing(L'๛');
}Possible output:
In Thai UTF-8 locale: 0x61 narrowed to 0x61 0xe5b could not be narrowed In Thai TIS-620 locale: 0x61 narrowed to 0x61 0xe5b narrowed to 0xfb
References
- C11 standard (ISO/IEC 9899:2011):
- 7.29.6.1.2 The wctob function (p: 441)
- C99 standard (ISO/IEC 9899:1999):
- 7.24.6.1.2 The wctob function (p: 387)
See also
|
(C95) | widens a single-byte narrow character to wide character, if possible (function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
http://en.cppreference.com/w/c/string/multibyte/wctob