added *scratch*
parent
69d617d406
commit
7c87b44c81
37
4ed.cpp
37
4ed.cpp
|
@ -2178,14 +2178,28 @@ App_Step_Sig(app_step){
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
General_Memory *general = &models->mem.general;
|
General_Memory *general = &models->mem.general;
|
||||||
Editing_File *file = working_set_alloc_always(&models->working_set, general);
|
|
||||||
file_create_read_only(system, models, file, "*messages*");
|
|
||||||
working_set_add(system, &models->working_set, file, general);
|
|
||||||
file->settings.never_kill = 1;
|
|
||||||
file->settings.unimportant = 1;
|
|
||||||
file->settings.unwrapped_lines = 1;
|
|
||||||
|
|
||||||
models->message_buffer = file;
|
{
|
||||||
|
Editing_File *file = working_set_alloc_always(&models->working_set, general);
|
||||||
|
file_create_read_only(system, models, file, "*messages*");
|
||||||
|
working_set_add(system, &models->working_set, file, general);
|
||||||
|
file->settings.never_kill = 1;
|
||||||
|
file->settings.unimportant = 1;
|
||||||
|
file->settings.unwrapped_lines = 1;
|
||||||
|
|
||||||
|
models->message_buffer = file;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
Editing_File *file = working_set_alloc_always(&models->working_set, general);
|
||||||
|
file_create_empty(system, models, file, "*scratch*");
|
||||||
|
working_set_add(system, &models->working_set, file, general);
|
||||||
|
file->settings.never_kill = 1;
|
||||||
|
file->settings.unimportant = 1;
|
||||||
|
file->settings.unwrapped_lines = 1;
|
||||||
|
|
||||||
|
models->scratch_buffer = file;
|
||||||
|
}
|
||||||
|
|
||||||
if (models->hooks[hook_start]){
|
if (models->hooks[hook_start]){
|
||||||
models->hooks[hook_start](&models->app_links);
|
models->hooks[hook_start](&models->app_links);
|
||||||
|
@ -2220,6 +2234,14 @@ App_Step_Sig(app_step){
|
||||||
if (i < models->layout.panel_count){
|
if (i < models->layout.panel_count){
|
||||||
view_set_file(panel->view, models->message_buffer, models);
|
view_set_file(panel->view, models->message_buffer, models);
|
||||||
view_show_file(panel->view);
|
view_show_file(panel->view);
|
||||||
|
|
||||||
|
++i;
|
||||||
|
panel = panel->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (;i < models->layout.panel_count; ++i, panel = panel->next){
|
||||||
|
view_set_file(panel->view, models->scratch_buffer, models);
|
||||||
|
view_show_file(panel->view);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2835,6 +2857,7 @@ App_Step_Sig(app_step){
|
||||||
Panel *panel, *used_panels;
|
Panel *panel, *used_panels;
|
||||||
used_panels = &models->layout.used_sentinel;
|
used_panels = &models->layout.used_sentinel;
|
||||||
for (dll_items(panel, used_panels)){
|
for (dll_items(panel, used_panels)){
|
||||||
|
update_view_line_height(models, panel->view);
|
||||||
remeasure_file_view(system, panel->view);
|
remeasure_file_view(system, panel->view);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,6 +68,7 @@ struct Models{
|
||||||
Working_Set working_set;
|
Working_Set working_set;
|
||||||
struct Live_Views *live_set;
|
struct Live_Views *live_set;
|
||||||
Editing_File *message_buffer;
|
Editing_File *message_buffer;
|
||||||
|
Editing_File *scratch_buffer;
|
||||||
|
|
||||||
char hot_dir_base_[256];
|
char hot_dir_base_[256];
|
||||||
Hot_Directory hot_directory;
|
Hot_Directory hot_directory;
|
||||||
|
|
|
@ -1645,12 +1645,12 @@ file_view_nullify_file(View *view){
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
view_set_file(View *view, Editing_File *file, Models *models){
|
view_set_file(View *view, Editing_File *file, Models *models){
|
||||||
Font_Info *fnt_info;
|
#if 0
|
||||||
|
|
||||||
// TODO(allen): This belongs somewhere else.
|
// TODO(allen): This belongs somewhere else.
|
||||||
fnt_info = get_font_info(models->font_set, models->global_font.font_id);
|
Font_Info *fnt_info = get_font_info(models->font_set, models->global_font.font_id);
|
||||||
view->font_advance = fnt_info->advance;
|
view->font_advance = fnt_info->advance;
|
||||||
view->line_height = fnt_info->height;
|
view->line_height = fnt_info->height;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (view->file_data.file != 0){
|
if (view->file_data.file != 0){
|
||||||
touch_file(&models->working_set, view->file_data.file);
|
touch_file(&models->working_set, view->file_data.file);
|
||||||
|
@ -3025,6 +3025,13 @@ style_get_color(Style *style, Cpp_Token token){
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal void
|
||||||
|
update_view_line_height(Models *models, View *view){
|
||||||
|
Font_Info *fnt_info = get_font_info(models->font_set, models->global_font.font_id);
|
||||||
|
view->font_advance = fnt_info->advance;
|
||||||
|
view->line_height = fnt_info->height;
|
||||||
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
remeasure_file_view(System_Functions *system, View *view){
|
remeasure_file_view(System_Functions *system, View *view){
|
||||||
if (file_is_ready(view->file_data.file)){
|
if (file_is_ready(view->file_data.file)){
|
||||||
|
@ -4489,7 +4496,6 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
message = string_zero();
|
message = string_zero();
|
||||||
|
|
||||||
if (!file->settings.unimportant){
|
if (!file->settings.unimportant){
|
||||||
switch (buffer_get_sync(file)){
|
switch (buffer_get_sync(file)){
|
||||||
case SYNC_BEHIND_OS: message = message_unsynced; break;
|
case SYNC_BEHIND_OS: message = message_unsynced; break;
|
||||||
|
@ -4511,9 +4517,11 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
|
||||||
file = reserved_files[i];
|
file = reserved_files[i];
|
||||||
|
|
||||||
message = string_zero();
|
message = string_zero();
|
||||||
switch (buffer_get_sync(file)){
|
if (!file->settings.unimportant){
|
||||||
case SYNC_BEHIND_OS: message = message_unsynced; break;
|
switch (buffer_get_sync(file)){
|
||||||
case SYNC_UNSAVED: message = message_unsaved; break;
|
case SYNC_BEHIND_OS: message = message_unsynced; break;
|
||||||
|
case SYNC_UNSAVED: message = message_unsaved; break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
id.id[0] = (u64)(file);
|
id.id[0] = (u64)(file);
|
||||||
|
@ -5739,7 +5747,7 @@ draw_style_preview(GUI_Target *gui_target, Render_Target *target, View *view, i3
|
||||||
|
|
||||||
draw_margin(target, rect, inner, margin_color);
|
draw_margin(target, rect, inner, margin_color);
|
||||||
draw_rectangle(target, inner, back);
|
draw_rectangle(target, inner, back);
|
||||||
|
|
||||||
i32 y = inner.y0;
|
i32 y = inner.y0;
|
||||||
i32 x = inner.x0;
|
i32 x = inner.x0;
|
||||||
x = CEIL32(draw_string(target, font_id, style->name.str, x, y, text_color));
|
x = CEIL32(draw_string(target, font_id, style->name.str, x, y, text_color));
|
||||||
|
@ -5747,7 +5755,7 @@ draw_style_preview(GUI_Target *gui_target, Render_Target *target, View *view, i3
|
||||||
if (font_x > x + 10){
|
if (font_x > x + 10){
|
||||||
draw_string(target, font_id, info->name.str, font_x, y, text_color);
|
draw_string(target, font_id, info->name.str, font_x, y, text_color);
|
||||||
}
|
}
|
||||||
|
|
||||||
x = inner.x0;
|
x = inner.x0;
|
||||||
y += info->height;
|
y += info->height;
|
||||||
x = CEIL32(draw_string(target, font_id, "if", x, y, keyword_color));
|
x = CEIL32(draw_string(target, font_id, "if", x, y, keyword_color));
|
||||||
|
@ -6017,7 +6025,7 @@ struct Search_Match{
|
||||||
internal void
|
internal void
|
||||||
search_iter_init(General_Memory *general, Search_Iter *iter, i32 size){
|
search_iter_init(General_Memory *general, Search_Iter *iter, i32 size){
|
||||||
i32 str_max;
|
i32 str_max;
|
||||||
|
|
||||||
if (iter->word.str == 0){
|
if (iter->word.str == 0){
|
||||||
str_max = size*2;
|
str_max = size*2;
|
||||||
iter->word.str = (char*)general_memory_allocate(general, str_max, 0);
|
iter->word.str = (char*)general_memory_allocate(general, str_max, 0);
|
||||||
|
@ -6028,7 +6036,7 @@ search_iter_init(General_Memory *general, Search_Iter *iter, i32 size){
|
||||||
iter->word.str = (char*)general_memory_reallocate_nocopy(general, iter->word.str, str_max, 0);
|
iter->word.str = (char*)general_memory_reallocate_nocopy(general, iter->word.str, str_max, 0);
|
||||||
iter->word.memory_size = str_max;
|
iter->word.memory_size = str_max;
|
||||||
}
|
}
|
||||||
|
|
||||||
iter->i = 0;
|
iter->i = 0;
|
||||||
iter->pos = 0;
|
iter->pos = 0;
|
||||||
}
|
}
|
||||||
|
@ -6036,7 +6044,7 @@ search_iter_init(General_Memory *general, Search_Iter *iter, i32 size){
|
||||||
internal void
|
internal void
|
||||||
search_set_init(General_Memory *general, Search_Set *set, i32 set_count){
|
search_set_init(General_Memory *general, Search_Set *set, i32 set_count){
|
||||||
i32 max;
|
i32 max;
|
||||||
|
|
||||||
if (set->ranges == 0){
|
if (set->ranges == 0){
|
||||||
max = set_count*2;
|
max = set_count*2;
|
||||||
set->ranges = (Search_Range*)general_memory_allocate(general, sizeof(Search_Range)*max, 0);
|
set->ranges = (Search_Range*)general_memory_allocate(general, sizeof(Search_Range)*max, 0);
|
||||||
|
@ -6048,7 +6056,7 @@ search_set_init(General_Memory *general, Search_Set *set, i32 set_count){
|
||||||
general, set->ranges, sizeof(Search_Range)*max, 0);
|
general, set->ranges, sizeof(Search_Range)*max, 0);
|
||||||
set->max = max;
|
set->max = max;
|
||||||
}
|
}
|
||||||
|
|
||||||
set->count = set_count;
|
set->count = set_count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6071,7 +6079,7 @@ internal void
|
||||||
search_hits_init(General_Memory *general, Table *hits, String_Space *str, i32 table_size, i32 str_size){
|
search_hits_init(General_Memory *general, Table *hits, String_Space *str, i32 table_size, i32 str_size){
|
||||||
void *mem;
|
void *mem;
|
||||||
i32 mem_size;
|
i32 mem_size;
|
||||||
|
|
||||||
if (hits->hash_array == 0){
|
if (hits->hash_array == 0){
|
||||||
search_hits_table_alloc(general, hits, table_size);
|
search_hits_table_alloc(general, hits, table_size);
|
||||||
}
|
}
|
||||||
|
@ -6080,7 +6088,7 @@ search_hits_init(General_Memory *general, Table *hits, String_Space *str, i32 ta
|
||||||
mem = general_memory_reallocate_nocopy(general, hits->hash_array, mem_size, 0);
|
mem = general_memory_reallocate_nocopy(general, hits->hash_array, mem_size, 0);
|
||||||
table_init_memory(hits, mem, table_size, sizeof(Offset_String));
|
table_init_memory(hits, mem, table_size, sizeof(Offset_String));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (str->space == 0){
|
if (str->space == 0){
|
||||||
str->space = (char*)general_memory_allocate(general, str_size, 0);
|
str->space = (char*)general_memory_allocate(general, str_size, 0);
|
||||||
str->max = str_size;
|
str->max = str_size;
|
||||||
|
@ -6089,7 +6097,7 @@ search_hits_init(General_Memory *general, Table *hits, String_Space *str, i32 ta
|
||||||
str->space = (char*)general_memory_reallocate_nocopy(general, str->space, str_size, 0);
|
str->space = (char*)general_memory_reallocate_nocopy(general, str->space, str_size, 0);
|
||||||
str->max = str_size;
|
str->max = str_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
str->pos = str->new_pos = 0;
|
str->pos = str->new_pos = 0;
|
||||||
table_clear(hits);
|
table_clear(hits);
|
||||||
}
|
}
|
||||||
|
@ -6100,18 +6108,18 @@ search_hit_add(General_Memory *general, Table *hits, String_Space *space, char *
|
||||||
i32 new_size;
|
i32 new_size;
|
||||||
Offset_String ostring;
|
Offset_String ostring;
|
||||||
Table new_hits;
|
Table new_hits;
|
||||||
|
|
||||||
Assert(len != 0);
|
Assert(len != 0);
|
||||||
|
|
||||||
ostring = strspace_append(space, str, len);
|
ostring = strspace_append(space, str, len);
|
||||||
if (ostring.size == 0){
|
if (ostring.size == 0){
|
||||||
new_size = Max(space->max*2, space->max + len);
|
new_size = Max(space->max*2, space->max + len);
|
||||||
space->space = (char*)general_memory_reallocate(general, space->space, space->new_pos, new_size, 0);
|
space->space = (char*)general_memory_reallocate(general, space->space, space->new_pos, new_size, 0);
|
||||||
ostring = strspace_append(space, str, len);
|
ostring = strspace_append(space, str, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert(ostring.size != 0);
|
Assert(ostring.size != 0);
|
||||||
|
|
||||||
if (table_at_capacity(hits)){
|
if (table_at_capacity(hits)){
|
||||||
search_hits_table_alloc(general, &new_hits, hits->max*2);
|
search_hits_table_alloc(general, &new_hits, hits->max*2);
|
||||||
table_clear(&new_hits);
|
table_clear(&new_hits);
|
||||||
|
@ -6119,7 +6127,7 @@ search_hit_add(General_Memory *general, Table *hits, String_Space *space, char *
|
||||||
general_memory_free(general, hits->hash_array);
|
general_memory_free(general, hits->hash_array);
|
||||||
*hits = new_hits;
|
*hits = new_hits;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!table_add(hits, &ostring, space->space, tbl_offset_string_hash, tbl_offset_string_compare)){
|
if (!table_add(hits, &ostring, space->space, tbl_offset_string_hash, tbl_offset_string_compare)){
|
||||||
result = 1;
|
result = 1;
|
||||||
strspace_keep_prev(space);
|
strspace_keep_prev(space);
|
||||||
|
@ -6128,7 +6136,7 @@ search_hit_add(General_Memory *general, Table *hits, String_Space *space, char *
|
||||||
result = 0;
|
result = 0;
|
||||||
strspace_discard_prev(space);
|
strspace_discard_prev(space);
|
||||||
}
|
}
|
||||||
|
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6140,20 +6148,20 @@ search_next_match(Partition *part, Search_Set *set, Search_Iter *iter_){
|
||||||
Temp_Memory temp;
|
Temp_Memory temp;
|
||||||
char *spare;
|
char *spare;
|
||||||
i32 start_pos, end_pos, count;
|
i32 start_pos, end_pos, count;
|
||||||
|
|
||||||
temp = begin_temp_memory(part);
|
temp = begin_temp_memory(part);
|
||||||
spare = push_array(part, char, iter.word.size);
|
spare = push_array(part, char, iter.word.size);
|
||||||
|
|
||||||
count = set->count;
|
count = set->count;
|
||||||
for (; iter.i < count;){
|
for (; iter.i < count;){
|
||||||
range = set->ranges + iter.i;
|
range = set->ranges + iter.i;
|
||||||
|
|
||||||
end_pos = range->start + range->size;
|
end_pos = range->start + range->size;
|
||||||
|
|
||||||
if (iter.pos + iter.word.size < end_pos){
|
if (iter.pos + iter.word.size < end_pos){
|
||||||
start_pos = Max(iter.pos, range->start);
|
start_pos = Max(iter.pos, range->start);
|
||||||
result.start = buffer_find_string(range->buffer, start_pos, end_pos, iter.word.str, iter.word.size, spare);
|
result.start = buffer_find_string(range->buffer, start_pos, end_pos, iter.word.str, iter.word.size, spare);
|
||||||
|
|
||||||
if (result.start < end_pos){
|
if (result.start < end_pos){
|
||||||
iter.pos = result.start + 1;
|
iter.pos = result.start + 1;
|
||||||
if (result.start == 0 || !char_is_alpha_numeric(buffer_get_char(range->buffer, result.start - 1))){
|
if (result.start == 0 || !char_is_alpha_numeric(buffer_get_char(range->buffer, result.start - 1))){
|
||||||
|
@ -6175,9 +6183,9 @@ search_next_match(Partition *part, Search_Set *set, Search_Iter *iter_){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
end_temp_memory(temp);
|
end_temp_memory(temp);
|
||||||
|
|
||||||
*iter_ = iter;
|
*iter_ = iter;
|
||||||
|
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6192,26 +6200,28 @@ view_change_size(General_Memory *general, View *view){
|
||||||
internal View_And_ID
|
internal View_And_ID
|
||||||
live_set_alloc_view(Live_Views *live_set, Panel *panel, Models *models){
|
live_set_alloc_view(Live_Views *live_set, Panel *panel, Models *models){
|
||||||
View_And_ID result = {};
|
View_And_ID result = {};
|
||||||
|
|
||||||
Assert(live_set->count < live_set->max);
|
Assert(live_set->count < live_set->max);
|
||||||
++live_set->count;
|
++live_set->count;
|
||||||
|
|
||||||
result.view = live_set->free_sentinel.next;
|
result.view = live_set->free_sentinel.next;
|
||||||
result.id = (i32)(result.view - live_set->views);
|
result.id = (i32)(result.view - live_set->views);
|
||||||
Assert(result.id == result.view->persistent.id);
|
Assert(result.id == result.view->persistent.id);
|
||||||
|
|
||||||
dll_remove(result.view);
|
dll_remove(result.view);
|
||||||
memset(get_view_body(result.view), 0, get_view_size());
|
memset(get_view_body(result.view), 0, get_view_size());
|
||||||
|
|
||||||
result.view->in_use = 1;
|
result.view->in_use = 1;
|
||||||
panel->view = result.view;
|
panel->view = result.view;
|
||||||
result.view->panel = panel;
|
result.view->panel = panel;
|
||||||
|
|
||||||
result.view->persistent.models = models;
|
result.view->persistent.models = models;
|
||||||
result.view->current_scroll = &result.view->recent.scroll;
|
result.view->current_scroll = &result.view->recent.scroll;
|
||||||
|
|
||||||
|
update_view_line_height(models, result.view);
|
||||||
|
|
||||||
init_query_set(&result.view->query_set);
|
init_query_set(&result.view->query_set);
|
||||||
|
|
||||||
{
|
{
|
||||||
i32 gui_mem_size = Kbytes(32);
|
i32 gui_mem_size = Kbytes(32);
|
||||||
void *gui_mem = general_memory_allocate(&models->mem.general, gui_mem_size + 8, 0);
|
void *gui_mem = general_memory_allocate(&models->mem.general, gui_mem_size + 8, 0);
|
||||||
|
|
|
@ -93,6 +93,9 @@ CUSTOM_COMMAND_SIG(change_active_panel_build){
|
||||||
view = app->get_active_view(app, AccessAll);
|
view = app->get_active_view(app, AccessAll);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else{
|
||||||
|
exec_command(app, cmdid_change_active_panel);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(allen): This is a bit nasty. I want a system for picking
|
// TODO(allen): This is a bit nasty. I want a system for picking
|
||||||
|
|
Loading…
Reference in New Issue