mirror of
https://codeberg.org/dnkl/foot.git
synced 2026-02-05 04:06:08 -05:00
Fcft no longer uses wchar_t, but plain uint32_t to represent codepoints. Since we do a fair amount of string operations in foot, it still makes sense to use something that actually _is_ a string (or character), rather than an array of uint32_t. For this reason, we switch out all wchar_t usage in foot to char32_t. We also verify, at compile-time, that char32_t used UTF-32 (which is what fcft expects). Unfortunately, there are no string functions for char32_t. To avoid having to re-implement all wcs*() functions, we add a small wrapper layer of c32*() functions. These wrapper functions take char32_t arguments, but then simply call the corresponding wcs*() function. For this to work, wcs*() must _also_ be UTF-32 compatible. We can check for the presence of the __STDC_ISO_10646__ macro. If set, wchar_t is at least 4 bytes and its internal representation is UTF-32. FreeBSD does *not* define this macro, because its internal wchar_t representation depends on the current locale. It _does_ use UTF-32 _if_ the current locale is UTF-8. Since foot enforces UTF-8, we simply need to check if __FreeBSD__ is defined. Other fcft API changes: * fcft_glyph_rasterize() -> fcft_codepoint_rasterize() * font.space_advance has been removed * ‘tags’ have been removed from fcft_grapheme_rasterize() * ‘fcft_log_init()’ removed * ‘fcft_init()’ and ‘fcft_fini()’ must be explicitly called
89 lines
1.5 KiB
C
89 lines
1.5 KiB
C
#include <errno.h>
|
|
#include <stdarg.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include "xmalloc.h"
|
|
#include "debug.h"
|
|
|
|
static void *
|
|
check_alloc(void *alloc)
|
|
{
|
|
if (unlikely(alloc == NULL)) {
|
|
FATAL_ERROR(__func__, ENOMEM);
|
|
}
|
|
return alloc;
|
|
}
|
|
|
|
void *
|
|
xmalloc(size_t size)
|
|
{
|
|
if (unlikely(size == 0)) {
|
|
size = 1;
|
|
}
|
|
return check_alloc(malloc(size));
|
|
}
|
|
|
|
void *
|
|
xcalloc(size_t nmemb, size_t size)
|
|
{
|
|
xassert(size != 0);
|
|
return check_alloc(calloc(likely(nmemb) ? nmemb : 1, size));
|
|
}
|
|
|
|
void *
|
|
xrealloc(void *ptr, size_t size)
|
|
{
|
|
void *alloc = realloc(ptr, size);
|
|
return unlikely(size == 0) ? alloc : check_alloc(alloc);
|
|
}
|
|
|
|
char *
|
|
xstrdup(const char *str)
|
|
{
|
|
return check_alloc(strdup(str));
|
|
}
|
|
|
|
char *
|
|
xstrndup(const char *str, size_t n)
|
|
{
|
|
return check_alloc(strndup(str, n));
|
|
}
|
|
|
|
char32_t *
|
|
xc32dup(const char32_t *str)
|
|
{
|
|
return check_alloc(c32dup(str));
|
|
}
|
|
|
|
static VPRINTF(2) int
|
|
xvasprintf_(char **strp, const char *format, va_list ap)
|
|
{
|
|
va_list ap2;
|
|
va_copy(ap2, ap);
|
|
int n = vsnprintf(NULL, 0, format, ap2);
|
|
if (unlikely(n < 0)) {
|
|
FATAL_ERROR("vsnprintf", EILSEQ);
|
|
}
|
|
va_end(ap2);
|
|
*strp = xmalloc(n + 1);
|
|
return vsnprintf(*strp, n + 1, format, ap);
|
|
}
|
|
|
|
char *
|
|
xvasprintf(const char *format, va_list ap)
|
|
{
|
|
char *str;
|
|
xvasprintf_(&str, format, ap);
|
|
return str;
|
|
}
|
|
|
|
char *
|
|
xasprintf(const char *format, ...)
|
|
{
|
|
va_list ap;
|
|
va_start(ap, format);
|
|
char *str = xvasprintf(format, ap);
|
|
va_end(ap);
|
|
return str;
|
|
}
|