Changeset 28a5ebd in mainline for uspace/lib/draw


Ignore:
Timestamp:
2020-06-18T15:39:50Z (5 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.

Location:
uspace/lib/draw
Files:
7 edited

Legend:

Unmodified
Added
Removed
  • uspace/lib/draw/font.c

    r4f663f3e r28a5ebd  
    6464}
    6565
    66 errno_t font_resolve_glyph(font_t *font, wchar_t c, glyph_id_t *glyph_id)
     66errno_t font_resolve_glyph(font_t *font, char32_t c, glyph_id_t *glyph_id)
    6767{
    6868        return font->backend->resolve_glyph(font->backend_data, c, glyph_id);
     
    9595        size_t off = 0;
    9696        while (true) {
    97                 wchar_t c = str_decode(text, &off, STR_NO_LIMIT);
     97                char32_t c = str_decode(text, &off, STR_NO_LIMIT);
    9898                if (c == 0)
    9999                        break;
     
    138138        size_t off = 0;
    139139        while (true) {
    140                 wchar_t c = str_decode(text, &off, STR_NO_LIMIT);
     140                char32_t c = str_decode(text, &off, STR_NO_LIMIT);
    141141                if (c == 0)
    142142                        break;
  • uspace/lib/draw/font/bitmap_backend.c

    r4f663f3e r28a5ebd  
    6767}
    6868
    69 static errno_t bb_resolve_glyph(void *backend_data, wchar_t c, glyph_id_t *glyph_id)
     69static errno_t bb_resolve_glyph(void *backend_data, char32_t c, glyph_id_t *glyph_id)
    7070{
    7171        bitmap_backend_data_t *data = (bitmap_backend_data_t *) backend_data;
  • uspace/lib/draw/font/embedded.c

    r4f663f3e r28a5ebd  
    4343#include <draw/drawctx.h>
    4444
    45 static errno_t fde_resolve_glyph(void *unused, const wchar_t chr,
     45static errno_t fde_resolve_glyph(void *unused, const char32_t chr,
    4646    glyph_id_t *glyph_id)
    4747{
  • uspace/lib/draw/font/pcf.c

    r4f663f3e r28a5ebd  
    143143}
    144144
    145 static errno_t pcf_resolve_glyph(void *opaque_data, const wchar_t chr,
     145static errno_t pcf_resolve_glyph(void *opaque_data, const char32_t chr,
    146146    glyph_id_t *glyph_id)
    147147{
  • uspace/lib/draw/gfx/font-8x16.c

    r4f663f3e r28a5ebd  
    4747 *
    4848 */
    49 uint16_t fb_font_glyph(const wchar_t ch, bool *found)
     49uint16_t fb_font_glyph(const char32_t ch, bool *found)
    5050{
    5151        if (found)
  • uspace/lib/draw/include/draw/font.h

    r4f663f3e r28a5ebd  
    9797typedef struct {
    9898        errno_t (*get_font_metrics)(void *, font_metrics_t *);
    99         errno_t (*resolve_glyph)(void *, wchar_t, glyph_id_t *);
     99        errno_t (*resolve_glyph)(void *, char32_t, glyph_id_t *);
    100100        errno_t (*get_glyph_metrics)(void *, glyph_id_t, glyph_metrics_t *);
    101101        errno_t (*render_glyph)(void *, drawctx_t *, source_t *, sysarg_t,
     
    110110
    111111typedef struct {
    112         errno_t (*resolve_glyph)(void *, const wchar_t, glyph_id_t *);
     112        errno_t (*resolve_glyph)(void *, const char32_t, glyph_id_t *);
    113113        errno_t (*load_glyph_surface)(void *, glyph_id_t, surface_t **);
    114114        errno_t (*load_glyph_metrics)(void *, glyph_id_t, glyph_metrics_t *);
     
    118118extern font_t *font_create(font_backend_t *, void *);
    119119extern errno_t font_get_metrics(font_t *, font_metrics_t *);
    120 extern errno_t font_resolve_glyph(font_t *, wchar_t, glyph_id_t *);
     120extern errno_t font_resolve_glyph(font_t *, char32_t, glyph_id_t *);
    121121extern errno_t font_get_glyph_metrics(font_t *, glyph_id_t, glyph_metrics_t *);
    122122extern errno_t font_render_glyph(font_t *, drawctx_t *, source_t *,
  • uspace/lib/draw/include/draw/gfx.h

    r4f663f3e r28a5ebd  
    4040#include <stdbool.h>
    4141#include <stddef.h>
     42#include <uchar.h>
    4243
    4344#define CURSOR_WIDTH   11
     
    5253extern uint8_t cursor_mask[];
    5354
    54 extern uint16_t fb_font_glyph(const wchar_t, bool *);
     55extern uint16_t fb_font_glyph(const char32_t, bool *);
    5556extern uint8_t fb_font[FONT_GLYPHS][FONT_SCANLINES];
    5657
Note: See TracChangeset for help on using the changeset viewer.