wctob

From cppreference.com
< clrm; | stringlrm; | multibyte
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)