Font size and hinting in config.4coder
parent
4783c9598f
commit
23e6660172
|
@ -869,6 +869,11 @@ ENUM(int32_t, Special_Hook_ID){
|
||||||
special_hook_buffer_name_resolver,
|
special_hook_buffer_name_resolver,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
STRUCT Startup_Parameters{
|
||||||
|
int32_t override_font_size;
|
||||||
|
bool32 override_hinting;
|
||||||
|
};
|
||||||
|
|
||||||
TYPEDEF_FUNC int32_t Command_Caller_Hook_Function(struct Application_Links *app, Generic_Command cmd);
|
TYPEDEF_FUNC int32_t Command_Caller_Hook_Function(struct Application_Links *app, Generic_Command cmd);
|
||||||
#define COMMAND_CALLER_HOOK(name) int32_t name(struct Application_Links *app, Generic_Command cmd)
|
#define COMMAND_CALLER_HOOK(name) int32_t name(struct Application_Links *app, Generic_Command cmd)
|
||||||
|
|
||||||
|
|
|
@ -183,7 +183,7 @@ get_or_open_build_panel(Application_Links *app){
|
||||||
static void
|
static void
|
||||||
set_fancy_compilation_buffer_font(Application_Links *app){
|
set_fancy_compilation_buffer_font(Application_Links *app){
|
||||||
Buffer_Summary comp_buffer = get_buffer_by_name(app, literal("*compilation*"), AccessAll);
|
Buffer_Summary comp_buffer = get_buffer_by_name(app, literal("*compilation*"), AccessAll);
|
||||||
buffer_set_font(app, &comp_buffer, literal("Inconsolata"));
|
set_buffer_face_by_name(app, &comp_buffer, literal("Inconsolata"));
|
||||||
}
|
}
|
||||||
|
|
||||||
CUSTOM_COMMAND_SIG(build_in_build_panel)
|
CUSTOM_COMMAND_SIG(build_in_build_panel)
|
||||||
|
|
|
@ -1024,6 +1024,8 @@ config_init_default(Config_Data *config){
|
||||||
|
|
||||||
config->default_font_name = make_fixed_width_string(config->default_font_name_space);
|
config->default_font_name = make_fixed_width_string(config->default_font_name_space);
|
||||||
copy(&config->default_font_name, "");
|
copy(&config->default_font_name, "");
|
||||||
|
config->default_font_size = 16;
|
||||||
|
config->default_font_hinting = false;
|
||||||
|
|
||||||
config->default_compiler_bat = make_fixed_width_string(config->default_compiler_bat_space);
|
config->default_compiler_bat = make_fixed_width_string(config->default_compiler_bat_space);
|
||||||
copy(&config->default_compiler_bat, "cl");
|
copy(&config->default_compiler_bat, "cl");
|
||||||
|
@ -1077,8 +1079,11 @@ config_parse__data(Partition *arena, String file_name, String data, Config_Data
|
||||||
|
|
||||||
config_fixed_string_var(parsed, "default_theme_name", 0,
|
config_fixed_string_var(parsed, "default_theme_name", 0,
|
||||||
&config->default_theme_name, config->default_theme_name_space);
|
&config->default_theme_name, config->default_theme_name_space);
|
||||||
|
|
||||||
config_fixed_string_var(parsed, "default_font_name", 0,
|
config_fixed_string_var(parsed, "default_font_name", 0,
|
||||||
&config->default_font_name, config->default_font_name_space);
|
&config->default_font_name, config->default_font_name_space);
|
||||||
|
config_int_var(parsed, "default_font_size", 0, &config->default_font_size);
|
||||||
|
config_bool_var(parsed, "default_font_hinting", 0, &config->default_font_hinting);
|
||||||
|
|
||||||
config_fixed_string_var(parsed, "default_compiler_bat", 0,
|
config_fixed_string_var(parsed, "default_compiler_bat", 0,
|
||||||
&config->default_compiler_bat, config->default_compiler_bat_space);
|
&config->default_compiler_bat, config->default_compiler_bat_space);
|
||||||
|
@ -1243,7 +1248,8 @@ config_feedback_int(String *space, char *name, int32_t val){
|
||||||
////////////////////////////////
|
////////////////////////////////
|
||||||
|
|
||||||
static void
|
static void
|
||||||
load_config_and_apply(Application_Links *app, Partition *scratch, Config_Data *config){
|
load_config_and_apply(Application_Links *app, Partition *scratch, Config_Data *config,
|
||||||
|
int32_t override_font_size, bool32 override_hinting){
|
||||||
Temp_Memory temp = begin_temp_memory(scratch);
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
Config *parsed = config_parse__file_name(app, scratch, "config.4coder", config);
|
Config *parsed = config_parse__file_name(app, scratch, "config.4coder", config);
|
||||||
|
|
||||||
|
@ -1281,7 +1287,10 @@ load_config_and_apply(Application_Links *app, Partition *scratch, Config_Data *c
|
||||||
config_feedback_int(&space, "default_min_base_width", config->default_min_base_width);
|
config_feedback_int(&space, "default_min_base_width", config->default_min_base_width);
|
||||||
|
|
||||||
config_feedback_string(&space, "default_theme_name", config->default_theme_name);
|
config_feedback_string(&space, "default_theme_name", config->default_theme_name);
|
||||||
|
|
||||||
config_feedback_string(&space, "default_font_name", config->default_font_name);
|
config_feedback_string(&space, "default_font_name", config->default_font_name);
|
||||||
|
config_feedback_int(&space, "default_font_size", config->default_font_size);
|
||||||
|
config_feedback_bool(&space, "default_font_hinting", config->default_font_hinting);
|
||||||
|
|
||||||
config_feedback_string(&space, "default_compiler_bat", config->default_compiler_bat);
|
config_feedback_string(&space, "default_compiler_bat", config->default_compiler_bat);
|
||||||
config_feedback_string(&space, "default_flags_bat", config->default_flags_bat);
|
config_feedback_string(&space, "default_flags_bat", config->default_flags_bat);
|
||||||
|
@ -1299,6 +1308,25 @@ load_config_and_apply(Application_Links *app, Partition *scratch, Config_Data *c
|
||||||
change_mapping(app, config->current_mapping);
|
change_mapping(app, config->current_mapping);
|
||||||
adjust_all_buffer_wrap_widths(app, config->default_wrap_width, config->default_min_base_width);
|
adjust_all_buffer_wrap_widths(app, config->default_wrap_width, config->default_min_base_width);
|
||||||
global_set_setting(app, GlobalSetting_LAltLCtrlIsAltGr, config->lalt_lctrl_is_altgr);
|
global_set_setting(app, GlobalSetting_LAltLCtrlIsAltGr, config->lalt_lctrl_is_altgr);
|
||||||
|
|
||||||
|
change_theme(app, config->default_theme_name.str, config->default_theme_name.size);
|
||||||
|
|
||||||
|
Face_Description description = {0};
|
||||||
|
int32_t len = config->default_font_name.size;
|
||||||
|
char *name_ptr = config->default_font_name.str;
|
||||||
|
if (len > sizeof(description.font.name) - 1){
|
||||||
|
len = sizeof(description.font.name) - 1;
|
||||||
|
}
|
||||||
|
memcpy(description.font.name, name_ptr, len);
|
||||||
|
description.font.name[len] = 0;
|
||||||
|
if (override_font_size != 0){
|
||||||
|
description.pt_size = override_font_size;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
description.pt_size = config->default_font_size;
|
||||||
|
}
|
||||||
|
description.hinting = config->default_font_hinting || override_hinting;
|
||||||
|
change_global_face_by_description(app, description, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
end_temp_memory(temp);
|
end_temp_memory(temp);
|
||||||
|
|
|
@ -173,6 +173,8 @@ struct Config_Data{
|
||||||
|
|
||||||
char default_font_name_space[256];
|
char default_font_name_space[256];
|
||||||
String default_font_name;
|
String default_font_name;
|
||||||
|
int32_t default_font_size;
|
||||||
|
bool32 default_font_hinting;
|
||||||
|
|
||||||
char default_compiler_bat_space[256];
|
char default_compiler_bat_space[256];
|
||||||
String default_compiler_bat;
|
String default_compiler_bat;
|
||||||
|
|
|
@ -229,179 +229,6 @@ CUSTOM_DOC("Switch to a named key binding map.")
|
||||||
|
|
||||||
////////////////////////////////
|
////////////////////////////////
|
||||||
|
|
||||||
#if 0
|
|
||||||
static bool32
|
|
||||||
get_current_name(char **name_out, int32_t *len_out){
|
|
||||||
bool32 result = false;
|
|
||||||
*name_out = 0;
|
|
||||||
if (user_name.str[0] != 0){
|
|
||||||
*name_out = user_name.str;
|
|
||||||
*len_out = user_name.size;
|
|
||||||
result = true;
|
|
||||||
}
|
|
||||||
return(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
static String
|
|
||||||
get_default_theme_name(void){
|
|
||||||
String str = default_theme_name;
|
|
||||||
if (str.size == 0){
|
|
||||||
str = make_lit_string("4coder");
|
|
||||||
}
|
|
||||||
return(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
static String
|
|
||||||
get_default_font_name(void){
|
|
||||||
String str = default_font_name;
|
|
||||||
if (str.size == 0){
|
|
||||||
str = make_lit_string("Liberation Mono");
|
|
||||||
}
|
|
||||||
return(str);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
////////////////////////////////
|
|
||||||
|
|
||||||
static bool32
|
|
||||||
descriptions_match(Face_Description *a, Face_Description *b){
|
|
||||||
bool32 result = false;
|
|
||||||
if (match(a->font.name, b->font.name) && a->font.in_local_font_folder == b->font.in_local_font_folder){
|
|
||||||
if (memcmp((&a->pt_size), (&b->pt_size), sizeof(*a) - sizeof(a->font)) == 0){
|
|
||||||
result = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
static Face_ID
|
|
||||||
get_existing_face_id_matching_name(Application_Links *app, char *name, int32_t len){
|
|
||||||
String name_str = make_string(name, len);
|
|
||||||
Face_ID largest_id = get_largest_face_id(app);
|
|
||||||
Face_ID result = 0;
|
|
||||||
for (Face_ID id = 1; id <= largest_id; ++id){
|
|
||||||
Face_Description compare = get_face_description(app, id);
|
|
||||||
if (match(compare.font.name, name_str)){
|
|
||||||
result = id;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
static Face_ID
|
|
||||||
get_existing_face_id_matching_description(Application_Links *app, Face_Description *description){
|
|
||||||
Face_ID largest_id = get_largest_face_id(app);
|
|
||||||
Face_ID result = 0;
|
|
||||||
for (Face_ID id = 1; id <= largest_id; ++id){
|
|
||||||
Face_Description compare = get_face_description(app, id);
|
|
||||||
if (descriptions_match(&compare, description)){
|
|
||||||
result = id;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
static Face_ID
|
|
||||||
get_face_id_by_name(Application_Links *app, char *name, int32_t len, Face_Description *base_description){
|
|
||||||
Face_ID new_id = 0;
|
|
||||||
|
|
||||||
String str = make_string(name, len);
|
|
||||||
if (!match(str, base_description->font.name)){
|
|
||||||
new_id = get_existing_face_id_matching_name(app, name, len);
|
|
||||||
if (new_id == 0){
|
|
||||||
Face_Description description = *base_description;
|
|
||||||
copy_fast_unsafe_cs(description.font.name, str);
|
|
||||||
description.font.name[str.size] = 0;
|
|
||||||
|
|
||||||
description.font.in_local_font_folder = false;
|
|
||||||
new_id = try_create_new_face(app, &description);
|
|
||||||
if (new_id == 0){
|
|
||||||
description.font.in_local_font_folder = true;
|
|
||||||
new_id = try_create_new_face(app, &description);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return(new_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
change_font(Application_Links *app, char *name, int32_t len, bool32 apply_to_all_buffers){
|
|
||||||
Face_ID global_face_id = get_face_id(app, 0);
|
|
||||||
Face_Description description = get_face_description(app, global_face_id);
|
|
||||||
Face_ID new_id = get_face_id_by_name(app, name, len, &description);
|
|
||||||
if (new_id != 0){
|
|
||||||
set_global_face(app, new_id, apply_to_all_buffers);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
buffer_set_font(Application_Links *app, Buffer_Summary *buffer, char *name, int32_t len){
|
|
||||||
Face_ID current_id = get_face_id(app, buffer);
|
|
||||||
if (current_id != 0){
|
|
||||||
Face_Description description = get_face_description(app, current_id);
|
|
||||||
Face_ID new_id = get_face_id_by_name(app, name, len, &description);
|
|
||||||
if (new_id != 0){
|
|
||||||
buffer_set_face(app, buffer, new_id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static Face_ID
|
|
||||||
get_face_id_by_description(Application_Links *app, Face_Description *description, Face_Description *base_description){
|
|
||||||
Face_ID new_id = 0;
|
|
||||||
if (!descriptions_match(description, base_description)){
|
|
||||||
new_id = get_existing_face_id_matching_description(app, description);
|
|
||||||
if (new_id == 0){
|
|
||||||
new_id = try_create_new_face(app, description);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return(new_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
change_face_description(Application_Links *app, Face_Description *new_description, bool32 apply_to_all_buffers){
|
|
||||||
Face_ID global_face_id = get_face_id(app, 0);
|
|
||||||
Face_Description old_description = get_face_description(app, global_face_id);
|
|
||||||
Face_ID new_id = get_face_id_by_description(app, new_description, &old_description);
|
|
||||||
if (new_id != 0){
|
|
||||||
set_global_face(app, new_id, apply_to_all_buffers);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
buffer_set_face_description(Application_Links *app, Buffer_Summary *buffer, Face_Description *new_description){
|
|
||||||
Face_ID current_id = get_face_id(app, buffer);
|
|
||||||
if (current_id != 0){
|
|
||||||
Face_Description old_description = get_face_description(app, current_id);
|
|
||||||
Face_ID new_id = get_face_id_by_description(app, new_description, &old_description);
|
|
||||||
if (new_id != 0){
|
|
||||||
buffer_set_face(app, buffer, new_id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static Face_Description
|
|
||||||
get_buffer_face_description(Application_Links *app, Buffer_Summary *buffer){
|
|
||||||
Face_ID current_id = get_face_id(app, buffer);
|
|
||||||
Face_Description description = {0};
|
|
||||||
if (current_id != 0){
|
|
||||||
description = get_face_description(app, current_id);
|
|
||||||
}
|
|
||||||
return(description);
|
|
||||||
}
|
|
||||||
|
|
||||||
static Face_Description
|
|
||||||
get_global_face_description(Application_Links *app){
|
|
||||||
Face_ID current_id = get_face_id(app, 0);
|
|
||||||
Face_Description description = get_face_description(app, current_id);
|
|
||||||
return(description);
|
|
||||||
}
|
|
||||||
|
|
||||||
////////////////////////////////
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
init_memory(Application_Links *app){
|
init_memory(Application_Links *app){
|
||||||
int32_t part_size = (32 << 20);
|
int32_t part_size = (32 << 20);
|
||||||
|
@ -415,7 +242,7 @@ init_memory(Application_Links *app){
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
default_4coder_initialize(Application_Links *app){
|
default_4coder_initialize(Application_Links *app, int32_t override_font_size, bool32 override_hinting){
|
||||||
init_memory(app);
|
init_memory(app);
|
||||||
|
|
||||||
static const char message[] = ""
|
static const char message[] = ""
|
||||||
|
@ -428,19 +255,14 @@ default_4coder_initialize(Application_Links *app){
|
||||||
String msg = make_lit_string(message);
|
String msg = make_lit_string(message);
|
||||||
print_message(app, msg.str, msg.size);
|
print_message(app, msg.str, msg.size);
|
||||||
|
|
||||||
load_config_and_apply(app, &global_part, &global_config);
|
load_config_and_apply(app, &global_part, &global_config, override_font_size, override_hinting);
|
||||||
load_folder_of_themes_into_live_set(app, &global_part, "themes");
|
load_folder_of_themes_into_live_set(app, &global_part, "themes");
|
||||||
|
|
||||||
String theme = global_config.default_theme_name;
|
|
||||||
String font = global_config.default_font_name;
|
|
||||||
|
|
||||||
change_theme(app, theme.str, theme.size);
|
|
||||||
change_font(app, font.str, font.size, true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
default_4coder_initialize(Application_Links *app, bool32 use_scroll_bars, bool32 use_file_bars){
|
default_4coder_initialize(Application_Links *app, int32_t override_font_size, bool32 override_hinting,
|
||||||
default_4coder_initialize(app);
|
bool32 use_scroll_bars, bool32 use_file_bars){
|
||||||
|
default_4coder_initialize(app, override_font_size, override_hinting);
|
||||||
global_config.use_scroll_bars = use_scroll_bars;
|
global_config.use_scroll_bars = use_scroll_bars;
|
||||||
global_config.use_file_bars = use_file_bars;
|
global_config.use_file_bars = use_file_bars;
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,8 @@ START_HOOK_SIG(default_start){
|
||||||
named_maps = named_maps_values;
|
named_maps = named_maps_values;
|
||||||
named_map_count = ArrayCount(named_maps_values);
|
named_map_count = ArrayCount(named_maps_values);
|
||||||
|
|
||||||
default_4coder_initialize(app);
|
Face_Description command_line_description = get_face_description(app, 0);
|
||||||
|
default_4coder_initialize(app, command_line_description.pt_size, command_line_description.hinting);
|
||||||
default_4coder_side_by_side_panels(app, files, file_count);
|
default_4coder_side_by_side_panels(app, files, file_count);
|
||||||
|
|
||||||
if (global_config.automatically_load_project){
|
if (global_config.automatically_load_project){
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#include "4coder_default_framework_variables.cpp"
|
#include "4coder_default_framework_variables.cpp"
|
||||||
#include "4coder_buffer_seek_constructors.cpp"
|
#include "4coder_buffer_seek_constructors.cpp"
|
||||||
#include "4coder_helper.cpp"
|
#include "4coder_helper.cpp"
|
||||||
|
#include "4coder_font_helper.cpp"
|
||||||
#include "4coder_config.cpp"
|
#include "4coder_config.cpp"
|
||||||
#include "4coder_default_framework.cpp"
|
#include "4coder_default_framework.cpp"
|
||||||
#include "4coder_seek.cpp"
|
#include "4coder_seek.cpp"
|
||||||
|
|
|
@ -0,0 +1,129 @@
|
||||||
|
/*
|
||||||
|
4coder_font_helper.cpp - Procedures for font setting operations
|
||||||
|
*/
|
||||||
|
|
||||||
|
// TOP
|
||||||
|
|
||||||
|
static Face_Description
|
||||||
|
get_buffer_face_description(Application_Links *app, Buffer_Summary *buffer){
|
||||||
|
Face_ID current_id = get_face_id(app, buffer);
|
||||||
|
Face_Description description = {0};
|
||||||
|
if (current_id != 0){
|
||||||
|
description = get_face_description(app, current_id);
|
||||||
|
}
|
||||||
|
return(description);
|
||||||
|
}
|
||||||
|
|
||||||
|
static Face_Description
|
||||||
|
get_global_face_description(Application_Links *app){
|
||||||
|
Face_ID current_id = get_face_id(app, 0);
|
||||||
|
Face_Description description = get_face_description(app, current_id);
|
||||||
|
return(description);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool32
|
||||||
|
descriptions_match(Face_Description *a, Face_Description *b){
|
||||||
|
bool32 result = false;
|
||||||
|
if (match(a->font.name, b->font.name) && a->font.in_local_font_folder == b->font.in_local_font_folder){
|
||||||
|
if (memcmp((&a->pt_size), (&b->pt_size), sizeof(*a) - sizeof(a->font)) == 0){
|
||||||
|
result = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
static Face_ID
|
||||||
|
get_existing_face_id_matching_name(Application_Links *app, char *name, int32_t len){
|
||||||
|
String name_str = make_string(name, len);
|
||||||
|
Face_ID largest_id = get_largest_face_id(app);
|
||||||
|
Face_ID result = 0;
|
||||||
|
for (Face_ID id = 1; id <= largest_id; ++id){
|
||||||
|
Face_Description compare = get_face_description(app, id);
|
||||||
|
if (match(compare.font.name, name_str)){
|
||||||
|
result = id;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
static Face_ID
|
||||||
|
get_existing_face_id_matching_description(Application_Links *app, Face_Description *description){
|
||||||
|
Face_ID largest_id = get_largest_face_id(app);
|
||||||
|
Face_ID result = 0;
|
||||||
|
for (Face_ID id = 1; id <= largest_id; ++id){
|
||||||
|
Face_Description compare = get_face_description(app, id);
|
||||||
|
if (descriptions_match(&compare, description)){
|
||||||
|
result = id;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
static Face_ID
|
||||||
|
get_face_id_by_name(Application_Links *app, char *name, int32_t len, Face_Description *base_description){
|
||||||
|
Face_ID new_id = 0;
|
||||||
|
String str = make_string(name, len);
|
||||||
|
if (!match(str, base_description->font.name)){
|
||||||
|
new_id = get_existing_face_id_matching_name(app, name, len);
|
||||||
|
if (new_id == 0){
|
||||||
|
Face_Description description = *base_description;
|
||||||
|
copy_fast_unsafe_cs(description.font.name, str);
|
||||||
|
description.font.name[str.size] = 0;
|
||||||
|
description.font.in_local_font_folder = false;
|
||||||
|
new_id = try_create_new_face(app, &description);
|
||||||
|
if (new_id == 0){
|
||||||
|
description.font.in_local_font_folder = true;
|
||||||
|
new_id = try_create_new_face(app, &description);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return(new_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
static Face_ID
|
||||||
|
get_face_id_by_description(Application_Links *app, Face_Description *description, Face_Description *base_description){
|
||||||
|
Face_ID new_id = 0;
|
||||||
|
if (!descriptions_match(description, base_description)){
|
||||||
|
new_id = get_existing_face_id_matching_description(app, description);
|
||||||
|
if (new_id == 0){
|
||||||
|
new_id = try_create_new_face(app, description);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return(new_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_global_face_by_name(Application_Links *app, char *name, int32_t len, bool32 apply_to_all_buffers){
|
||||||
|
Face_ID global_face_id = get_face_id(app, 0);
|
||||||
|
Face_Description description = get_face_description(app, global_face_id);
|
||||||
|
Face_ID new_id = get_face_id_by_name(app, name, len, &description);
|
||||||
|
if (new_id != 0){
|
||||||
|
set_global_face(app, new_id, apply_to_all_buffers);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
change_global_face_by_description(Application_Links *app, Face_Description description, bool32 apply_to_all_buffers){
|
||||||
|
Face_ID face_id = get_face_id(app, 0);
|
||||||
|
if (!try_modify_face(app, face_id, &description)){
|
||||||
|
description.font.in_local_font_folder = !description.font.in_local_font_folder;
|
||||||
|
try_modify_face(app, face_id, &description);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_buffer_face_by_name(Application_Links *app, Buffer_Summary *buffer, char *name, int32_t len){
|
||||||
|
Face_ID current_id = get_face_id(app, buffer);
|
||||||
|
if (current_id != 0){
|
||||||
|
Face_Description description = get_face_description(app, current_id);
|
||||||
|
Face_ID new_id = get_face_id_by_name(app, name, len, &description);
|
||||||
|
if (new_id != 0){
|
||||||
|
buffer_set_face(app, buffer, new_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// BOTTOM
|
||||||
|
|
1
4ed.cpp
1
4ed.cpp
|
@ -1633,6 +1633,7 @@ App_Step_Sig(app_step){
|
||||||
char **flags = models->settings.custom_flags;
|
char **flags = models->settings.custom_flags;
|
||||||
i32 flags_count = models->settings.custom_flags_count;
|
i32 flags_count = models->settings.custom_flags_count;
|
||||||
|
|
||||||
|
|
||||||
models->hook_start(&models->app_links, files, files_count, flags, flags_count);
|
models->hook_start(&models->app_links, files, files_count, flags, flags_count);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2463,7 +2463,9 @@ Get_Face_Description(Application_Links *app, Face_ID id)
|
||||||
DOC_PARAM(id, The face slot from which to read a description. If zero gets default values.)
|
DOC_PARAM(id, The face slot from which to read a description. If zero gets default values.)
|
||||||
DOC(Fills out the values of a Face_Description struct, which includes all the information that determines the appearance of the face. If the id does not specify a valid face the description will be invalid. An invalid description has a zero length string in it's font.name field (i.e. description.font.name[0] == 0), and a valid description always contains a non-zero length string in the font.name field (i.e. description.font.name[0] != 0)
|
DOC(Fills out the values of a Face_Description struct, which includes all the information that determines the appearance of the face. If the id does not specify a valid face the description will be invalid. An invalid description has a zero length string in it's font.name field (i.e. description.font.name[0] == 0), and a valid description always contains a non-zero length string in the font.name field (i.e. description.font.name[0] != 0)
|
||||||
|
|
||||||
If the input id is zero, the description returned will be invalid, but the pt_size and hinting fields will reflect the default values for those fields as specified on the command line. The default values, if unspecified, are pt_size=16 and hinting=false. Note that the id of zero is reserved and is never a valid face.)
|
If the input id is zero, the description returned will be invalid, but the pt_size and hinting fields will reflect the default values for those fields as specified on the command line. The default values, if unspecified, are pt_size=0 and hinting=false. These default values are overriden by config.4coder when instantiating fonts at startup, but the original values of pt_size=0 and hinting=false from the command line are preserved and returned here for the lifetime of the program.
|
||||||
|
|
||||||
|
Note that the id of zero is reserved and is never a valid face.)
|
||||||
DOC_RETURN(Returns a Face_Description that is valid if the id references a valid face slot and is filled with the description of the face. Otherwise returns an invalid Face_Description.)
|
DOC_RETURN(Returns a Face_Description that is valid if the id references a valid face slot and is filled with the description of the face. Otherwise returns an invalid Face_Description.)
|
||||||
DOC_SEE(Face_Description)
|
DOC_SEE(Face_Description)
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -33,9 +33,7 @@ global_const App_Settings null_app_settings = {0};
|
||||||
|
|
||||||
struct Debug_Input_Event{
|
struct Debug_Input_Event{
|
||||||
Key_Code key;
|
Key_Code key;
|
||||||
|
|
||||||
char consumer[32];
|
char consumer[32];
|
||||||
|
|
||||||
b8 is_hold;
|
b8 is_hold;
|
||||||
b8 is_ctrl;
|
b8 is_ctrl;
|
||||||
b8 is_alt;
|
b8 is_alt;
|
||||||
|
|
Loading…
Reference in New Issue