boiled out the redraw nonsense, close to event drive now
parent
dd0661e0e5
commit
653cc0bf23
|
@ -249,7 +249,6 @@ enum Param_ID{
|
||||||
enum Hook_ID{
|
enum Hook_ID{
|
||||||
hook_start,
|
hook_start,
|
||||||
hook_open_file,
|
hook_open_file,
|
||||||
hook_frame,
|
|
||||||
hook_new_file,
|
hook_new_file,
|
||||||
hook_file_out_of_sync,
|
hook_file_out_of_sync,
|
||||||
// never below this
|
// never below this
|
||||||
|
|
|
@ -77,45 +77,6 @@ HOOK_SIG(my_file_settings){
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
HOOK_SIG(my_frame){
|
|
||||||
// NOTE(allen|a4): Please use me sparingly! This get's called roughly once every *33 ms*
|
|
||||||
// if everything is going well. But if you start doing a lot in here, there's nothing 4codes does
|
|
||||||
// to stop you from making it a lot slower.
|
|
||||||
|
|
||||||
int result = 0;
|
|
||||||
Theme_Color theme_color_1[] = {
|
|
||||||
{Stag_Cursor, 0x00FF00},
|
|
||||||
{Stag_At_Cursor, 0x000000}
|
|
||||||
};
|
|
||||||
|
|
||||||
Theme_Color theme_color_2[2] = {
|
|
||||||
{Stag_Cursor, 0x000000},
|
|
||||||
{Stag_At_Cursor, 0xFFFFFF}
|
|
||||||
};
|
|
||||||
|
|
||||||
Theme_Color *theme_color;
|
|
||||||
|
|
||||||
++blink_t;
|
|
||||||
|
|
||||||
if (blink_t == 20 || blink_t == 40){
|
|
||||||
if (blink_t == 20){
|
|
||||||
theme_color = theme_color_2;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
theme_color = theme_color_1;
|
|
||||||
blink_t = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
result = 1;
|
|
||||||
app->set_theme_colors(app, theme_color, 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
// return non-zero if you do anything that might change the screen!
|
|
||||||
// 4coder won't redraw unless you tell it you've changed something important.
|
|
||||||
// If you redraw *all* the time it's going to slow 4coder down and increase power consumption.
|
|
||||||
return(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
CUSTOM_COMMAND_SIG(write_allen_todo){
|
CUSTOM_COMMAND_SIG(write_allen_todo){
|
||||||
write_string(app, make_lit_string("// TODO(allen): "));
|
write_string(app, make_lit_string("// TODO(allen): "));
|
||||||
}
|
}
|
||||||
|
|
192
4ed.cpp
192
4ed.cpp
|
@ -235,7 +235,7 @@ COMMAND_DECL(null){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(write_character){
|
COMMAND_DECL(write_character){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -282,7 +282,7 @@ seek_token_right(Cpp_Token_Stack *tokens, i32 pos){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(seek_left){
|
COMMAND_DECL(seek_left){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -335,7 +335,7 @@ COMMAND_DECL(seek_left){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(seek_right){
|
COMMAND_DECL(seek_right){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -390,7 +390,7 @@ COMMAND_DECL(seek_right){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(seek_whitespace_up){
|
COMMAND_DECL(seek_whitespace_up){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -399,7 +399,7 @@ COMMAND_DECL(seek_whitespace_up){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(seek_whitespace_down){
|
COMMAND_DECL(seek_whitespace_down){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -408,7 +408,7 @@ COMMAND_DECL(seek_whitespace_down){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(center_view){
|
COMMAND_DECL(center_view){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -428,7 +428,7 @@ COMMAND_DECL(center_view){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(word_complete){
|
COMMAND_DECL(word_complete){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_VARS(vars);
|
USE_VARS(vars);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
|
@ -588,7 +588,7 @@ COMMAND_DECL(word_complete){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(set_mark){
|
COMMAND_DECL(set_mark){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -596,7 +596,7 @@ COMMAND_DECL(set_mark){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(copy){
|
COMMAND_DECL(copy){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -631,7 +631,7 @@ COMMAND_DECL(copy){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(cut){
|
COMMAND_DECL(cut){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -672,7 +672,7 @@ COMMAND_DECL(cut){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(paste){
|
COMMAND_DECL(paste){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -702,7 +702,7 @@ COMMAND_DECL(paste){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(paste_next){
|
COMMAND_DECL(paste_next){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -737,7 +737,7 @@ COMMAND_DECL(paste_next){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(delete_range){
|
COMMAND_DECL(delete_range){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -756,7 +756,7 @@ COMMAND_DECL(delete_range){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(timeline_scrub){
|
COMMAND_DECL(timeline_scrub){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE_HISTORY(file, view);
|
REQ_FILE_HISTORY(file, view);
|
||||||
|
|
||||||
|
@ -766,7 +766,7 @@ COMMAND_DECL(timeline_scrub){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(undo){
|
COMMAND_DECL(undo){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE_HISTORY(file, view);
|
REQ_FILE_HISTORY(file, view);
|
||||||
|
@ -775,7 +775,7 @@ COMMAND_DECL(undo){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(redo){
|
COMMAND_DECL(redo){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE_HISTORY(file, view);
|
REQ_FILE_HISTORY(file, view);
|
||||||
|
@ -784,7 +784,7 @@ COMMAND_DECL(redo){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(history_backward){
|
COMMAND_DECL(history_backward){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE_HISTORY(file, view);
|
REQ_FILE_HISTORY(file, view);
|
||||||
|
@ -793,7 +793,7 @@ COMMAND_DECL(history_backward){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(history_forward){
|
COMMAND_DECL(history_forward){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE_HISTORY(file, view);
|
REQ_FILE_HISTORY(file, view);
|
||||||
|
@ -802,7 +802,7 @@ COMMAND_DECL(history_forward){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(interactive_new){
|
COMMAND_DECL(interactive_new){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
|
|
||||||
|
@ -828,7 +828,7 @@ struct App_Open_File_Result{
|
||||||
};
|
};
|
||||||
|
|
||||||
COMMAND_DECL(interactive_open){
|
COMMAND_DECL(interactive_open){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_PANEL(panel);
|
USE_PANEL(panel);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
|
@ -908,7 +908,7 @@ view_file_in_panel(Command_Data *cmd, Panel *panel, Editing_File *file){
|
||||||
// - Keep current version open and do some sort of diff to keep
|
// - Keep current version open and do some sort of diff to keep
|
||||||
// the cursor position correct
|
// the cursor position correct
|
||||||
COMMAND_DECL(reopen){
|
COMMAND_DECL(reopen){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VARS(vars);
|
USE_VARS(vars);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
|
@ -933,7 +933,7 @@ COMMAND_DECL(reopen){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(save){
|
COMMAND_DECL(save){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_FILE(file, view);
|
USE_FILE(file, view);
|
||||||
|
@ -1009,7 +1009,7 @@ COMMAND_DECL(save){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(change_active_panel){
|
COMMAND_DECL(change_active_panel){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_PANEL(panel);
|
USE_PANEL(panel);
|
||||||
|
|
||||||
|
@ -1021,7 +1021,7 @@ COMMAND_DECL(change_active_panel){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(interactive_switch_buffer){
|
COMMAND_DECL(interactive_switch_buffer){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
|
|
||||||
|
@ -1030,7 +1030,7 @@ COMMAND_DECL(interactive_switch_buffer){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(interactive_kill_buffer){
|
COMMAND_DECL(interactive_kill_buffer){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
|
|
||||||
|
@ -1039,7 +1039,7 @@ COMMAND_DECL(interactive_kill_buffer){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(kill_buffer){
|
COMMAND_DECL(kill_buffer){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_FILE(file, view);
|
USE_FILE(file, view);
|
||||||
|
@ -1068,7 +1068,7 @@ COMMAND_DECL(kill_buffer){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(toggle_line_wrap){
|
COMMAND_DECL(toggle_line_wrap){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -1092,14 +1092,14 @@ COMMAND_DECL(toggle_line_wrap){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(toggle_show_whitespace){
|
COMMAND_DECL(toggle_show_whitespace){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
view->show_whitespace = !view->show_whitespace;
|
view->show_whitespace = !view->show_whitespace;
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(toggle_tokens){
|
COMMAND_DECL(toggle_tokens){
|
||||||
#if BUFFER_EXPERIMENT_SCALPEL <= 0
|
#if BUFFER_EXPERIMENT_SCALPEL <= 0
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1145,7 +1145,7 @@ case_change_range(System_Functions *system,
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(to_uppercase){
|
COMMAND_DECL(to_uppercase){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1153,7 +1153,7 @@ COMMAND_DECL(to_uppercase){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(to_lowercase){
|
COMMAND_DECL(to_lowercase){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1161,7 +1161,7 @@ COMMAND_DECL(to_lowercase){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(clean_all_lines){
|
COMMAND_DECL(clean_all_lines){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1170,7 +1170,7 @@ COMMAND_DECL(clean_all_lines){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(eol_dosify){
|
COMMAND_DECL(eol_dosify){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -1179,7 +1179,7 @@ COMMAND_DECL(eol_dosify){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(eol_nixify){
|
COMMAND_DECL(eol_nixify){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -1188,7 +1188,7 @@ COMMAND_DECL(eol_nixify){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(auto_tab_range){
|
COMMAND_DECL(auto_tab_range){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1233,7 +1233,7 @@ COMMAND_DECL(auto_tab_range){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(open_panel_vsplit){
|
COMMAND_DECL(open_panel_vsplit){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VARS(vars);
|
USE_VARS(vars);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_PANEL(panel);
|
USE_PANEL(panel);
|
||||||
|
@ -1261,7 +1261,7 @@ COMMAND_DECL(open_panel_vsplit){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(open_panel_hsplit){
|
COMMAND_DECL(open_panel_hsplit){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VARS(vars);
|
USE_VARS(vars);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_PANEL(panel);
|
USE_PANEL(panel);
|
||||||
|
@ -1289,7 +1289,7 @@ COMMAND_DECL(open_panel_hsplit){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(close_panel){
|
COMMAND_DECL(close_panel){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_PANEL(panel);
|
USE_PANEL(panel);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
|
@ -1370,7 +1370,7 @@ COMMAND_DECL(close_panel){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(move_left){
|
COMMAND_DECL(move_left){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -1380,7 +1380,7 @@ COMMAND_DECL(move_left){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(move_right){
|
COMMAND_DECL(move_right){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -1391,7 +1391,7 @@ COMMAND_DECL(move_right){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(delete){
|
COMMAND_DECL(delete){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1412,7 +1412,7 @@ COMMAND_DECL(delete){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(backspace){
|
COMMAND_DECL(backspace){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_OPEN_VIEW(view);
|
REQ_OPEN_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1434,7 +1434,7 @@ COMMAND_DECL(backspace){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(move_up){
|
COMMAND_DECL(move_up){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1449,7 +1449,7 @@ COMMAND_DECL(move_up){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(move_down){
|
COMMAND_DECL(move_down){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
@ -1462,7 +1462,7 @@ COMMAND_DECL(move_down){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(seek_end_of_line){
|
COMMAND_DECL(seek_end_of_line){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -1471,7 +1471,7 @@ COMMAND_DECL(seek_end_of_line){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(seek_beginning_of_line){
|
COMMAND_DECL(seek_beginning_of_line){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
|
||||||
|
@ -1480,7 +1480,7 @@ COMMAND_DECL(seek_beginning_of_line){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(page_down){
|
COMMAND_DECL(page_down){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
|
|
||||||
f32 height = view_file_height(view);
|
f32 height = view_file_height(view);
|
||||||
|
@ -1494,7 +1494,7 @@ COMMAND_DECL(page_down){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(page_up){
|
COMMAND_DECL(page_up){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
|
|
||||||
f32 height = view_file_height(view);
|
f32 height = view_file_height(view);
|
||||||
|
@ -1508,7 +1508,7 @@ COMMAND_DECL(page_up){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(open_color_tweaker){
|
COMMAND_DECL(open_color_tweaker){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
|
|
||||||
|
@ -1516,7 +1516,7 @@ COMMAND_DECL(open_color_tweaker){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(open_config){
|
COMMAND_DECL(open_config){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
|
|
||||||
|
@ -1524,7 +1524,7 @@ COMMAND_DECL(open_config){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(open_menu){
|
COMMAND_DECL(open_menu){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
|
|
||||||
|
@ -1532,7 +1532,7 @@ COMMAND_DECL(open_menu){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(close_minor_view){
|
COMMAND_DECL(close_minor_view){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
|
|
||||||
|
@ -1544,7 +1544,7 @@ COMMAND_DECL(close_minor_view){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(cursor_mark_swap){
|
COMMAND_DECL(cursor_mark_swap){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
|
|
||||||
i32 pos = view->cursor.pos;
|
i32 pos = view->cursor.pos;
|
||||||
|
@ -1553,12 +1553,12 @@ COMMAND_DECL(cursor_mark_swap){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(user_callback){
|
COMMAND_DECL(user_callback){
|
||||||
ProfileMomentFunction();
|
|
||||||
if (binding.custom) binding.custom(&app_links);
|
if (binding.custom) binding.custom(&app_links);
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(set_settings){
|
COMMAND_DECL(set_settings){
|
||||||
ProfileMomentFunction();
|
|
||||||
REQ_READABLE_VIEW(view);
|
REQ_READABLE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
|
@ -1641,7 +1641,7 @@ COMMAND_DECL(set_settings){
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(command_line){
|
COMMAND_DECL(command_line){
|
||||||
ProfileMomentFunction();
|
|
||||||
USE_VARS(vars);
|
USE_VARS(vars);
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_PANEL(panel);
|
USE_PANEL(panel);
|
||||||
|
@ -3487,25 +3487,18 @@ update_cli_handle_with_file(System_Functions *system, Models *models,
|
||||||
}
|
}
|
||||||
|
|
||||||
App_Step_Sig(app_step){
|
App_Step_Sig(app_step){
|
||||||
ProfileStart(OS_syncing);
|
|
||||||
Application_Step_Result app_result = *result;
|
Application_Step_Result app_result = *result;
|
||||||
app_result.redraw = force_redraw;
|
|
||||||
|
|
||||||
App_Vars *vars = (App_Vars*)memory->vars_memory;
|
App_Vars *vars = (App_Vars*)memory->vars_memory;
|
||||||
Models *models = &vars->models;
|
Models *models = &vars->models;
|
||||||
target->partition = &models->mem.part;
|
target->partition = &models->mem.part;
|
||||||
|
|
||||||
if (first_step || !time_step){
|
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// NOTE(allen): OS clipboard event handling
|
// NOTE(allen): OS clipboard event handling
|
||||||
if (clipboard.str){
|
if (clipboard.str){
|
||||||
String *dest = working_set_next_clipboard_string(&models->mem.general, &models->working_set, clipboard.size);
|
String *dest = working_set_next_clipboard_string(&models->mem.general, &models->working_set, clipboard.size);
|
||||||
dest->size = eol_convert_in(dest->str, clipboard.str, clipboard.size);
|
dest->size = eol_convert_in(dest->str, clipboard.str, clipboard.size);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(allen): profile this see if it's costing me lots of power (I think it is).
|
|
||||||
// NOTE(allen): check files are up to date
|
// NOTE(allen): check files are up to date
|
||||||
{
|
{
|
||||||
File_Node *node, *used_nodes;
|
File_Node *node, *used_nodes;
|
||||||
|
@ -3519,22 +3512,22 @@ App_Step_Sig(app_step){
|
||||||
time_stamp = system->file_time_stamp(make_c_str(file->name.source_path));
|
time_stamp = system->file_time_stamp(make_c_str(file->name.source_path));
|
||||||
|
|
||||||
if (time_stamp > 0){
|
if (time_stamp > 0){
|
||||||
File_Sync_State prev_sync = buffer_get_sync(file);
|
|
||||||
|
|
||||||
file->state.last_sys_write_time = time_stamp;
|
file->state.last_sys_write_time = time_stamp;
|
||||||
|
#if 0
|
||||||
|
File_Sync_State prev_sync = buffer_get_sync(file);
|
||||||
file->state.sync = buffer_get_sync(file);
|
file->state.sync = buffer_get_sync(file);
|
||||||
|
|
||||||
if (file->state.last_sys_write_time != file->state.last_4ed_write_time){
|
if (file->state.last_sys_write_time != file->state.last_4ed_write_time){
|
||||||
if (file->state.sync != prev_sync){
|
if (file->state.sync != prev_sync){
|
||||||
app_result.redraw = 1;
|
app_result.redraw = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE(allen): update child processes
|
// NOTE(allen): update child processes
|
||||||
if (time_step){
|
if (dt > 0){
|
||||||
Temp_Memory temp = begin_temp_memory(&models->mem.part);
|
Temp_Memory temp = begin_temp_memory(&models->mem.part);
|
||||||
u32 max = Kbytes(32);
|
u32 max = Kbytes(32);
|
||||||
char *dest = push_array(&models->mem.part, char, max);
|
char *dest = push_array(&models->mem.part, char, max);
|
||||||
|
@ -3546,7 +3539,6 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
if (file != 0){
|
if (file != 0){
|
||||||
i32 r = update_cli_handle_with_file(system, models, &proc->cli, file, dest, max, 0);
|
i32 r = update_cli_handle_with_file(system, models, &proc->cli, file, dest, max, 0);
|
||||||
if (r) app_result.redraw = 1;
|
|
||||||
if (r < 0){
|
if (r < 0){
|
||||||
*proc = vars->cli_processes.procs[--count];
|
*proc = vars->cli_processes.procs[--count];
|
||||||
--i;
|
--i;
|
||||||
|
@ -3582,8 +3574,6 @@ App_Step_Sig(app_step){
|
||||||
// be handled in the same place.
|
// be handled in the same place.
|
||||||
view_change_size(system, &models->mem.general, view);
|
view_change_size(system, &models->mem.general, view);
|
||||||
}
|
}
|
||||||
|
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3598,9 +3588,6 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
mouse->wheel = -mouse->wheel;
|
mouse->wheel = -mouse->wheel;
|
||||||
|
|
||||||
ProfileEnd(OS_syncing);
|
|
||||||
|
|
||||||
ProfileStart(hover_status);
|
|
||||||
// NOTE(allen): detect mouse hover status
|
// NOTE(allen): detect mouse hover status
|
||||||
i32 mx = mouse->x;
|
i32 mx = mouse->x;
|
||||||
i32 my = mouse->y;
|
i32 my = mouse->y;
|
||||||
|
@ -3677,11 +3664,8 @@ App_Step_Sig(app_step){
|
||||||
mouse_divider_id = 0;
|
mouse_divider_id = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProfileEnd(hover_status);
|
|
||||||
|
|
||||||
// NOTE(allen): prepare to start executing commands
|
// NOTE(allen): prepare to start executing commands
|
||||||
ProfileStart(prepare_commands);
|
|
||||||
|
|
||||||
Command_Data *cmd = &vars->command_data;
|
Command_Data *cmd = &vars->command_data;
|
||||||
|
|
||||||
cmd->models = models;
|
cmd->models = models;
|
||||||
|
@ -3757,10 +3741,8 @@ App_Step_Sig(app_step){
|
||||||
do_feedback_message(system, models, welcome);
|
do_feedback_message(system, models, welcome);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProfileEnd(prepare_commands);
|
|
||||||
|
|
||||||
// NOTE(allen): try to abort the command corroutine if we are shutting down
|
// NOTE(allen): try to abort the command corroutine if we are shutting down
|
||||||
ProfileStart(try_to_shutdown);
|
|
||||||
if (app_result.trying_to_kill){
|
if (app_result.trying_to_kill){
|
||||||
b32 there_is_unsaved = 0;
|
b32 there_is_unsaved = 0;
|
||||||
|
|
||||||
|
@ -3802,16 +3784,13 @@ App_Step_Sig(app_step){
|
||||||
IAct_Sure_To_Close, IInt_Sure_To_Close, make_lit_string("Are you sure?"));
|
IAct_Sure_To_Close, IInt_Sure_To_Close, make_lit_string("Are you sure?"));
|
||||||
|
|
||||||
models->command_coroutine = command_coroutine;
|
models->command_coroutine = command_coroutine;
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
app_result.perform_kill = 1;
|
app_result.perform_kill = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProfileEnd(try_to_shutdown);
|
|
||||||
|
|
||||||
// NOTE(allen): process the command_coroutine if it is unfinished
|
// NOTE(allen): process the command_coroutine if it is unfinished
|
||||||
ProfileStart(command_coroutine);
|
|
||||||
b8 consumed_input[6] = {0};
|
b8 consumed_input[6] = {0};
|
||||||
|
|
||||||
if (models->command_coroutine != 0){
|
if (models->command_coroutine != 0){
|
||||||
|
@ -3860,7 +3839,6 @@ App_Step_Sig(app_step){
|
||||||
if (pass_in){
|
if (pass_in){
|
||||||
models->command_coroutine =
|
models->command_coroutine =
|
||||||
system->resume_coroutine(command_coroutine, &user_in, models->command_coroutine_flags);
|
system->resume_coroutine(command_coroutine, &user_in, models->command_coroutine_flags);
|
||||||
app_result.redraw = 1;
|
|
||||||
|
|
||||||
// TOOD(allen): Deduplicate
|
// TOOD(allen): Deduplicate
|
||||||
// TODO(allen): Should I somehow allow a view to clean up however it wants after a
|
// TODO(allen): Should I somehow allow a view to clean up however it wants after a
|
||||||
|
@ -3924,7 +3902,6 @@ App_Step_Sig(app_step){
|
||||||
if (pass_in){
|
if (pass_in){
|
||||||
models->command_coroutine = system->resume_coroutine(command_coroutine, &user_in,
|
models->command_coroutine = system->resume_coroutine(command_coroutine, &user_in,
|
||||||
models->command_coroutine_flags);
|
models->command_coroutine_flags);
|
||||||
app_result.redraw = 1;
|
|
||||||
|
|
||||||
// TOOD(allen): Deduplicate
|
// TOOD(allen): Deduplicate
|
||||||
// TODO(allen): Should I somehow allow a view to clean up however it wants after a
|
// TODO(allen): Should I somehow allow a view to clean up however it wants after a
|
||||||
|
@ -3938,18 +3915,7 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
update_command_data(vars, cmd);
|
update_command_data(vars, cmd);
|
||||||
|
|
||||||
ProfileEnd(command_coroutine);
|
|
||||||
|
|
||||||
ProfileStart(frame_hook);
|
|
||||||
if (models->hooks[hook_frame]){
|
|
||||||
if ((models->hooks[hook_frame])(&app_links)){
|
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ProfileStart(frame_hook);
|
|
||||||
|
|
||||||
// NOTE(allen): pass raw input to the panels
|
// NOTE(allen): pass raw input to the panels
|
||||||
ProfileStart(step);
|
|
||||||
|
|
||||||
Input_Summary dead_input = {};
|
Input_Summary dead_input = {};
|
||||||
dead_input.mouse.x = mouse->x;
|
dead_input.mouse.x = mouse->x;
|
||||||
|
@ -4002,9 +3968,7 @@ App_Step_Sig(app_step){
|
||||||
view = panel->view;
|
view = panel->view;
|
||||||
active = (panel == cmd->panel);
|
active = (panel == cmd->panel);
|
||||||
input = (active)?(active_input):(dead_input);
|
input = (active)?(active_input):(dead_input);
|
||||||
if (step_file_view(system, view, active_view, input)){
|
step_file_view(system, view, active_view, input);
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (dll_items(panel, used_panels)){
|
for (dll_items(panel, used_panels)){
|
||||||
|
@ -4014,17 +3978,13 @@ App_Step_Sig(app_step){
|
||||||
if (panel == mouse_panel && !mouse->out_of_window){
|
if (panel == mouse_panel && !mouse->out_of_window){
|
||||||
input.mouse = mouse_state;
|
input.mouse = mouse_state;
|
||||||
}
|
}
|
||||||
if (do_input_file_view(system, exchange, view, panel->inner, active, &input)){
|
do_input_file_view(system, exchange, view, panel->inner, active, &input);
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
update_command_data(vars, cmd);
|
update_command_data(vars, cmd);
|
||||||
ProfileEnd(step);
|
|
||||||
|
|
||||||
// NOTE(allen): command execution
|
// NOTE(allen): command execution
|
||||||
ProfileStart(command);
|
|
||||||
if (!consumed_input[0] || !consumed_input[1]){
|
if (!consumed_input[0] || !consumed_input[1]){
|
||||||
b32 consumed_input2[2] = {0};
|
b32 consumed_input2[2] = {0};
|
||||||
|
|
||||||
|
@ -4065,7 +4025,6 @@ App_Step_Sig(app_step){
|
||||||
models->command_coroutine = system->launch_coroutine(models->command_coroutine,
|
models->command_coroutine = system->launch_coroutine(models->command_coroutine,
|
||||||
&cmd_in, models->command_coroutine_flags);
|
&cmd_in, models->command_coroutine_flags);
|
||||||
models->prev_command = cmd_bind;
|
models->prev_command = cmd_bind;
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
@ -4084,9 +4043,7 @@ App_Step_Sig(app_step){
|
||||||
}
|
}
|
||||||
|
|
||||||
update_command_data(vars, cmd);
|
update_command_data(vars, cmd);
|
||||||
ProfileEnd(command);
|
|
||||||
|
|
||||||
ProfileStart(resizing);
|
|
||||||
// NOTE(allen): panel resizing
|
// NOTE(allen): panel resizing
|
||||||
switch (vars->state){
|
switch (vars->state){
|
||||||
case APP_STATE_EDIT:
|
case APP_STATE_EDIT:
|
||||||
|
@ -4158,7 +4115,6 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
case APP_STATE_RESIZING:
|
case APP_STATE_RESIZING:
|
||||||
{
|
{
|
||||||
app_result.redraw = 1;
|
|
||||||
if (mouse->l){
|
if (mouse->l){
|
||||||
Panel_Divider *divider = vars->resizing.divider;
|
Panel_Divider *divider = vars->resizing.divider;
|
||||||
if (divider->v_divider){
|
if (divider->v_divider){
|
||||||
|
@ -4185,14 +4141,11 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
if (mouse_in_edit_area && mouse_panel != 0 && mouse->press_l){
|
if (mouse_in_edit_area && mouse_panel != 0 && mouse->press_l){
|
||||||
models->layout.active_panel = (i32)(mouse_panel - models->layout.panels);
|
models->layout.active_panel = (i32)(mouse_panel - models->layout.panels);
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
update_command_data(vars, cmd);
|
update_command_data(vars, cmd);
|
||||||
ProfileEnd(resizing);
|
|
||||||
|
|
||||||
// NOTE(allen): processing sys app bindings
|
// NOTE(allen): processing sys app bindings
|
||||||
ProfileStart(sys_app_bind_processing);
|
|
||||||
{
|
{
|
||||||
Mem_Options *mem = &models->mem;
|
Mem_Options *mem = &models->mem;
|
||||||
General_Memory *general = &mem->general;
|
General_Memory *general = &mem->general;
|
||||||
|
@ -4236,8 +4189,6 @@ App_Step_Sig(app_step){
|
||||||
view_measure_wraps(system, general, iter.view);
|
view_measure_wraps(system, general, iter.view);
|
||||||
view_cursor_move(iter.view, preload_settings.start_line, 0);
|
view_cursor_move(iter.view, preload_settings.start_line, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
if (binding->fail & SysAppCreateNewBuffer){
|
if (binding->fail & SysAppCreateNewBuffer){
|
||||||
|
@ -4250,8 +4201,6 @@ App_Step_Sig(app_step){
|
||||||
working_set_remove(system, &models->working_set, ed_file->name.source_path);
|
working_set_remove(system, &models->working_set, ed_file->name.source_path);
|
||||||
working_set_free_file(&models->working_set, ed_file);
|
working_set_free_file(&models->working_set, ed_file);
|
||||||
}
|
}
|
||||||
|
|
||||||
app_result.redraw = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
exchange_free_file(exchange, binding->sys_id);
|
exchange_free_file(exchange, binding->sys_id);
|
||||||
|
@ -4283,10 +4232,8 @@ App_Step_Sig(app_step){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProfileEnd(sys_app_bind_processing);
|
|
||||||
|
|
||||||
// NOTE(allen): process as many delayed actions as possible
|
// NOTE(allen): process as many delayed actions as possible
|
||||||
ProfileStart(delayed_actions);
|
|
||||||
if (models->delay1.count > 0){
|
if (models->delay1.count > 0){
|
||||||
Working_Set *working_set = &models->working_set;
|
Working_Set *working_set = &models->working_set;
|
||||||
Mem_Options *mem = &models->mem;
|
Mem_Options *mem = &models->mem;
|
||||||
|
@ -4322,8 +4269,6 @@ App_Step_Sig(app_step){
|
||||||
String filename = string;
|
String filename = string;
|
||||||
i32 file_id;
|
i32 file_id;
|
||||||
|
|
||||||
filename.str[0] = char_to_lower(filename.str[0]);
|
|
||||||
|
|
||||||
result.file = working_set_contains(system, working_set, filename);
|
result.file = working_set_contains(system, working_set, filename);
|
||||||
if (result.file == 0){
|
if (result.file == 0){
|
||||||
result.is_new = 1;
|
result.is_new = 1;
|
||||||
|
@ -4522,9 +4467,7 @@ App_Step_Sig(app_step){
|
||||||
}
|
}
|
||||||
|
|
||||||
end_temp_memory(param_stack_temp);
|
end_temp_memory(param_stack_temp);
|
||||||
ProfileEnd(delayed_actions);
|
|
||||||
|
|
||||||
ProfileStart(resize);
|
|
||||||
// NOTE(allen): send resize messages to panels that have changed size
|
// NOTE(allen): send resize messages to panels that have changed size
|
||||||
{
|
{
|
||||||
Panel *panel, *used_panels;
|
Panel *panel, *used_panels;
|
||||||
|
@ -4539,9 +4482,7 @@ App_Step_Sig(app_step){
|
||||||
panel->prev_inner = inner;
|
panel->prev_inner = inner;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProfileEnd(resize);
|
|
||||||
|
|
||||||
ProfileStart(style_change);
|
|
||||||
// NOTE(allen): send style change messages if the style has changed
|
// NOTE(allen): send style change messages if the style has changed
|
||||||
if (models->global_font.font_changed){
|
if (models->global_font.font_changed){
|
||||||
models->global_font.font_changed = 0;
|
models->global_font.font_changed = 0;
|
||||||
|
@ -4564,11 +4505,9 @@ App_Step_Sig(app_step){
|
||||||
remeasure_file_view(system, panel->view, panel->inner);
|
remeasure_file_view(system, panel->view, panel->inner);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProfileEnd(style_change);
|
|
||||||
|
|
||||||
ProfileStart(redraw);
|
// NOTE(allen): rendering
|
||||||
if (mouse_panel != models->prev_mouse_panel) app_result.redraw = 1;
|
{
|
||||||
if (app_result.redraw){
|
|
||||||
begin_render_section(target, system);
|
begin_render_section(target, system);
|
||||||
|
|
||||||
target->clip_top = -1;
|
target->clip_top = -1;
|
||||||
|
@ -4610,9 +4549,7 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
end_render_section(target, system);
|
end_render_section(target, system);
|
||||||
}
|
}
|
||||||
ProfileEnd(redraw);
|
|
||||||
|
|
||||||
ProfileStart(get_cursor);
|
|
||||||
// NOTE(allen): get cursor type
|
// NOTE(allen): get cursor type
|
||||||
if (mouse_in_edit_area){
|
if (mouse_in_edit_area){
|
||||||
app_result.mouse_cursor_type = APP_MOUSE_CURSOR_ARROW;
|
app_result.mouse_cursor_type = APP_MOUSE_CURSOR_ARROW;
|
||||||
|
@ -4631,7 +4568,6 @@ App_Step_Sig(app_step){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
models->prev_mouse_panel = mouse_panel;
|
models->prev_mouse_panel = mouse_panel;
|
||||||
ProfileEnd(get_cursor);
|
|
||||||
|
|
||||||
app_result.lctrl_lalt_is_altgr = models->settings.lctrl_lalt_is_altgr;
|
app_result.lctrl_lalt_is_altgr = models->settings.lctrl_lalt_is_altgr;
|
||||||
*result = app_result;
|
*result = app_result;
|
||||||
|
|
3
4ed.h
3
4ed.h
|
@ -97,7 +97,6 @@ enum Application_Mouse_Cursor{
|
||||||
|
|
||||||
struct Application_Step_Result{
|
struct Application_Step_Result{
|
||||||
Application_Mouse_Cursor mouse_cursor_type;
|
Application_Mouse_Cursor mouse_cursor_type;
|
||||||
b32 redraw;
|
|
||||||
b32 lctrl_lalt_is_altgr;
|
b32 lctrl_lalt_is_altgr;
|
||||||
b32 trying_to_kill;
|
b32 trying_to_kill;
|
||||||
b32 perform_kill;
|
b32 perform_kill;
|
||||||
|
@ -111,7 +110,7 @@ name(System_Functions *system, \
|
||||||
Application_Memory *memory, \
|
Application_Memory *memory, \
|
||||||
Exchange *exchange, \
|
Exchange *exchange, \
|
||||||
String clipboard, \
|
String clipboard, \
|
||||||
b32 time_step, b32 first_step, b32 force_redraw, \
|
f32 dt, b32 first_step, \
|
||||||
Application_Step_Result *result)
|
Application_Step_Result *result)
|
||||||
|
|
||||||
typedef App_Step_Sig(App_Step);
|
typedef App_Step_Sig(App_Step);
|
||||||
|
|
15
4ed_file.cpp
15
4ed_file.cpp
|
@ -429,7 +429,11 @@ working_set_add(System_Functions *system, Working_Set *working_set, Editing_File
|
||||||
working_set__grow_if_needed(&working_set->table, general, system, tbl_string_hash, tbl_file_compare);
|
working_set__grow_if_needed(&working_set->table, general, system, tbl_string_hash, tbl_file_compare);
|
||||||
working_set__entry_comp(system, file->name.source_path, &entry_comp);
|
working_set__entry_comp(system, file->name.source_path, &entry_comp);
|
||||||
entry_comp.entry.id = file->id;
|
entry_comp.entry.id = file->id;
|
||||||
table_add(&working_set->table, &entry_comp, system, tbl_string_hash, tbl_file_compare);
|
if (table_add(&working_set->table, &entry_comp, system, tbl_string_hash, tbl_file_compare)){
|
||||||
|
if (!uhash_equal(entry_comp.hash, uhash_zero())){
|
||||||
|
system->file_track(file->name.source_path);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
|
@ -437,6 +441,9 @@ working_set_remove(System_Functions *system, Working_Set *working_set, String fi
|
||||||
File_Entry_Comparison entry_comp;
|
File_Entry_Comparison entry_comp;
|
||||||
working_set__entry_comp(system, filename, &entry_comp);
|
working_set__entry_comp(system, filename, &entry_comp);
|
||||||
table_remove_match(&working_set->table, &entry_comp, system, tbl_string_hash, tbl_file_compare);
|
table_remove_match(&working_set->table, &entry_comp, system, tbl_string_hash, tbl_file_compare);
|
||||||
|
if (!uhash_equal(entry_comp.hash, uhash_zero())){
|
||||||
|
system->file_untrack(filename);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(allen): Pick better first options.
|
// TODO(allen): Pick better first options.
|
||||||
|
@ -444,8 +451,6 @@ internal Editing_File*
|
||||||
working_set_lookup_file(Working_Set *working_set, String string){
|
working_set_lookup_file(Working_Set *working_set, String string){
|
||||||
Editing_File *file = 0;
|
Editing_File *file = 0;
|
||||||
|
|
||||||
replace_char(string, '\\', '/');
|
|
||||||
|
|
||||||
{
|
{
|
||||||
File_Node *node, *used_nodes;
|
File_Node *node, *used_nodes;
|
||||||
used_nodes = &working_set->used_sentinel;
|
used_nodes = &working_set->used_sentinel;
|
||||||
|
@ -562,8 +567,6 @@ internal b32
|
||||||
filename_match(String query, Absolutes *absolutes, String filename, b32 case_sensitive){
|
filename_match(String query, Absolutes *absolutes, String filename, b32 case_sensitive){
|
||||||
b32 result;
|
b32 result;
|
||||||
result = (query.size == 0);
|
result = (query.size == 0);
|
||||||
replace_char(query, '\\', '/');
|
|
||||||
replace_char(filename, '\\', '/');
|
|
||||||
if (!result) result = wildcard_match(absolutes, filename, case_sensitive);
|
if (!result) result = wildcard_match(absolutes, filename, case_sensitive);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -576,8 +579,6 @@ hot_directory_first_match(Hot_Directory *hot_directory,
|
||||||
b32 case_sensitive){
|
b32 case_sensitive){
|
||||||
Hot_Directory_Match result = {};
|
Hot_Directory_Match result = {};
|
||||||
|
|
||||||
replace_char(str, '\\', '/');
|
|
||||||
|
|
||||||
Absolutes absolutes;
|
Absolutes absolutes;
|
||||||
if (!exact_match)
|
if (!exact_match)
|
||||||
get_absolutes(str, &absolutes, 1, 1);
|
get_absolutes(str, &absolutes, 1, 1);
|
||||||
|
|
|
@ -382,7 +382,6 @@ file_grow_starts_widths_as_needed(General_Memory *general, Buffer_Type *buffer,
|
||||||
internal void
|
internal void
|
||||||
file_measure_starts_widths(System_Functions *system, General_Memory *general,
|
file_measure_starts_widths(System_Functions *system, General_Memory *general,
|
||||||
Buffer_Type *buffer, float *advance_data){
|
Buffer_Type *buffer, float *advance_data){
|
||||||
ProfileMomentFunction();
|
|
||||||
if (!buffer->line_starts){
|
if (!buffer->line_starts){
|
||||||
i32 max = buffer->line_max = Kbytes(1);
|
i32 max = buffer->line_max = Kbytes(1);
|
||||||
buffer->line_starts = (i32*)general_memory_allocate(general, max*sizeof(i32), BUBBLE_STARTS);
|
buffer->line_starts = (i32*)general_memory_allocate(general, max*sizeof(i32), BUBBLE_STARTS);
|
||||||
|
@ -441,17 +440,6 @@ get_opaque_font_advance(Render_Font *font){
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
|
||||||
internal void
|
|
||||||
file_remeasure_widths_(System_Functions *system,
|
|
||||||
General_Memory *general, Buffer_Type *buffer, Render_Font *font,
|
|
||||||
i32 line_start, i32 line_end, i32 line_shift){
|
|
||||||
ProfileMomentFunction();
|
|
||||||
file_grow_starts_widths_as_needed(general, buffer, line_shift);
|
|
||||||
buffer_remeasure_widths(buffer, font->advance_data, line_start, line_end, line_shift);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
inline i32
|
inline i32
|
||||||
view_wrapped_line_span(f32 line_width, f32 max_width){
|
view_wrapped_line_span(f32 line_width, f32 max_width){
|
||||||
i32 line_count = CEIL32(line_width / max_width);
|
i32 line_count = CEIL32(line_width / max_width);
|
||||||
|
@ -485,7 +473,6 @@ view_compute_lowest_line(View *view){
|
||||||
internal void
|
internal void
|
||||||
view_measure_wraps(System_Functions *system,
|
view_measure_wraps(System_Functions *system,
|
||||||
General_Memory *general, View *view){
|
General_Memory *general, View *view){
|
||||||
ProfileMomentFunction();
|
|
||||||
Buffer_Type *buffer;
|
Buffer_Type *buffer;
|
||||||
|
|
||||||
buffer = &view->file->state.buffer;
|
buffer = &view->file->state.buffer;
|
||||||
|
@ -1655,7 +1642,6 @@ internal void
|
||||||
file_do_single_edit(System_Functions *system,
|
file_do_single_edit(System_Functions *system,
|
||||||
Models *models, Editing_File *file,
|
Models *models, Editing_File *file,
|
||||||
Edit_Spec spec, History_Mode history_mode, b32 use_high_permission = 0){
|
Edit_Spec spec, History_Mode history_mode, b32 use_high_permission = 0){
|
||||||
ProfileMomentFunction();
|
|
||||||
if (!use_high_permission && file->settings.read_only) return;
|
if (!use_high_permission && file->settings.read_only) return;
|
||||||
|
|
||||||
Mem_Options *mem = &models->mem;
|
Mem_Options *mem = &models->mem;
|
||||||
|
@ -1731,7 +1717,6 @@ file_do_single_edit(System_Functions *system,
|
||||||
internal void
|
internal void
|
||||||
file_do_white_batch_edit(System_Functions *system, Models *models, Editing_File *file,
|
file_do_white_batch_edit(System_Functions *system, Models *models, Editing_File *file,
|
||||||
Edit_Spec spec, History_Mode history_mode, b32 use_high_permission = 0){
|
Edit_Spec spec, History_Mode history_mode, b32 use_high_permission = 0){
|
||||||
ProfileMomentFunction();
|
|
||||||
if (!use_high_permission && file->settings.read_only) return;
|
if (!use_high_permission && file->settings.read_only) return;
|
||||||
|
|
||||||
Mem_Options *mem = &models->mem;
|
Mem_Options *mem = &models->mem;
|
||||||
|
@ -5540,7 +5525,7 @@ search_hit_add(General_Memory *general, Table *hits, String_Space *space, char *
|
||||||
*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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,37 +10,6 @@
|
||||||
// TOP
|
// TOP
|
||||||
|
|
||||||
#if FRED_INTERNAL == 1
|
#if FRED_INTERNAL == 1
|
||||||
#define ProfileStart_(name, start, counter, hit, thread, n, c)
|
|
||||||
|
|
||||||
#define ProfileEnd_(name, start, counter, hit, thread)
|
|
||||||
|
|
||||||
#define ProfileMoment_(name, counter, thread)
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
|
|
||||||
#define ProfileStart(name) char *_pname_##name; i64 _pstart_##name; \
|
|
||||||
i32 _pcounter_##name; u32 _phit_##name; \
|
|
||||||
ProfileStart_(_pname_##name, _pstart_##name, _pcounter_##name, \
|
|
||||||
_phit_##name, system->thread_get_id(thread), \
|
|
||||||
#name, __COUNTER__)
|
|
||||||
|
|
||||||
#define ProfileEnd(name) ProfileEnd_(_pname_##name, _pstart_##name, \
|
|
||||||
_pcounter_##name, _phit_##name, \
|
|
||||||
system->thread_get_id(thread))
|
|
||||||
|
|
||||||
#define ProfileMoment(name, thread) ProfileMoment_(#name, __COUNTER__, thread)
|
|
||||||
#define ProfileMomentFunction() ProfileMoment_(__FUNCTION__, __COUNTER__, 0)
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#define ProfileStart(name)
|
|
||||||
#define ProfileEnd(name)
|
|
||||||
#define ProfileMoment(name)
|
|
||||||
#define ProfileMomentFunction()
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
struct Sys_Bubble : public Bubble{
|
struct Sys_Bubble : public Bubble{
|
||||||
i32 line_number;
|
i32 line_number;
|
||||||
|
@ -49,11 +18,6 @@ struct Sys_Bubble : public Bubble{
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#define ProfileStart(name)
|
|
||||||
#define ProfileEnd(name)
|
|
||||||
#define ProfileMoment(name)
|
|
||||||
#define ProfileMomentFunction()
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// BOTTOM
|
// BOTTOM
|
||||||
|
|
18
4ed_system.h
18
4ed_system.h
|
@ -45,6 +45,13 @@ typedef Sys_Set_File_List_Sig(System_Set_File_List);
|
||||||
#define Sys_File_Unique_Hash_Sig(name) Unique_Hash name(String filename, b32 *success)
|
#define Sys_File_Unique_Hash_Sig(name) Unique_Hash name(String filename, b32 *success)
|
||||||
typedef Sys_File_Unique_Hash_Sig(System_File_Unique_Hash);
|
typedef Sys_File_Unique_Hash_Sig(System_File_Unique_Hash);
|
||||||
|
|
||||||
|
#define Sys_File_Track_Sig(name) void name(String filename)
|
||||||
|
typedef Sys_File_Track_Sig(System_File_Track);
|
||||||
|
|
||||||
|
#define Sys_File_Untrack_Sig(name) void name(String filename)
|
||||||
|
typedef Sys_File_Untrack_Sig(System_File_Untrack);
|
||||||
|
|
||||||
|
|
||||||
#define Sys_Post_Clipboard_Sig(name) void name(String str)
|
#define Sys_Post_Clipboard_Sig(name) void name(String str)
|
||||||
typedef Sys_Post_Clipboard_Sig(System_Post_Clipboard);
|
typedef Sys_Post_Clipboard_Sig(System_Post_Clipboard);
|
||||||
|
|
||||||
|
@ -193,10 +200,12 @@ typedef INTERNAL_Sys_Get_Thread_States_Sig(INTERNAL_System_Get_Thread_States);
|
||||||
typedef INTERNAL_Sys_Debug_Message_Sig(INTERNAL_System_Debug_Message);
|
typedef INTERNAL_Sys_Debug_Message_Sig(INTERNAL_System_Debug_Message);
|
||||||
|
|
||||||
struct System_Functions{
|
struct System_Functions{
|
||||||
// files: 3
|
// files: 4
|
||||||
System_File_Time_Stamp *file_time_stamp;
|
System_File_Time_Stamp *file_time_stamp;
|
||||||
System_Set_File_List *set_file_list;
|
System_Set_File_List *set_file_list;
|
||||||
System_File_Unique_Hash *file_unique_hash;
|
System_File_Unique_Hash *file_unique_hash;
|
||||||
|
System_File_Track *file_track;
|
||||||
|
System_File_Untrack *file_untrack;
|
||||||
|
|
||||||
// file system navigation (4coder_custom.h): 2
|
// file system navigation (4coder_custom.h): 2
|
||||||
File_Exists_Function *file_exists;
|
File_Exists_Function *file_exists;
|
||||||
|
@ -262,9 +271,16 @@ struct File_Exchange{
|
||||||
i32 num_active, max;
|
i32 num_active, max;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct Write_Event{
|
||||||
|
Write_Event *next, *prev;
|
||||||
|
String filename;
|
||||||
|
u64 time_stamp;
|
||||||
|
};
|
||||||
|
|
||||||
struct Exchange{
|
struct Exchange{
|
||||||
Thread_Exchange thread;
|
Thread_Exchange thread;
|
||||||
File_Exchange file;
|
File_Exchange file;
|
||||||
|
Write_Event write_event_sentinel;
|
||||||
};
|
};
|
||||||
|
|
||||||
// BOTTOM
|
// BOTTOM
|
||||||
|
|
|
@ -47,9 +47,12 @@
|
||||||
#define FPS 30
|
#define FPS 30
|
||||||
#define frame_useconds (1000000 / FPS)
|
#define frame_useconds (1000000 / FPS)
|
||||||
|
|
||||||
|
// TODO(allen): Do we still need all of these? I've abandoned the
|
||||||
|
// main thread / update loop thread thing for a while at least.
|
||||||
#define WM_4coder_LOAD_FONT (WM_USER + 1)
|
#define WM_4coder_LOAD_FONT (WM_USER + 1)
|
||||||
#define WM_4coder_PAINT (WM_USER + 2)
|
#define WM_4coder_PAINT (WM_USER + 2)
|
||||||
#define WM_4coder_SET_CURSOR (WM_USER + 3)
|
#define WM_4coder_SET_CURSOR (WM_USER + 3)
|
||||||
|
#define WM_4coder_ANIMATE (WM_USER + 4)
|
||||||
|
|
||||||
struct Thread_Context{
|
struct Thread_Context{
|
||||||
u32 job_id;
|
u32 job_id;
|
||||||
|
@ -84,8 +87,6 @@ struct Win32_Input_Chunk_Transient{
|
||||||
i8 mouse_wheel;
|
i8 mouse_wheel;
|
||||||
|
|
||||||
b8 trying_to_kill;
|
b8 trying_to_kill;
|
||||||
|
|
||||||
b8 redraw;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Win32_Input_Chunk_Persistent{
|
struct Win32_Input_Chunk_Persistent{
|
||||||
|
@ -159,10 +160,9 @@ struct Win32_Vars{
|
||||||
|
|
||||||
Font_Load_System fnt;
|
Font_Load_System fnt;
|
||||||
|
|
||||||
// NOTE(allen): I don't expect to have many of these, but it pays
|
// NOTE(allen): Going to do an experiment that
|
||||||
// to look a head a little so this is set up so that we can just bump
|
// will involve more coroutines.
|
||||||
// it up if needed.
|
Win32_Coroutine coroutine_data[18];
|
||||||
Win32_Coroutine coroutine_data[2];
|
|
||||||
Win32_Coroutine *coroutine_free;
|
Win32_Coroutine *coroutine_free;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -463,6 +463,14 @@ Sys_Set_File_List_Sig(system_set_file_list){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal
|
||||||
|
Sys_File_Track_Sig(system_file_track){
|
||||||
|
}
|
||||||
|
|
||||||
|
internal
|
||||||
|
Sys_File_Untrack_Sig(system_file_untrack){
|
||||||
|
}
|
||||||
|
|
||||||
internal
|
internal
|
||||||
Sys_File_Unique_Hash_Sig(system_file_unique_hash){
|
Sys_File_Unique_Hash_Sig(system_file_unique_hash){
|
||||||
Unique_Hash hash = {0};
|
Unique_Hash hash = {0};
|
||||||
|
@ -1088,6 +1096,8 @@ Win32LoadSystemCode(){
|
||||||
win32vars.system->file_time_stamp = system_file_time_stamp;
|
win32vars.system->file_time_stamp = system_file_time_stamp;
|
||||||
win32vars.system->file_unique_hash = system_file_unique_hash;
|
win32vars.system->file_unique_hash = system_file_unique_hash;
|
||||||
win32vars.system->set_file_list = system_set_file_list;
|
win32vars.system->set_file_list = system_set_file_list;
|
||||||
|
win32vars.system->file_track = system_file_track;
|
||||||
|
win32vars.system->file_untrack = system_file_untrack;
|
||||||
|
|
||||||
win32vars.system->file_exists = system_file_exists;
|
win32vars.system->file_exists = system_file_exists;
|
||||||
win32vars.system->directory_cd = system_directory_cd;
|
win32vars.system->directory_cd = system_directory_cd;
|
||||||
|
@ -1391,7 +1401,6 @@ Win32Callback(HWND hwnd, UINT uMsg,
|
||||||
i32 new_height = HIWORD(lParam);
|
i32 new_height = HIWORD(lParam);
|
||||||
|
|
||||||
Win32Resize(new_width, new_height);
|
Win32Resize(new_width, new_height);
|
||||||
win32vars.input_chunk.trans.redraw = 1;
|
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
|
@ -1474,11 +1483,8 @@ Win32Callback(HWND hwnd, UINT uMsg,
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
DWORD
|
internal void
|
||||||
UpdateLoop(LPVOID param){
|
UpdateStep(){
|
||||||
ConvertThreadToFiber(0);
|
|
||||||
|
|
||||||
for (;win32vars.input_chunk.pers.keep_playing;){
|
|
||||||
i64 timer_start = system_time();
|
i64 timer_start = system_time();
|
||||||
|
|
||||||
system_acquire_lock(INPUT_LOCK);
|
system_acquire_lock(INPUT_LOCK);
|
||||||
|
@ -1524,10 +1530,6 @@ UpdateLoop(LPVOID param){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 redraw = exchange_vars.thread.force_redraw;
|
|
||||||
if (redraw) exchange_vars.thread.force_redraw = 0;
|
|
||||||
redraw = redraw || input_chunk.trans.redraw;
|
|
||||||
|
|
||||||
Key_Input_Data input_data;
|
Key_Input_Data input_data;
|
||||||
Mouse_State mouse;
|
Mouse_State mouse;
|
||||||
Application_Step_Result result;
|
Application_Step_Result result;
|
||||||
|
@ -1549,11 +1551,13 @@ UpdateLoop(LPVOID param){
|
||||||
mouse.y = input_chunk.pers.mouse_y;
|
mouse.y = input_chunk.pers.mouse_y;
|
||||||
|
|
||||||
result.mouse_cursor_type = APP_MOUSE_CURSOR_DEFAULT;
|
result.mouse_cursor_type = APP_MOUSE_CURSOR_DEFAULT;
|
||||||
result.redraw = redraw;
|
|
||||||
result.lctrl_lalt_is_altgr = win32vars.lctrl_lalt_is_altgr;
|
result.lctrl_lalt_is_altgr = win32vars.lctrl_lalt_is_altgr;
|
||||||
result.trying_to_kill = input_chunk.trans.trying_to_kill;
|
result.trying_to_kill = input_chunk.trans.trying_to_kill;
|
||||||
result.perform_kill = 0;
|
result.perform_kill = 0;
|
||||||
|
|
||||||
|
// NOTE(allen): The expected dt given the frame limit in seconds.
|
||||||
|
f32 dt = frame_useconds / 1000000.f;
|
||||||
|
|
||||||
win32vars.app.step(win32vars.system,
|
win32vars.app.step(win32vars.system,
|
||||||
&input_data,
|
&input_data,
|
||||||
&mouse,
|
&mouse,
|
||||||
|
@ -1561,25 +1565,20 @@ UpdateLoop(LPVOID param){
|
||||||
&memory_vars,
|
&memory_vars,
|
||||||
&exchange_vars,
|
&exchange_vars,
|
||||||
win32vars.clipboard_contents,
|
win32vars.clipboard_contents,
|
||||||
1, win32vars.first, redraw,
|
dt, win32vars.first,
|
||||||
&result);
|
&result);
|
||||||
|
|
||||||
if (result.perform_kill){
|
if (result.perform_kill){
|
||||||
win32vars.input_chunk.pers.keep_playing = 0;
|
win32vars.input_chunk.pers.keep_playing = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
ProfileStart(OS_frame_out);
|
|
||||||
|
|
||||||
Win32SetCursorFromUpdate(result.mouse_cursor_type);
|
Win32SetCursorFromUpdate(result.mouse_cursor_type);
|
||||||
win32vars.lctrl_lalt_is_altgr = result.lctrl_lalt_is_altgr;
|
win32vars.lctrl_lalt_is_altgr = result.lctrl_lalt_is_altgr;
|
||||||
|
|
||||||
if (result.redraw) Win32RedrawFromUpdate();
|
Win32RedrawFromUpdate();
|
||||||
|
|
||||||
win32vars.first = 0;
|
win32vars.first = 0;
|
||||||
|
|
||||||
ProfileEnd(OS_frame_out);
|
|
||||||
|
|
||||||
ProfileStart(OS_file_process);
|
|
||||||
{
|
{
|
||||||
File_Slot *file;
|
File_Slot *file;
|
||||||
int d = 0;
|
int d = 0;
|
||||||
|
@ -1636,9 +1635,7 @@ UpdateLoop(LPVOID param){
|
||||||
|
|
||||||
ex__check(&exchange_vars.file);
|
ex__check(&exchange_vars.file);
|
||||||
}
|
}
|
||||||
ProfileEnd(OS_file_process);
|
|
||||||
|
|
||||||
ProfileStart(frame_sleep);
|
|
||||||
i64 timer_end = system_time();
|
i64 timer_end = system_time();
|
||||||
i64 end_target = (timer_start + frame_useconds);
|
i64 end_target = (timer_start + frame_useconds);
|
||||||
|
|
||||||
|
@ -1650,9 +1647,16 @@ UpdateLoop(LPVOID param){
|
||||||
}
|
}
|
||||||
system_acquire_lock(FRAME_LOCK);
|
system_acquire_lock(FRAME_LOCK);
|
||||||
timer_start = system_time();
|
timer_start = system_time();
|
||||||
ProfileEnd(frame_sleep);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
PostMessage(NULL, WM_4coder_ANIMATE, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
DWORD
|
||||||
|
UpdateLoop(LPVOID param){
|
||||||
|
ConvertThreadToFiber(0);
|
||||||
|
for (;win32vars.input_chunk.pers.keep_playing;){
|
||||||
|
UpdateStep();
|
||||||
|
}
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1667,9 +1671,9 @@ WinMain(HINSTANCE hInstance,
|
||||||
LPSTR lpCmdLine,
|
LPSTR lpCmdLine,
|
||||||
int nCmdShow){
|
int nCmdShow){
|
||||||
#else
|
#else
|
||||||
int
|
int main(int argc, char **argv){
|
||||||
main(int argc, char **argv){
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
HINSTANCE hInstance = GetModuleHandle(0);
|
HINSTANCE hInstance = GetModuleHandle(0);
|
||||||
HANDLE original_out = GetStdHandle(STD_OUTPUT_HANDLE);
|
HANDLE original_out = GetStdHandle(STD_OUTPUT_HANDLE);
|
||||||
|
|
||||||
|
@ -2005,6 +2009,7 @@ WinMain(HINSTANCE hInstance,
|
||||||
win32vars.first = 1;
|
win32vars.first = 1;
|
||||||
timeBeginPeriod(1);
|
timeBeginPeriod(1);
|
||||||
|
|
||||||
|
#if 0
|
||||||
win32vars.update_loop_thread =
|
win32vars.update_loop_thread =
|
||||||
CreateThread(0,
|
CreateThread(0,
|
||||||
0,
|
0,
|
||||||
|
@ -2012,6 +2017,7 @@ WinMain(HINSTANCE hInstance,
|
||||||
0,
|
0,
|
||||||
CREATE_SUSPENDED,
|
CREATE_SUSPENDED,
|
||||||
&win32vars.update_loop_thread_id);
|
&win32vars.update_loop_thread_id);
|
||||||
|
#endif
|
||||||
|
|
||||||
system_acquire_lock(FRAME_LOCK);
|
system_acquire_lock(FRAME_LOCK);
|
||||||
|
|
||||||
|
@ -2021,15 +2027,30 @@ WinMain(HINSTANCE hInstance,
|
||||||
ResumeThread(win32vars.update_loop_thread);
|
ResumeThread(win32vars.update_loop_thread);
|
||||||
|
|
||||||
MSG msg;
|
MSG msg;
|
||||||
for (;win32vars.input_chunk.pers.keep_playing && GetMessage(&msg, 0, 0, 0);){
|
for (;win32vars.input_chunk.pers.keep_playing;){
|
||||||
|
if (GetMessage(&msg, 0, 0, 0)){
|
||||||
if (msg.message == WM_QUIT){
|
if (msg.message == WM_QUIT){
|
||||||
system_acquire_lock(INPUT_LOCK);
|
//system_acquire_lock(INPUT_LOCK);
|
||||||
win32vars.input_chunk.pers.keep_playing = 0;
|
win32vars.input_chunk.pers.keep_playing = 0;
|
||||||
system_release_lock(INPUT_LOCK);
|
//system_release_lock(INPUT_LOCK);
|
||||||
}else{
|
}else{
|
||||||
TranslateMessage(&msg);
|
TranslateMessage(&msg);
|
||||||
DispatchMessage(&msg);
|
DispatchMessage(&msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
while (PeekMessage(&msg, 0, 0, 0, 1)){
|
||||||
|
if (msg.message == WM_QUIT){
|
||||||
|
//system_acquire_lock(INPUT_LOCK);
|
||||||
|
win32vars.input_chunk.pers.keep_playing = 0;
|
||||||
|
//system_release_lock(INPUT_LOCK);
|
||||||
|
}else{
|
||||||
|
TranslateMessage(&msg);
|
||||||
|
DispatchMessage(&msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
UpdateStep();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in New Issue