Changeset 28a5ebd in mainline for abi/include/_bits/wchar_limits.h


Ignore:
Timestamp:
2020-06-18T15:39:50Z (4 years ago)
Author:
Martin Decky <martin@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
ce52c333
Parents:
4f663f3e
Message:

Use char32_t instead of wchat_t to represent UTF-32 strings

The intention of the native HelenOS string API has been always to
support Unicode in the UTF-8 and UTF-32 encodings as the sole character
representations and ignore the obsolete mess of older single-byte and
multibyte character encodings. Before C11, the wchar_t type has been
slightly misused for the purpose of the UTF-32 strings. The newer
char32_t type is obviously a much more suitable option. The standard
defines char32_t as uint_least32_t, thus we can take the liberty to fix
it to uint32_t.

To maintain compatilibity with the C Standard, the putwchar(wchar_t)
functions has been replaced by our custom putuchar(char32_t) functions
where appropriate.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • abi/include/_bits/wchar_limits.h

    r4f663f3e r28a5ebd  
    3838 */
    3939
    40 #ifndef _BITS_WCHAR_MIN_H_
    41 #define _BITS_WCHAR_MIN_H_
     40#ifndef _BITS_WCHAR_LIMITS_H_
     41#define _BITS_WCHAR_LIMITS_H_
    4242
    43 /* wchar_t should always be signed int in HelenOS. */
     43/* wchar_t should always be int32_t in HelenOS. */
    4444
    4545#include <_bits/wchar_t.h>
    4646
    4747#ifndef __cplusplus
    48 _Static_assert(((wchar_t)-1) < 0, "wchar_t is not int");
    49 _Static_assert(sizeof(wchar_t) == 4, "wchar_t is not int");
     48_Static_assert(((wchar_t) -1) < 0, "wchar_t is not int32_t");
     49_Static_assert(sizeof(wchar_t) == 4, "wchar_t is not int32_t");
    5050#endif
    5151
Note: See TracChangeset for help on using the changeset viewer.