Linux fonts up and running
parent
542d7a8a2a
commit
eb6f4fa08e
|
@ -494,6 +494,7 @@ system_font_get_local_stubs(Partition *part){
|
||||||
|
|
||||||
if (dir_len + len + 1 <= sizeof(list.first->stub.name)){
|
if (dir_len + len + 1 <= sizeof(list.first->stub.name)){
|
||||||
Font_Setup *setup = push_struct(part, Font_Setup);
|
Font_Setup *setup = push_struct(part, Font_Setup);
|
||||||
|
memset(setup, 0, sizeof(*setup));
|
||||||
partition_align(part, 8);
|
partition_align(part, 8);
|
||||||
|
|
||||||
sll_push(list.first, list.last, setup);
|
sll_push(list.first, list.last, setup);
|
||||||
|
@ -539,7 +540,13 @@ system_font_init(Font_Functions *font_links, u32 pt_size, b32 use_hinting, Font_
|
||||||
i32 capacity = (i32)(sizeof(loadable->display_name));
|
i32 capacity = (i32)(sizeof(loadable->display_name));
|
||||||
|
|
||||||
if (stub->load_from_path){
|
if (stub->load_from_path){
|
||||||
|
if (ptr->has_display_name){
|
||||||
|
name_good = true;
|
||||||
|
memcpy(loadable->display_name, ptr->name, ptr->len);
|
||||||
|
}
|
||||||
|
else{
|
||||||
name_good = font_load_name(stub, loadable->display_name, capacity);
|
name_good = font_load_name(stub, loadable->display_name, capacity);
|
||||||
|
}
|
||||||
if (name_good){
|
if (name_good){
|
||||||
loadable->display_len = str_size(loadable->display_name);
|
loadable->display_len = str_size(loadable->display_name);
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,6 +36,10 @@ global Font_Vars fontvars = {0};
|
||||||
struct Font_Setup{
|
struct Font_Setup{
|
||||||
Font_Setup *next;
|
Font_Setup *next;
|
||||||
Font_Loadable_Stub stub;
|
Font_Loadable_Stub stub;
|
||||||
|
|
||||||
|
b32 has_display_name;
|
||||||
|
i32 len;
|
||||||
|
char name[64];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Font_Setup_List{
|
struct Font_Setup_List{
|
||||||
|
@ -54,7 +58,7 @@ struct Font_Raw_Data{
|
||||||
internal Sys_Font_Data(name);
|
internal Sys_Font_Data(name);
|
||||||
|
|
||||||
#define Sys_Font_Data_Not_Used \
|
#define Sys_Font_Data_Not_Used \
|
||||||
internal Sys_Font_Data(name){Font_Raw_Data data = {0}; InvalidCodePath; return(data);}
|
internal Sys_Font_Data(name){Font_Raw_Data data = {0}; LOG("there is no font data retrieval procedure available\n"); return(data);}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -460,8 +460,63 @@ Sys_CLI_End_Update_Sig(system_cli_end_update){
|
||||||
#include "4ed_font_provider_freetype.h"
|
#include "4ed_font_provider_freetype.h"
|
||||||
#include "4ed_font_provider_freetype.cpp"
|
#include "4ed_font_provider_freetype.cpp"
|
||||||
|
|
||||||
|
#undef internal
|
||||||
|
#include <fontconfig/fontconfig.h>
|
||||||
|
#define internal static
|
||||||
|
|
||||||
Sys_Font_Data_Not_Used;
|
Sys_Font_Data_Not_Used;
|
||||||
|
|
||||||
|
internal char*
|
||||||
|
linux_get_loadable_fonts(Partition *part, Font_Setup_List *list){
|
||||||
|
FcConfig* config = FcInitLoadConfigAndFonts();
|
||||||
|
FcPattern* pat = FcPatternBuild(
|
||||||
|
0,
|
||||||
|
FC_STYLE, FcTypeString, (FcChar8*)"Regular",
|
||||||
|
(void*)0);
|
||||||
|
FcObjectSet* os = FcObjectSetBuild(FC_FAMILY, FC_FILE, (char*)0);
|
||||||
|
FcFontSet* fs = FcFontList(config, pat, os);
|
||||||
|
if (fs != 0){
|
||||||
|
LOGF("Total matching fonts: %d\n", fs->nfont);
|
||||||
|
for (int i=0; fs && i < fs->nfont; ++i) {
|
||||||
|
FcPattern* font = fs->fonts[i];
|
||||||
|
FcChar8 *file = 0;
|
||||||
|
FcChar8 *style = 0;
|
||||||
|
FcChar8 *family = 0;
|
||||||
|
|
||||||
|
if (FcPatternGetString(font, FC_FILE, 0, &file) == FcResultMatch &&
|
||||||
|
FcPatternGetString(font, FC_FAMILY, 0, &family) == FcResultMatch)
|
||||||
|
{
|
||||||
|
Temp_Memory reset = begin_temp_memory(part);
|
||||||
|
Font_Setup *setup = push_array(part, Font_Setup, 1);
|
||||||
|
if (setup != 0){
|
||||||
|
memset(setup, 0, sizeof(*setup));
|
||||||
|
|
||||||
|
i32 len = str_size((char*)file);
|
||||||
|
if (len < sizeof(setup->stub.name)){
|
||||||
|
i32 name_len = str_size((char*)family);
|
||||||
|
if (name_len < sizeof(setup->name)){
|
||||||
|
setup->stub.load_from_path = true;
|
||||||
|
memcpy(setup->stub.name, file, len + 1);
|
||||||
|
setup->stub.len = len;
|
||||||
|
setup->has_display_name = true;
|
||||||
|
setup->len = name_len;
|
||||||
|
memcpy(setup->name, family, name_len + 1);
|
||||||
|
sll_push(list->first, list->last, setup);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
end_temp_memory(reset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
end_temp_memory(reset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
FcFontSetDestroy(fs);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#include <GL/gl.h>
|
#include <GL/gl.h>
|
||||||
#include "opengl/4ed_opengl_render.cpp"
|
#include "opengl/4ed_opengl_render.cpp"
|
||||||
|
|
||||||
|
@ -1611,6 +1666,7 @@ main(int argc, char **argv){
|
||||||
Partition *scratch = &shared_vars.scratch;
|
Partition *scratch = &shared_vars.scratch;
|
||||||
Temp_Memory temp = begin_temp_memory(scratch);
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
Font_Setup_List font_setup = system_font_get_local_stubs(scratch);
|
Font_Setup_List font_setup = system_font_get_local_stubs(scratch);
|
||||||
|
linux_get_loadable_fonts(scratch, &font_setup);
|
||||||
system_font_init(&sysfunc.font, plat_settings.font_size, plat_settings.use_hinting, font_setup);
|
system_font_init(&sysfunc.font, plat_settings.font_size, plat_settings.use_hinting, font_setup);
|
||||||
end_temp_memory(temp);
|
end_temp_memory(temp);
|
||||||
|
|
||||||
|
|
|
@ -578,6 +578,7 @@ const TEXTMETRIC *lpntme,
|
||||||
DWORD FontType,
|
DWORD FontType,
|
||||||
LPARAM lParam
|
LPARAM lParam
|
||||||
){
|
){
|
||||||
|
|
||||||
if ((FontType & TRUETYPE_FONTTYPE) != 0){
|
if ((FontType & TRUETYPE_FONTTYPE) != 0){
|
||||||
ENUMLOGFONTEXDV *log_font = (ENUMLOGFONTEXDV*)lpelfe;
|
ENUMLOGFONTEXDV *log_font = (ENUMLOGFONTEXDV*)lpelfe;
|
||||||
TCHAR *name = ((log_font)->elfEnumLogfontEx).elfLogFont.lfFaceName;
|
TCHAR *name = ((log_font)->elfEnumLogfontEx).elfLogFont.lfFaceName;
|
||||||
|
@ -594,8 +595,8 @@ LPARAM lParam
|
||||||
}
|
}
|
||||||
|
|
||||||
Win32_Font_Enum p = *(Win32_Font_Enum*)lParam;
|
Win32_Font_Enum p = *(Win32_Font_Enum*)lParam;
|
||||||
Temp_Memory reset = begin_temp_memory(p.part);
|
|
||||||
|
|
||||||
|
Temp_Memory reset = begin_temp_memory(p.part);
|
||||||
Font_Setup *setup = push_array(p.part, Font_Setup, 1);
|
Font_Setup *setup = push_array(p.part, Font_Setup, 1);
|
||||||
if (setup != 0){
|
if (setup != 0){
|
||||||
memset(setup, 0, sizeof(*setup));
|
memset(setup, 0, sizeof(*setup));
|
||||||
|
@ -619,6 +620,7 @@ LPARAM lParam
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return(1);
|
return(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue