Changeset 28a5ebd in mainline for kernel/generic/src/printf/vprintf.c


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
  • kernel/generic/src/printf/vprintf.c

    r4f663f3e r28a5ebd  
    4747
    4848        while (offset < size) {
    49                 putwchar(str_decode(str, &offset, size));
     49                putuchar(str_decode(str, &offset, size));
    5050                chars++;
    5151        }
     
    5454}
    5555
    56 static int vprintf_wstr_write(const wchar_t *str, size_t size, void *data)
     56static int vprintf_wstr_write(const char32_t *str, size_t size, void *data)
    5757{
    5858        size_t offset = 0;
     
    6060
    6161        while (offset < size) {
    62                 putwchar(str[chars]);
     62                putuchar(str[chars]);
    6363                chars++;
    64                 offset += sizeof(wchar_t);
     64                offset += sizeof(char32_t);
    6565        }
    6666
     
    7272        size_t offset = 0;
    7373        size_t chars = 0;
    74         wchar_t uc;
     74        char32_t uc;
    7575
    7676        while ((uc = str_decode(str, &offset, STR_NO_LIMIT)) != 0) {
    77                 putwchar(uc);
     77                putuchar(uc);
    7878                chars++;
    7979        }
    8080
    81         putwchar('\n');
     81        putuchar('\n');
    8282        return chars;
    8383}
Note: See TracChangeset for help on using the changeset viewer.