summaryrefslogtreecommitdiff
path: root/src/text.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/text.cc')
-rw-r--r--src/text.cc23
1 files changed, 21 insertions, 2 deletions
diff --git a/src/text.cc b/src/text.cc
index 600220e..43ee74e 100644
--- a/src/text.cc
+++ b/src/text.cc
@@ -1,5 +1,10 @@
#include "text.h"
+#include <fcntl.h>
+#include <mimalloc.h>
+#include <unistd.h>
+#include <utils.h>
+
#include "utils.h"
enum font_context_error_e wayc_font_context_init(struct font_context_s* ctx) {
@@ -22,12 +27,26 @@ enum font_error_e wayc_font_init(struct font_s* font,
wayc_notnull(ctx);
wayc_notnull(path);
- FT_Error err = FT_New_Face(ctx->library, path, 0, &font->face);
- if (err) return FONT_ERROR_LOAD;
+ i32 fd = open(path, O_RDONLY);
+ if (fd < 0) return FONT_ERROR_FILE_LOAD;
+ wayc_defer(close(fd));
+
+ usize size = lseek(fd, 0, SEEK_END);
+ if (size < 0) return FONT_ERROR_FILE_LOAD;
+ lseek(fd, 0, SEEK_SET);
+
+ font->data = (u8*)mi_malloc(size);
+ usize _read = read(fd, font->data, size);
+ if (_read != size) return FONT_ERROR_FILE_LOAD;
+
+ FT_Error err = FT_New_Memory_Face(ctx->library, (const FT_Byte*)font->data,
+ size, 0, &font->face);
+ if (err) return FONT_ERROR_FONT_LOAD;
return FONT_ERROR_NONE;
}
void wayc_font_deinit(struct font_s* font) {
wayc_notnull(font);
FT_Done_Face(font->face);
+ mi_free(font->data);
}