Changeset 28a5ebd in mainline for uspace/app/edit/sheet.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
  • uspace/app/edit/sheet.c

    r4f663f3e r28a5ebd  
    195195        size_t copy_sz;
    196196        size_t off, prev;
    197         wchar_t c;
     197        char32_t c;
    198198
    199199        spp = sh->data + spos->b_off;
     
    222222{
    223223        size_t cur_pos, prev_pos;
    224         wchar_t c;
     224        char32_t c;
    225225        coord_t cc;
    226226
     
    291291        size_t off;
    292292        coord_t cc;
    293         wchar_t c;
     293        char32_t c;
    294294        sheet_t *sh;
    295295
     
    320320
    321321/** Get a character at spt and return next spt */
    322 wchar_t spt_next_char(spt_t spt, spt_t *next)
    323 {
    324         wchar_t ch = str_decode(spt.sh->data, &spt.b_off, spt.sh->text_size);
     322char32_t spt_next_char(spt_t spt, spt_t *next)
     323{
     324        char32_t ch = str_decode(spt.sh->data, &spt.b_off, spt.sh->text_size);
    325325        if (next)
    326326                *next = spt;
     
    328328}
    329329
    330 wchar_t spt_prev_char(spt_t spt, spt_t *prev)
    331 {
    332         wchar_t ch = str_decode_reverse(spt.sh->data, &spt.b_off, spt.sh->text_size);
     330char32_t spt_prev_char(spt_t spt, spt_t *prev)
     331{
     332        char32_t ch = str_decode_reverse(spt.sh->data, &spt.b_off, spt.sh->text_size);
    333333        if (prev)
    334334                *prev = spt;
Note: See TracChangeset for help on using the changeset viewer.