eliminated do_view callback
parent
451a5b983e
commit
1b16bf2c11
|
@ -12,50 +12,6 @@
|
||||||
#ifndef FRED_BUFFER_TYPES_H
|
#ifndef FRED_BUFFER_TYPES_H
|
||||||
#define FRED_BUFFER_TYPES_H
|
#define FRED_BUFFER_TYPES_H
|
||||||
|
|
||||||
#ifndef FRED_STRING_STRUCT
|
|
||||||
#define FRED_STRING_STRUCT
|
|
||||||
typedef struct String{
|
|
||||||
char *str;
|
|
||||||
int size;
|
|
||||||
int memory_size;
|
|
||||||
} String;
|
|
||||||
|
|
||||||
typedef struct Offset_String{
|
|
||||||
int offset;
|
|
||||||
int size;
|
|
||||||
} Offset_String;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
typedef unsigned char Code;
|
|
||||||
|
|
||||||
typedef enum{
|
|
||||||
MDFR_SHIFT_INDEX,
|
|
||||||
MDFR_CONTROL_INDEX,
|
|
||||||
MDFR_ALT_INDEX,
|
|
||||||
MDFR_CAPS_INDEX,
|
|
||||||
// always last
|
|
||||||
MDFR_INDEX_COUNT
|
|
||||||
} Key_Control;
|
|
||||||
|
|
||||||
typedef struct Key_Event_Data{
|
|
||||||
Code keycode;
|
|
||||||
Code character;
|
|
||||||
Code character_no_caps_lock;
|
|
||||||
|
|
||||||
char modifiers[MDFR_INDEX_COUNT];
|
|
||||||
} Key_Event_Data;
|
|
||||||
|
|
||||||
typedef struct Mouse_State{
|
|
||||||
char l, r;
|
|
||||||
char press_l, press_r;
|
|
||||||
char release_l, release_r;
|
|
||||||
char wheel;
|
|
||||||
char out_of_window;
|
|
||||||
int x, y;
|
|
||||||
} Mouse_State;
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct Full_Cursor{
|
typedef struct Full_Cursor{
|
||||||
int pos;
|
int pos;
|
||||||
int line, character;
|
int line, character;
|
||||||
|
@ -126,114 +82,6 @@ seek_line_char(int line, int character){
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef union Range{
|
|
||||||
struct{
|
|
||||||
int min, max;
|
|
||||||
};
|
|
||||||
struct{
|
|
||||||
int start, end;
|
|
||||||
};
|
|
||||||
} Range;
|
|
||||||
|
|
||||||
inline Range
|
|
||||||
make_range(int p1, int p2){
|
|
||||||
Range range;
|
|
||||||
if (p1 < p2){
|
|
||||||
range.min = p1;
|
|
||||||
range.max = p2;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
range.min = p2;
|
|
||||||
range.max = p1;
|
|
||||||
}
|
|
||||||
return(range);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
typedef enum Dynamic_Type{
|
|
||||||
dynamic_type_int,
|
|
||||||
dynamic_type_string,
|
|
||||||
// never below this
|
|
||||||
dynamic_type_count
|
|
||||||
} Dynamic_Type;
|
|
||||||
|
|
||||||
typedef struct Dynamic{
|
|
||||||
int type;
|
|
||||||
union{
|
|
||||||
struct{
|
|
||||||
int str_len;
|
|
||||||
char *str_value;
|
|
||||||
};
|
|
||||||
int int_value;
|
|
||||||
};
|
|
||||||
} Dynamic;
|
|
||||||
|
|
||||||
inline Dynamic
|
|
||||||
dynamic_int(int x){
|
|
||||||
Dynamic result;
|
|
||||||
result.type = dynamic_type_int;
|
|
||||||
result.int_value = x;
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline Dynamic
|
|
||||||
dynamic_string(const char *string, int len){
|
|
||||||
Dynamic result;
|
|
||||||
result.type = dynamic_type_string;
|
|
||||||
result.str_len = len;
|
|
||||||
result.str_value = (char*)(string);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int
|
|
||||||
dynamic_to_int(Dynamic *dynamic){
|
|
||||||
int result = 0;
|
|
||||||
if (dynamic->type == dynamic_type_int){
|
|
||||||
result = dynamic->int_value;
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline char*
|
|
||||||
dynamic_to_string(Dynamic *dynamic, int *len){
|
|
||||||
char *result = 0;
|
|
||||||
if (dynamic->type == dynamic_type_string){
|
|
||||||
result = dynamic->str_value;
|
|
||||||
*len = dynamic->str_len;
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int
|
|
||||||
dynamic_to_bool(Dynamic *dynamic){
|
|
||||||
int result = 0;
|
|
||||||
if (dynamic->type == dynamic_type_int){
|
|
||||||
result = (dynamic->int_value != 0);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
result = 1;
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct File_Info{
|
|
||||||
String filename;
|
|
||||||
int folder;
|
|
||||||
} File_Info;
|
|
||||||
|
|
||||||
typedef struct File_List{
|
|
||||||
// Ignore this, it's for internal stuff.
|
|
||||||
void *block;
|
|
||||||
|
|
||||||
// The list of files and folders.
|
|
||||||
File_Info *infos;
|
|
||||||
int count;
|
|
||||||
|
|
||||||
// Ignore this, it's for internal stuff.
|
|
||||||
int block_size;
|
|
||||||
} File_List;
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -564,6 +564,26 @@ CUSTOM_COMMAND_SIG(query_replace){
|
||||||
app->view_set_cursor(app, &view, seek_pos(pos), 1);
|
app->view_set_cursor(app, &view, seek_pos(pos), 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CUSTOM_COMMAND_SIG(close_all_code){
|
||||||
|
String extension;
|
||||||
|
Buffer_Summary buffer;
|
||||||
|
int max, i;
|
||||||
|
|
||||||
|
max = app->get_buffer_max_index(app);
|
||||||
|
for (i = 0; i < max; ++i){
|
||||||
|
buffer = app->get_buffer(app, i);
|
||||||
|
extension = file_extension(make_string(buffer.file_name, buffer.file_name_len));
|
||||||
|
if (match(extension, make_lit_string("cpp")) ||
|
||||||
|
match(extension, make_lit_string("hpp")) ||
|
||||||
|
match(extension, make_lit_string("c")) ||
|
||||||
|
match(extension, make_lit_string("h"))){
|
||||||
|
//
|
||||||
|
push_parameter(app, par_buffer_id, buffer.buffer_id);
|
||||||
|
exec_command(app, cmdid_kill_buffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CUSTOM_COMMAND_SIG(open_all_code){
|
CUSTOM_COMMAND_SIG(open_all_code){
|
||||||
// NOTE(allen|a3.4.4): This method of getting the hot directory works
|
// NOTE(allen|a3.4.4): This method of getting the hot directory works
|
||||||
// because this custom.cpp gives no special meaning to app->memory
|
// because this custom.cpp gives no special meaning to app->memory
|
||||||
|
@ -603,6 +623,29 @@ CUSTOM_COMMAND_SIG(open_all_code){
|
||||||
app->free_file_list(app, list);
|
app->free_file_list(app, list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CUSTOM_COMMAND_SIG(execute_any_cli){
|
||||||
|
Query_Bar bar_out, bar_cmd;
|
||||||
|
String hot_directory;
|
||||||
|
char space[1024], more_space[1024], even_more_space[1024];
|
||||||
|
|
||||||
|
bar_out.prompt = make_lit_string("Output Buffer: ");
|
||||||
|
bar_out.string = make_fixed_width_string(space);
|
||||||
|
if (!query_user_string(app, &bar_out)) return;
|
||||||
|
|
||||||
|
bar_cmd.prompt = make_lit_string("Command: ");
|
||||||
|
bar_cmd.string = make_fixed_width_string(more_space);
|
||||||
|
if (!query_user_string(app, &bar_cmd)) return;
|
||||||
|
|
||||||
|
hot_directory = make_fixed_width_string(even_more_space);
|
||||||
|
hot_directory.size = app->directory_get_hot(app, hot_directory.str, hot_directory.memory_size);
|
||||||
|
|
||||||
|
push_parameter(app, par_cli_overlap_with_conflict, 1);
|
||||||
|
push_parameter(app, par_name, bar_out.string.str, bar_out.string.size);
|
||||||
|
push_parameter(app, par_cli_path, hot_directory.str, hot_directory.size);
|
||||||
|
push_parameter(app, par_cli_command, bar_cmd.string.str, bar_cmd.string.size);
|
||||||
|
exec_command(app, cmdid_command_line);
|
||||||
|
}
|
||||||
|
|
||||||
CUSTOM_COMMAND_SIG(execute_arbitrary_command){
|
CUSTOM_COMMAND_SIG(execute_arbitrary_command){
|
||||||
// NOTE(allen): This isn't a super powerful version of this command, I will expand
|
// NOTE(allen): This isn't a super powerful version of this command, I will expand
|
||||||
// upon it so that it has all the cmdid_* commands by default. However, with this
|
// upon it so that it has all the cmdid_* commands by default. However, with this
|
||||||
|
@ -624,6 +667,9 @@ CUSTOM_COMMAND_SIG(execute_arbitrary_command){
|
||||||
if (match(bar.string, make_lit_string("open all code"))){
|
if (match(bar.string, make_lit_string("open all code"))){
|
||||||
exec_command(app, open_all_code);
|
exec_command(app, open_all_code);
|
||||||
}
|
}
|
||||||
|
else if(match(bar.string, make_lit_string("close all code"))){
|
||||||
|
exec_command(app, close_all_code);
|
||||||
|
}
|
||||||
else if (match(bar.string, make_lit_string("open in quotes"))){
|
else if (match(bar.string, make_lit_string("open in quotes"))){
|
||||||
exec_command(app, open_file_in_quotes);
|
exec_command(app, open_file_in_quotes);
|
||||||
}
|
}
|
||||||
|
@ -840,6 +886,7 @@ extern "C" GET_BINDING_DATA(get_bindings){
|
||||||
|
|
||||||
bind(context, 'm', MDFR_ALT, build_search);
|
bind(context, 'm', MDFR_ALT, build_search);
|
||||||
bind(context, 'x', MDFR_ALT, execute_arbitrary_command);
|
bind(context, 'x', MDFR_ALT, execute_arbitrary_command);
|
||||||
|
bind(context, 'z', MDFR_ALT, execute_any_cli);
|
||||||
|
|
||||||
// NOTE(allen): These callbacks may not actually be useful to you, but
|
// NOTE(allen): These callbacks may not actually be useful to you, but
|
||||||
// go look at them and see what they do.
|
// go look at them and see what they do.
|
||||||
|
|
204
4coder_custom.h
204
4coder_custom.h
|
@ -2,6 +2,156 @@
|
||||||
#include "4coder_keycodes.h"
|
#include "4coder_keycodes.h"
|
||||||
#include "4coder_buffer_types.h"
|
#include "4coder_buffer_types.h"
|
||||||
|
|
||||||
|
#ifndef FRED_STRING_STRUCT
|
||||||
|
#define FRED_STRING_STRUCT
|
||||||
|
typedef struct String{
|
||||||
|
char *str;
|
||||||
|
int size;
|
||||||
|
int memory_size;
|
||||||
|
} String;
|
||||||
|
|
||||||
|
typedef struct Offset_String{
|
||||||
|
int offset;
|
||||||
|
int size;
|
||||||
|
} Offset_String;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef unsigned char Code;
|
||||||
|
|
||||||
|
typedef enum{
|
||||||
|
MDFR_SHIFT_INDEX,
|
||||||
|
MDFR_CONTROL_INDEX,
|
||||||
|
MDFR_ALT_INDEX,
|
||||||
|
MDFR_CAPS_INDEX,
|
||||||
|
// always last
|
||||||
|
MDFR_INDEX_COUNT
|
||||||
|
} Key_Control;
|
||||||
|
|
||||||
|
typedef struct Key_Event_Data{
|
||||||
|
Code keycode;
|
||||||
|
Code character;
|
||||||
|
Code character_no_caps_lock;
|
||||||
|
|
||||||
|
char modifiers[MDFR_INDEX_COUNT];
|
||||||
|
} Key_Event_Data;
|
||||||
|
|
||||||
|
typedef struct Mouse_State{
|
||||||
|
char l, r;
|
||||||
|
char press_l, press_r;
|
||||||
|
char release_l, release_r;
|
||||||
|
char wheel;
|
||||||
|
char out_of_window;
|
||||||
|
int x, y;
|
||||||
|
} Mouse_State;
|
||||||
|
|
||||||
|
|
||||||
|
typedef union Range{
|
||||||
|
struct{
|
||||||
|
int min, max;
|
||||||
|
};
|
||||||
|
struct{
|
||||||
|
int start, end;
|
||||||
|
};
|
||||||
|
} Range;
|
||||||
|
|
||||||
|
inline Range
|
||||||
|
make_range(int p1, int p2){
|
||||||
|
Range range;
|
||||||
|
if (p1 < p2){
|
||||||
|
range.min = p1;
|
||||||
|
range.max = p2;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
range.min = p2;
|
||||||
|
range.max = p1;
|
||||||
|
}
|
||||||
|
return(range);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
typedef enum Dynamic_Type{
|
||||||
|
dynamic_type_int,
|
||||||
|
dynamic_type_string,
|
||||||
|
// never below this
|
||||||
|
dynamic_type_count
|
||||||
|
} Dynamic_Type;
|
||||||
|
|
||||||
|
typedef struct Dynamic{
|
||||||
|
int type;
|
||||||
|
union{
|
||||||
|
struct{
|
||||||
|
int str_len;
|
||||||
|
char *str_value;
|
||||||
|
};
|
||||||
|
int int_value;
|
||||||
|
};
|
||||||
|
} Dynamic;
|
||||||
|
|
||||||
|
inline Dynamic
|
||||||
|
dynamic_int(int x){
|
||||||
|
Dynamic result;
|
||||||
|
result.type = dynamic_type_int;
|
||||||
|
result.int_value = x;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline Dynamic
|
||||||
|
dynamic_string(const char *string, int len){
|
||||||
|
Dynamic result;
|
||||||
|
result.type = dynamic_type_string;
|
||||||
|
result.str_len = len;
|
||||||
|
result.str_value = (char*)(string);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline int
|
||||||
|
dynamic_to_int(Dynamic *dynamic){
|
||||||
|
int result = 0;
|
||||||
|
if (dynamic->type == dynamic_type_int){
|
||||||
|
result = dynamic->int_value;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline char*
|
||||||
|
dynamic_to_string(Dynamic *dynamic, int *len){
|
||||||
|
char *result = 0;
|
||||||
|
if (dynamic->type == dynamic_type_string){
|
||||||
|
result = dynamic->str_value;
|
||||||
|
*len = dynamic->str_len;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline int
|
||||||
|
dynamic_to_bool(Dynamic *dynamic){
|
||||||
|
int result = 0;
|
||||||
|
if (dynamic->type == dynamic_type_int){
|
||||||
|
result = (dynamic->int_value != 0);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
result = 1;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef struct File_Info{
|
||||||
|
String filename;
|
||||||
|
int folder;
|
||||||
|
} File_Info;
|
||||||
|
|
||||||
|
typedef struct File_List{
|
||||||
|
// Ignore this, it's for internal stuff.
|
||||||
|
void *block;
|
||||||
|
|
||||||
|
// The list of files and folders.
|
||||||
|
File_Info *infos;
|
||||||
|
int count;
|
||||||
|
|
||||||
|
// Ignore this, it's for internal stuff.
|
||||||
|
int block_size;
|
||||||
|
} File_List;
|
||||||
|
|
||||||
#define MDFR_NONE 0
|
#define MDFR_NONE 0
|
||||||
#define MDFR_CTRL 1
|
#define MDFR_CTRL 1
|
||||||
#define MDFR_ALT 2
|
#define MDFR_ALT 2
|
||||||
|
@ -169,41 +319,41 @@ extern "C"{
|
||||||
struct Application_Links;
|
struct Application_Links;
|
||||||
|
|
||||||
// Command exectuion
|
// Command exectuion
|
||||||
#define PUSH_PARAMETER_SIG(name) void name(Application_Links *context, Dynamic param, Dynamic value)
|
#define PUSH_PARAMETER_SIG(name) void name(Application_Links *app, Dynamic param, Dynamic value)
|
||||||
#define PUSH_MEMORY_SIG(name) char* name(Application_Links *context, int len)
|
#define PUSH_MEMORY_SIG(name) char* name(Application_Links *app, int len)
|
||||||
#define EXECUTE_COMMAND_SIG(name) void name(Application_Links *context, int command_id)
|
#define EXECUTE_COMMAND_SIG(name) void name(Application_Links *app, int command_id)
|
||||||
#define CLEAR_PARAMETERS_SIG(name) void name(Application_Links *context)
|
#define CLEAR_PARAMETERS_SIG(name) void name(Application_Links *app)
|
||||||
|
|
||||||
// File system navigation
|
// File system navigation
|
||||||
#define DIRECTORY_GET_HOT_SIG(name) int name(Application_Links *context, char *out, int capacity)
|
#define DIRECTORY_GET_HOT_SIG(name) int name(Application_Links *app, char *out, int capacity)
|
||||||
#define FILE_EXISTS_SIG(name) int name(Application_Links *context, char *filename, int len)
|
#define FILE_EXISTS_SIG(name) int name(Application_Links *app, char *filename, int len)
|
||||||
#define DIRECTORY_CD_SIG(name) int name(Application_Links *context, char *dir, int *len, int capacity, char *rel_path, int rel_len)
|
#define DIRECTORY_CD_SIG(name) int name(Application_Links *app, char *dir, int *len, int capacity, char *rel_path, int rel_len)
|
||||||
#define GET_FILE_LIST_SIG(name) File_List name(Application_Links *context, char *dir, int len)
|
#define GET_FILE_LIST_SIG(name) File_List name(Application_Links *app, char *dir, int len)
|
||||||
#define FREE_FILE_LIST_SIG(name) void name(Application_Links *context, File_List list)
|
#define FREE_FILE_LIST_SIG(name) void name(Application_Links *app, File_List list)
|
||||||
|
|
||||||
// Direct buffer manipulation
|
// Direct buffer manipulation
|
||||||
#define GET_BUFFER_MAX_INDEX_SIG(name) int name(Application_Links *context)
|
#define GET_BUFFER_MAX_INDEX_SIG(name) int name(Application_Links *app)
|
||||||
#define GET_BUFFER_SIG(name) Buffer_Summary name(Application_Links *context, int index)
|
#define GET_BUFFER_SIG(name) Buffer_Summary name(Application_Links *app, int index)
|
||||||
#define GET_ACTIVE_BUFFER_SIG(name) Buffer_Summary name(Application_Links *context)
|
#define GET_ACTIVE_BUFFER_SIG(name) Buffer_Summary name(Application_Links *app)
|
||||||
#define GET_BUFFER_BY_NAME(name) Buffer_Summary name(Application_Links *context, char *filename, int len)
|
#define GET_BUFFER_BY_NAME(name) Buffer_Summary name(Application_Links *app, char *filename, int len)
|
||||||
|
|
||||||
#define REFRESH_BUFFER_SIG(name) int name(Application_Links *context, Buffer_Summary *buffer)
|
#define REFRESH_BUFFER_SIG(name) int name(Application_Links *app, Buffer_Summary *buffer)
|
||||||
#define BUFFER_SEEK_DELIMITER_SIG(name) int name(Application_Links *context, Buffer_Summary *buffer, int start, char delim, int seek_forward, int *out)
|
#define BUFFER_SEEK_DELIMITER_SIG(name) int name(Application_Links *app, Buffer_Summary *buffer, int start, char delim, int seek_forward, int *out)
|
||||||
#define BUFFER_SEEK_STRING_SIG(name) int name(Application_Links *context, Buffer_Summary *buffer, int start, char *str, int len, int seek_forward, int *out)
|
#define BUFFER_SEEK_STRING_SIG(name) int name(Application_Links *app, Buffer_Summary *buffer, int start, char *str, int len, int seek_forward, int *out)
|
||||||
#define BUFFER_READ_RANGE_SIG(name) int name(Application_Links *context, Buffer_Summary *buffer, int start, int end, char *out)
|
#define BUFFER_READ_RANGE_SIG(name) int name(Application_Links *app, Buffer_Summary *buffer, int start, int end, char *out)
|
||||||
#define BUFFER_REPLACE_RANGE_SIG(name) int name(Application_Links *context, Buffer_Summary *buffer, int start, int end, char *str, int len)
|
#define BUFFER_REPLACE_RANGE_SIG(name) int name(Application_Links *app, Buffer_Summary *buffer, int start, int end, char *str, int len)
|
||||||
#define BUFFER_SET_POS_SIG(name) int name(Application_Links *context, Buffer_Summary *buffer, int pos)
|
#define BUFFER_SET_POS_SIG(name) int name(Application_Links *app, Buffer_Summary *buffer, int pos)
|
||||||
|
|
||||||
// File view manipulation
|
// File view manipulation
|
||||||
#define GET_VIEW_MAX_INDEX_SIG(name) int name(Application_Links *context)
|
#define GET_VIEW_MAX_INDEX_SIG(name) int name(Application_Links *app)
|
||||||
#define GET_VIEW_SIG(name) View_Summary name(Application_Links *context, int index)
|
#define GET_VIEW_SIG(name) View_Summary name(Application_Links *app, int index)
|
||||||
#define GET_ACTIVE_VIEW_SIG(name) View_Summary name(Application_Links *context)
|
#define GET_ACTIVE_VIEW_SIG(name) View_Summary name(Application_Links *app)
|
||||||
|
|
||||||
#define REFRESH_VIEW_SIG(name) int name(Application_Links *context, View_Summary *view)
|
#define REFRESH_VIEW_SIG(name) int name(Application_Links *app, View_Summary *view)
|
||||||
#define VIEW_SET_CURSOR_SIG(name) int name(Application_Links *context, View_Summary *view, Buffer_Seek seek, int set_preferred_x)
|
#define VIEW_SET_CURSOR_SIG(name) int name(Application_Links *app, View_Summary *view, Buffer_Seek seek, int set_preferred_x)
|
||||||
#define VIEW_SET_MARK_SIG(name) int name(Application_Links *context, View_Summary *view, Buffer_Seek seek)
|
#define VIEW_SET_MARK_SIG(name) int name(Application_Links *app, View_Summary *view, Buffer_Seek seek)
|
||||||
#define VIEW_SET_HIGHLIGHT_SIG(name) int name(Application_Links *context, View_Summary *view, int start, int end, int turn_on)
|
#define VIEW_SET_HIGHLIGHT_SIG(name) int name(Application_Links *app, View_Summary *view, int start, int end, int turn_on)
|
||||||
#define VIEW_SET_BUFFER_SIG(name) int name(Application_Links *context, View_Summary *view, int buffer_id)
|
#define VIEW_SET_BUFFER_SIG(name) int name(Application_Links *app, View_Summary *view, int buffer_id)
|
||||||
|
|
||||||
// Directly get user input
|
// Directly get user input
|
||||||
#define EventOnAnyKey 0x1
|
#define EventOnAnyKey 0x1
|
||||||
|
|
195
4ed.cpp
195
4ed.cpp
|
@ -1096,10 +1096,32 @@ COMMAND_DECL(interactive_kill_buffer){
|
||||||
COMMAND_DECL(kill_buffer){
|
COMMAND_DECL(kill_buffer){
|
||||||
ProfileMomentFunction();
|
ProfileMomentFunction();
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
USE_FILE(file, view);
|
||||||
USE_DELAY(delay);
|
USE_DELAY(delay);
|
||||||
|
USE_WORKING_SET(working_set);
|
||||||
|
|
||||||
|
int buffer_id = -1;
|
||||||
|
|
||||||
|
Command_Parameter *end = param_stack_end(&command->part);
|
||||||
|
Command_Parameter *param = param_stack_first(&command->part, end);
|
||||||
|
for (; param < end; param = param_next(param, end)){
|
||||||
|
int v = dynamic_to_int(¶m->param.param);
|
||||||
|
if (v == par_buffer_id && param->param.value.type == dynamic_type_int){
|
||||||
|
buffer_id = dynamic_to_int(¶m->param.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
delayed_try_kill(delay, file->name.live_name, view->panel);
|
if (buffer_id != -1){
|
||||||
|
if (buffer_id > 0 && buffer_id < working_set->file_max_count){
|
||||||
|
file = working_set->files + buffer_id;
|
||||||
|
if (!file->state.is_dummy){
|
||||||
|
delayed_kill(delay, file->name.source_path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (file){
|
||||||
|
delayed_try_kill(delay, file->name.live_name, view->panel);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(toggle_line_wrap){
|
COMMAND_DECL(toggle_line_wrap){
|
||||||
|
@ -1748,9 +1770,11 @@ build(System_Functions *system, Mem_Options *mem,
|
||||||
index = (i32)(file - vars->working_set.files);
|
index = (i32)(file - vars->working_set.files);
|
||||||
if (file){
|
if (file){
|
||||||
if (!(flags & CLI_AlwaysBindToView)){
|
if (!(flags & CLI_AlwaysBindToView)){
|
||||||
Panel *panel = layout->panels;
|
View *view;
|
||||||
for (i32 i = 0; i < layout->panel_count; ++i, ++panel){
|
Panel *panel, *used_panels;
|
||||||
View *view = panel->view;
|
used_panels = &layout->used_sentinel;
|
||||||
|
for (dll_items(panel, used_panels)){
|
||||||
|
view = panel->view;
|
||||||
if (view->file == file){
|
if (view->file == file){
|
||||||
bind_to_new_view = 0;
|
bind_to_new_view = 0;
|
||||||
break;
|
break;
|
||||||
|
@ -1881,18 +1905,20 @@ globalvar Command_Function command_table[cmdid_count];
|
||||||
internal void
|
internal void
|
||||||
fill_buffer_summary(Buffer_Summary *buffer, Editing_File *file, Working_Set *working_set){
|
fill_buffer_summary(Buffer_Summary *buffer, Editing_File *file, Working_Set *working_set){
|
||||||
buffer->exists = 1;
|
buffer->exists = 1;
|
||||||
buffer->ready = file_is_ready(file);
|
if (!file->state.is_dummy){
|
||||||
buffer->is_lexed = file->settings.tokens_exist;
|
buffer->ready = file_is_ready(file);
|
||||||
buffer->buffer_id = (int)(file - working_set->files);
|
buffer->is_lexed = file->settings.tokens_exist;
|
||||||
buffer->size = file->state.buffer.size;
|
buffer->buffer_id = (int)(file - working_set->files);
|
||||||
buffer->buffer_cursor_pos = file->state.cursor_pos;
|
buffer->size = file->state.buffer.size;
|
||||||
|
buffer->buffer_cursor_pos = file->state.cursor_pos;
|
||||||
buffer->file_name_len = file->name.source_path.size;
|
|
||||||
buffer->buffer_name_len = file->name.live_name.size;
|
buffer->file_name_len = file->name.source_path.size;
|
||||||
buffer->file_name = file->name.source_path.str;
|
buffer->buffer_name_len = file->name.live_name.size;
|
||||||
buffer->buffer_name = file->name.live_name.str;
|
buffer->file_name = file->name.source_path.str;
|
||||||
|
buffer->buffer_name = file->name.live_name.str;
|
||||||
buffer->map_id = file->settings.base_map_id;
|
|
||||||
|
buffer->map_id = file->settings.base_map_id;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
|
@ -1911,7 +1937,7 @@ fill_view_summary(View_Summary *view, View *file_view, Live_Views *live_set, Wor
|
||||||
|
|
||||||
extern "C"{
|
extern "C"{
|
||||||
EXECUTE_COMMAND_SIG(external_exec_command_keep_stack){
|
EXECUTE_COMMAND_SIG(external_exec_command_keep_stack){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Command_Function function = command_table[command_id];
|
Command_Function function = command_table[command_id];
|
||||||
Command_Binding binding;
|
Command_Binding binding;
|
||||||
binding.function = function;
|
binding.function = function;
|
||||||
|
@ -1921,7 +1947,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
PUSH_PARAMETER_SIG(external_push_parameter){
|
PUSH_PARAMETER_SIG(external_push_parameter){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Partition *part = &cmd->part;
|
Partition *part = &cmd->part;
|
||||||
Command_Parameter *cmd_param = push_struct(part, Command_Parameter);
|
Command_Parameter *cmd_param = push_struct(part, Command_Parameter);
|
||||||
cmd_param->type = 0;
|
cmd_param->type = 0;
|
||||||
|
@ -1930,7 +1956,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
PUSH_MEMORY_SIG(external_push_memory){
|
PUSH_MEMORY_SIG(external_push_memory){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Partition *part = &cmd->part;
|
Partition *part = &cmd->part;
|
||||||
Command_Parameter *base = push_struct(part, Command_Parameter);
|
Command_Parameter *base = push_struct(part, Command_Parameter);
|
||||||
char *result = push_array(part, char, len);
|
char *result = push_array(part, char, len);
|
||||||
|
@ -1944,12 +1970,12 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
CLEAR_PARAMETERS_SIG(external_clear_parameters){
|
CLEAR_PARAMETERS_SIG(external_clear_parameters){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
cmd->part.pos = 0;
|
cmd->part.pos = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
DIRECTORY_GET_HOT_SIG(external_directory_get_hot){
|
DIRECTORY_GET_HOT_SIG(external_directory_get_hot){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Hot_Directory *hot = &cmd->vars->hot_directory;
|
Hot_Directory *hot = &cmd->vars->hot_directory;
|
||||||
i32 copy_max = capacity - 1;
|
i32 copy_max = capacity - 1;
|
||||||
hot_directory_clean_end(hot);
|
hot_directory_clean_end(hot);
|
||||||
|
@ -1961,7 +1987,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_FILE_LIST_SIG(external_get_file_list){
|
GET_FILE_LIST_SIG(external_get_file_list){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
System_Functions *system = cmd->system;
|
System_Functions *system = cmd->system;
|
||||||
File_List result = {};
|
File_List result = {};
|
||||||
system->set_file_list(&result, make_string(dir, len));
|
system->set_file_list(&result, make_string(dir, len));
|
||||||
|
@ -1969,20 +1995,20 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
FREE_FILE_LIST_SIG(external_free_file_list){
|
FREE_FILE_LIST_SIG(external_free_file_list){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
System_Functions *system = cmd->system;
|
System_Functions *system = cmd->system;
|
||||||
system->set_file_list(&list, make_string(0, 0));
|
system->set_file_list(&list, make_string(0, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_BUFFER_MAX_INDEX_SIG(external_get_buffer_max_index){
|
GET_BUFFER_MAX_INDEX_SIG(external_get_buffer_max_index){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Working_Set *working_set = cmd->working_set;
|
Working_Set *working_set = cmd->working_set;
|
||||||
int max = working_set->file_index_count;
|
int max = working_set->file_index_count;
|
||||||
return(max);
|
return(max);
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_BUFFER_SIG(external_get_buffer){
|
GET_BUFFER_SIG(external_get_buffer){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
Working_Set *working_set = cmd->working_set;
|
Working_Set *working_set = cmd->working_set;
|
||||||
int max = working_set->file_index_count;
|
int max = working_set->file_index_count;
|
||||||
|
@ -1990,36 +2016,28 @@ extern "C"{
|
||||||
|
|
||||||
if (index >= 0 && index < max){
|
if (index >= 0 && index < max){
|
||||||
file = working_set->files + index;
|
file = working_set->files + index;
|
||||||
if (!file->state.is_dummy){
|
fill_buffer_summary(&buffer, file, working_set);
|
||||||
fill_buffer_summary(&buffer, file, working_set);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return(buffer);
|
return(buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_ACTIVE_BUFFER_SIG(external_get_active_buffer){
|
GET_ACTIVE_BUFFER_SIG(external_get_active_buffer){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
View *view;
|
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
Working_Set *working_set;
|
|
||||||
Buffer_Summary buffer = {};
|
Buffer_Summary buffer = {};
|
||||||
|
|
||||||
view = cmd->view;
|
file = cmd->view->file;
|
||||||
if (view){
|
|
||||||
file = view->file;
|
if (file && !file->state.is_dummy){
|
||||||
working_set = cmd->working_set;
|
fill_buffer_summary(&buffer, file, cmd->working_set);
|
||||||
|
|
||||||
if (file && !file->state.is_dummy){
|
|
||||||
fill_buffer_summary(&buffer, file, working_set);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return(buffer);
|
return(buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_BUFFER_BY_NAME(external_get_buffer_by_name){
|
GET_BUFFER_BY_NAME(external_get_buffer_by_name){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
Working_Set *working_set;
|
Working_Set *working_set;
|
||||||
i32 index;
|
i32 index;
|
||||||
|
@ -2038,13 +2056,13 @@ extern "C"{
|
||||||
|
|
||||||
REFRESH_BUFFER_SIG(external_refresh_buffer){
|
REFRESH_BUFFER_SIG(external_refresh_buffer){
|
||||||
int result;
|
int result;
|
||||||
*buffer = external_get_buffer(context, buffer->buffer_id);
|
*buffer = external_get_buffer(app, buffer->buffer_id);
|
||||||
result = buffer->exists;
|
result = buffer->exists;
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
BUFFER_SEEK_DELIMITER_SIG(external_buffer_seek_delimiter){
|
BUFFER_SEEK_DELIMITER_SIG(external_buffer_seek_delimiter){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
Working_Set *working_set;
|
Working_Set *working_set;
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
@ -2076,7 +2094,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
BUFFER_SEEK_STRING_SIG(external_buffer_seek_string){
|
BUFFER_SEEK_STRING_SIG(external_buffer_seek_string){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
Working_Set *working_set;
|
Working_Set *working_set;
|
||||||
Temp_Memory temp;
|
Temp_Memory temp;
|
||||||
|
@ -2114,7 +2132,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
BUFFER_READ_RANGE_SIG(external_buffer_read_range){
|
BUFFER_READ_RANGE_SIG(external_buffer_read_range){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
Working_Set *working_set;
|
Working_Set *working_set;
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
@ -2137,7 +2155,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
BUFFER_REPLACE_RANGE_SIG(external_buffer_replace_range){
|
BUFFER_REPLACE_RANGE_SIG(external_buffer_replace_range){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
Working_Set *working_set;
|
Working_Set *working_set;
|
||||||
|
|
||||||
|
@ -2177,7 +2195,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
BUFFER_SET_POS_SIG(external_buffer_set_pos){
|
BUFFER_SET_POS_SIG(external_buffer_set_pos){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
Working_Set *working_set;
|
Working_Set *working_set;
|
||||||
|
|
||||||
|
@ -2201,14 +2219,14 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_VIEW_MAX_INDEX_SIG(external_get_view_max_index){
|
GET_VIEW_MAX_INDEX_SIG(external_get_view_max_index){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Live_Views *live_set = cmd->live_set;
|
Live_Views *live_set = cmd->live_set;
|
||||||
int max = live_set->max;
|
int max = live_set->max;
|
||||||
return(max);
|
return(max);
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_VIEW_SIG(external_get_view){
|
GET_VIEW_SIG(external_get_view){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Live_Views *live_set = cmd->live_set;
|
Live_Views *live_set = cmd->live_set;
|
||||||
int max = live_set->max;
|
int max = live_set->max;
|
||||||
View *vptr;
|
View *vptr;
|
||||||
|
@ -2223,7 +2241,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
GET_ACTIVE_VIEW_SIG(external_get_active_view){
|
GET_ACTIVE_VIEW_SIG(external_get_active_view){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
View_Summary view = {};
|
View_Summary view = {};
|
||||||
View *vptr;
|
View *vptr;
|
||||||
|
|
||||||
|
@ -2235,13 +2253,13 @@ extern "C"{
|
||||||
|
|
||||||
REFRESH_VIEW_SIG(external_refresh_view){
|
REFRESH_VIEW_SIG(external_refresh_view){
|
||||||
int result;
|
int result;
|
||||||
*view = external_get_view(context, view->view_id);
|
*view = external_get_view(app, view->view_id);
|
||||||
result = view->exists;
|
result = view->exists;
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
VIEW_SET_CURSOR_SIG(external_view_set_cursor){
|
VIEW_SET_CURSOR_SIG(external_view_set_cursor){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Live_Views *live_set;
|
Live_Views *live_set;
|
||||||
View *vptr;
|
View *vptr;
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
@ -2250,6 +2268,9 @@ extern "C"{
|
||||||
live_set = cmd->live_set;
|
live_set = cmd->live_set;
|
||||||
vptr = (View*)((char*)live_set->views + live_set->stride * view->view_id);
|
vptr = (View*)((char*)live_set->views + live_set->stride * view->view_id);
|
||||||
result = 1;
|
result = 1;
|
||||||
|
if (seek.type == buffer_seek_line_char && seek.character <= 0){
|
||||||
|
seek.character = 1;
|
||||||
|
}
|
||||||
vptr->cursor = view_compute_cursor(vptr, seek);
|
vptr->cursor = view_compute_cursor(vptr, seek);
|
||||||
if (set_preferred_x){
|
if (set_preferred_x){
|
||||||
vptr->preferred_x = view_get_cursor_x(vptr);
|
vptr->preferred_x = view_get_cursor_x(vptr);
|
||||||
|
@ -2261,7 +2282,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
VIEW_SET_MARK_SIG(external_view_set_mark){
|
VIEW_SET_MARK_SIG(external_view_set_mark){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Live_Views *live_set;
|
Live_Views *live_set;
|
||||||
View *vptr;
|
View *vptr;
|
||||||
Full_Cursor cursor;
|
Full_Cursor cursor;
|
||||||
|
@ -2271,6 +2292,9 @@ extern "C"{
|
||||||
live_set = cmd->live_set;
|
live_set = cmd->live_set;
|
||||||
vptr = (View*)((char*)live_set->views + live_set->stride * view->view_id);
|
vptr = (View*)((char*)live_set->views + live_set->stride * view->view_id);
|
||||||
result = 1;
|
result = 1;
|
||||||
|
if (seek.type == buffer_seek_line_char && seek.character <= 0){
|
||||||
|
seek.character = 1;
|
||||||
|
}
|
||||||
if (seek.type != buffer_seek_pos){
|
if (seek.type != buffer_seek_pos){
|
||||||
cursor = view_compute_cursor(vptr, seek);
|
cursor = view_compute_cursor(vptr, seek);
|
||||||
vptr->mark = cursor.pos;
|
vptr->mark = cursor.pos;
|
||||||
|
@ -2285,7 +2309,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
VIEW_SET_HIGHLIGHT_SIG(external_view_set_highlight){
|
VIEW_SET_HIGHLIGHT_SIG(external_view_set_highlight){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Live_Views *live_set;
|
Live_Views *live_set;
|
||||||
View *vptr;
|
View *vptr;
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
@ -2307,7 +2331,7 @@ extern "C"{
|
||||||
}
|
}
|
||||||
|
|
||||||
VIEW_SET_BUFFER_SIG(external_view_set_buffer){
|
VIEW_SET_BUFFER_SIG(external_view_set_buffer){
|
||||||
Command_Data *cmd = (Command_Data*)context->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
Live_Views *live_set;
|
Live_Views *live_set;
|
||||||
View *vptr;
|
View *vptr;
|
||||||
Editing_File *file;
|
Editing_File *file;
|
||||||
|
@ -2939,6 +2963,7 @@ extern "C" SCROLL_RULE_SIG(fallback_scroll_rule){
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
App_Init_Sig(app_init){
|
App_Init_Sig(app_init){
|
||||||
app_links_init(system, memory->user_memory, memory->user_memory_size);
|
app_links_init(system, memory->user_memory, memory->user_memory_size);
|
||||||
|
|
||||||
|
@ -3249,7 +3274,7 @@ App_Init_Sig(app_init){
|
||||||
// more unified behavior, I will use this to add checks to the program's state so that I
|
// more unified behavior, I will use this to add checks to the program's state so that I
|
||||||
// can make sure it behaving well.
|
// can make sure it behaving well.
|
||||||
internal void
|
internal void
|
||||||
correctness_check(App_Vars *vars){
|
correctness_check_(App_Vars *vars){
|
||||||
Panel *panel, *used_panels;
|
Panel *panel, *used_panels;
|
||||||
used_panels = &vars->layout.used_sentinel;
|
used_panels = &vars->layout.used_sentinel;
|
||||||
for (dll_items(panel, used_panels)){
|
for (dll_items(panel, used_panels)){
|
||||||
|
@ -3410,8 +3435,6 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
ProfileEnd(OS_syncing);
|
ProfileEnd(OS_syncing);
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
ProfileStart(hover_status);
|
ProfileStart(hover_status);
|
||||||
// NOTE(allen): detect mouse hover status
|
// NOTE(allen): detect mouse hover status
|
||||||
i32 mx = mouse->x;
|
i32 mx = mouse->x;
|
||||||
|
@ -3491,8 +3514,6 @@ App_Step_Sig(app_step){
|
||||||
}
|
}
|
||||||
ProfileEnd(hover_status);
|
ProfileEnd(hover_status);
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
// NOTE(allen): prepare to start executing commands
|
// NOTE(allen): prepare to start executing commands
|
||||||
ProfileStart(prepare_commands);
|
ProfileStart(prepare_commands);
|
||||||
|
|
||||||
|
@ -3524,8 +3545,8 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
i32 i;
|
i32 i;
|
||||||
String file_name;
|
String file_name;
|
||||||
Panel *panel = vars->layout.panels;
|
Panel *panel = &vars->layout.used_sentinel;
|
||||||
for (i = 0; i < vars->settings.init_files_count; ++i, ++panel){
|
for (i = 0; i < vars->settings.init_files_count; ++i, panel = panel->next){
|
||||||
file_name = make_string_slowly(vars->settings.init_files[i]);
|
file_name = make_string_slowly(vars->settings.init_files[i]);
|
||||||
|
|
||||||
if (i < vars->layout.panel_count){
|
if (i < vars->layout.panel_count){
|
||||||
|
@ -3673,8 +3694,6 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
ProfileEnd(command_coroutine);
|
ProfileEnd(command_coroutine);
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
// NOTE(allen): pass raw input to the panels
|
// NOTE(allen): pass raw input to the panels
|
||||||
ProfileStart(step);
|
ProfileStart(step);
|
||||||
|
|
||||||
|
@ -3719,17 +3738,18 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
{
|
{
|
||||||
Panel *panel, *used_panels;
|
Panel *panel, *used_panels;
|
||||||
|
View *view;
|
||||||
|
b32 active;
|
||||||
|
|
||||||
used_panels = &vars->layout.used_sentinel;
|
used_panels = &vars->layout.used_sentinel;
|
||||||
for (dll_items(panel, used_panels)){
|
for (dll_items(panel, used_panels)){
|
||||||
View *view_ = panel->view;
|
view = panel->view;
|
||||||
Assert(view_->do_view);
|
active = (panel == cmd->panel);
|
||||||
b32 active = (panel == cmd->panel);
|
|
||||||
Input_Summary input = (active)?(active_input):(dead_input);
|
Input_Summary input = (active)?(active_input):(dead_input);
|
||||||
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 (view_->do_view(system, exchange, view_, panel->inner, cmd->view,
|
if (step_file_view(system, exchange, view, panel->inner, active, &input)){
|
||||||
VMSG_STEP, 0, &input, &active_input)){
|
|
||||||
app_result.redraw = 1;
|
app_result.redraw = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3738,8 +3758,6 @@ App_Step_Sig(app_step){
|
||||||
update_command_data(vars, cmd);
|
update_command_data(vars, cmd);
|
||||||
ProfileEnd(step);
|
ProfileEnd(step);
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
// NOTE(allen): command execution
|
// NOTE(allen): command execution
|
||||||
ProfileStart(command);
|
ProfileStart(command);
|
||||||
if (!consumed_input[0] || !consumed_input[1]){
|
if (!consumed_input[0] || !consumed_input[1]){
|
||||||
|
@ -3801,8 +3819,6 @@ App_Step_Sig(app_step){
|
||||||
update_command_data(vars, cmd);
|
update_command_data(vars, cmd);
|
||||||
ProfileEnd(command);
|
ProfileEnd(command);
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
ProfileStart(resizing);
|
ProfileStart(resizing);
|
||||||
// NOTE(allen): panel resizing
|
// NOTE(allen): panel resizing
|
||||||
switch (vars->state){
|
switch (vars->state){
|
||||||
|
@ -3908,8 +3924,6 @@ App_Step_Sig(app_step){
|
||||||
update_command_data(vars, cmd);
|
update_command_data(vars, cmd);
|
||||||
ProfileEnd(resizing);
|
ProfileEnd(resizing);
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
// NOTE(allen): processing sys app bindings
|
// NOTE(allen): processing sys app bindings
|
||||||
ProfileStart(sys_app_bind_processing);
|
ProfileStart(sys_app_bind_processing);
|
||||||
{
|
{
|
||||||
|
@ -4222,8 +4236,6 @@ App_Step_Sig(app_step){
|
||||||
end_temp_memory(param_stack_temp);
|
end_temp_memory(param_stack_temp);
|
||||||
ProfileEnd(delayed_actions);
|
ProfileEnd(delayed_actions);
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
ProfileStart(resize);
|
ProfileStart(resize);
|
||||||
// NOTE(allen): send resize messages to panels that have changed size
|
// NOTE(allen): send resize messages to panels that have changed size
|
||||||
{
|
{
|
||||||
|
@ -4236,9 +4248,7 @@ App_Step_Sig(app_step){
|
||||||
prev.x1 != inner.x1 || prev.y1 != inner.y1){
|
prev.x1 != inner.x1 || prev.y1 != inner.y1){
|
||||||
View *view = panel->view;
|
View *view = panel->view;
|
||||||
if (view){
|
if (view){
|
||||||
view->do_view(system, exchange,
|
remeasure_file_view(system, view, panel->inner);
|
||||||
view, inner, cmd->view,
|
|
||||||
VMSG_RESIZE, 0, &dead_input, &active_input);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
panel->prev_inner = inner;
|
panel->prev_inner = inner;
|
||||||
|
@ -4268,16 +4278,12 @@ App_Step_Sig(app_step){
|
||||||
for (dll_items(panel, used_panels)){
|
for (dll_items(panel, used_panels)){
|
||||||
View *view = panel->view;
|
View *view = panel->view;
|
||||||
if (view){
|
if (view){
|
||||||
view->do_view(system, exchange,
|
remeasure_file_view(system, view, panel->inner);
|
||||||
view, panel->inner, cmd->view,
|
|
||||||
VMSG_STYLE_CHANGE, 0, &dead_input, &active_input);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProfileEnd(style_change);
|
ProfileEnd(style_change);
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
ProfileStart(redraw);
|
ProfileStart(redraw);
|
||||||
if (mouse_panel != vars->prev_mouse_panel) app_result.redraw = 1;
|
if (mouse_panel != vars->prev_mouse_panel) app_result.redraw = 1;
|
||||||
if (app_result.redraw){
|
if (app_result.redraw){
|
||||||
|
@ -4300,14 +4306,9 @@ App_Step_Sig(app_step){
|
||||||
u32 back_color = style->main.back_color;
|
u32 back_color = style->main.back_color;
|
||||||
draw_rectangle(target, full, back_color);
|
draw_rectangle(target, full, back_color);
|
||||||
|
|
||||||
if (view){
|
draw_push_clip(target, panel->inner);
|
||||||
Assert(view->do_view);
|
draw_file_view(system, exchange, view, cmd->view, panel->inner, active, target, &dead_input);
|
||||||
draw_push_clip(target, panel->inner);
|
draw_pop_clip(target);
|
||||||
view->do_view(system, exchange,
|
|
||||||
view, panel->inner, cmd->view,
|
|
||||||
VMSG_DRAW, target, &dead_input, &active_input);
|
|
||||||
draw_pop_clip(target);
|
|
||||||
}
|
|
||||||
|
|
||||||
u32 margin_color;
|
u32 margin_color;
|
||||||
if (active){
|
if (active){
|
||||||
|
@ -4353,8 +4354,6 @@ App_Step_Sig(app_step){
|
||||||
*result = app_result;
|
*result = app_result;
|
||||||
result->lctrl_lalt_is_altgr = vars->settings.lctrl_lalt_is_altgr;
|
result->lctrl_lalt_is_altgr = vars->settings.lctrl_lalt_is_altgr;
|
||||||
|
|
||||||
correctness_check(vars);
|
|
||||||
|
|
||||||
// end-of-app_step
|
// end-of-app_step
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,10 +35,11 @@
|
||||||
#define FCPP_LEXER_IMPLEMENTATION
|
#define FCPP_LEXER_IMPLEMENTATION
|
||||||
#include "4cpp_lexer.h"
|
#include "4cpp_lexer.h"
|
||||||
|
|
||||||
#include "4ed_template.cpp"
|
|
||||||
#include "4ed_exchange.cpp"
|
|
||||||
#include "4ed_font_set.cpp"
|
#include "4ed_font_set.cpp"
|
||||||
#include "4ed_rendering_helper.cpp"
|
#include "4ed_rendering_helper.cpp"
|
||||||
|
|
||||||
|
#include "4ed_template.cpp"
|
||||||
|
#include "4ed_exchange.cpp"
|
||||||
#include "4ed_command.cpp"
|
#include "4ed_command.cpp"
|
||||||
#include "4ed_style.cpp"
|
#include "4ed_style.cpp"
|
||||||
#include "4ed_file.cpp"
|
#include "4ed_file.cpp"
|
||||||
|
|
|
@ -9,23 +9,6 @@
|
||||||
|
|
||||||
// TOP
|
// TOP
|
||||||
|
|
||||||
enum View_Message{
|
|
||||||
VMSG_STEP,
|
|
||||||
VMSG_DRAW,
|
|
||||||
VMSG_RESIZE,
|
|
||||||
VMSG_STYLE_CHANGE,
|
|
||||||
VMSG_FREE
|
|
||||||
};
|
|
||||||
|
|
||||||
struct View;
|
|
||||||
#define Do_View_Sig(name) \
|
|
||||||
i32 (name)(System_Functions *system, Exchange *exchange, \
|
|
||||||
View *view, i32_Rect rect, View *active, \
|
|
||||||
View_Message message, Render_Target *target, \
|
|
||||||
Input_Summary *user_input, Input_Summary *active_input)
|
|
||||||
|
|
||||||
typedef Do_View_Sig(Do_View_Function);
|
|
||||||
|
|
||||||
enum Interactive_Action{
|
enum Interactive_Action{
|
||||||
IAct_Open,
|
IAct_Open,
|
||||||
IAct_Save_As,
|
IAct_Save_As,
|
||||||
|
@ -42,7 +25,7 @@ enum Interactive_Interaction{
|
||||||
};
|
};
|
||||||
|
|
||||||
struct View_Mode{
|
struct View_Mode{
|
||||||
i8 rewrite;
|
i32 rewrite;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Incremental_Search{
|
struct Incremental_Search{
|
||||||
|
@ -91,7 +74,6 @@ struct View{
|
||||||
|
|
||||||
Panel *panel;
|
Panel *panel;
|
||||||
Command_Map *map;
|
Command_Map *map;
|
||||||
Do_View_Function *do_view;
|
|
||||||
Scroll_Rule_Function *scroll_rule;
|
Scroll_Rule_Function *scroll_rule;
|
||||||
i32 id;
|
i32 id;
|
||||||
|
|
||||||
|
@ -133,7 +115,8 @@ struct View{
|
||||||
Style_Library inspecting_styles;
|
Style_Library inspecting_styles;
|
||||||
b8 import_export_check[64];
|
b8 import_export_check[64];
|
||||||
i32 import_file_id;
|
i32 import_file_id;
|
||||||
|
|
||||||
|
// file stuff
|
||||||
i32 font_advance;
|
i32 font_advance;
|
||||||
i32 font_height;
|
i32 font_height;
|
||||||
|
|
||||||
|
@ -143,6 +126,7 @@ struct View{
|
||||||
f32 scroll_x, target_x, prev_target_x;
|
f32 scroll_x, target_x, prev_target_x;
|
||||||
f32 preferred_x;
|
f32 preferred_x;
|
||||||
i32 scroll_i;
|
i32 scroll_i;
|
||||||
|
f32 scroll_min_limit;
|
||||||
|
|
||||||
union{
|
union{
|
||||||
Incremental_Search isearch;
|
Incremental_Search isearch;
|
||||||
|
@ -168,8 +152,9 @@ struct View{
|
||||||
|
|
||||||
i32 line_count, line_max;
|
i32 line_count, line_max;
|
||||||
f32 *line_wrap_y;
|
f32 *line_wrap_y;
|
||||||
|
|
||||||
Command_Map *map_for_file;
|
Command_Map *map_for_file;
|
||||||
|
b32 reinit_scrolling;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct View_And_ID{
|
struct View_And_ID{
|
||||||
|
@ -666,16 +651,12 @@ file_close(System_Functions *system, General_Memory *general, Editing_File *file
|
||||||
general_memory_free(general, file->state.token_stack.tokens);
|
general_memory_free(general, file->state.token_stack.tokens);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if BUFFER_EXPERIMENT_SCALPEL <= 1
|
|
||||||
Buffer_Type *buffer = &file->state.buffer;
|
Buffer_Type *buffer = &file->state.buffer;
|
||||||
if (buffer->data){
|
if (buffer->data){
|
||||||
general_memory_free(general, buffer->data);
|
general_memory_free(general, buffer->data);
|
||||||
general_memory_free(general, buffer->line_starts);
|
general_memory_free(general, buffer->line_starts);
|
||||||
general_memory_free(general, buffer->line_widths);
|
general_memory_free(general, buffer->line_widths);
|
||||||
}
|
}
|
||||||
#elif BUFFER_EXPERIMENT_SCALPEL == 2
|
|
||||||
// TODO
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (file->state.undo.undo.edits){
|
if (file->state.undo.undo.edits){
|
||||||
general_memory_free(general, file->state.undo.undo.strings);
|
general_memory_free(general, file->state.undo.undo.strings);
|
||||||
|
@ -746,24 +727,8 @@ Job_Callback_Sig(job_full_lex){
|
||||||
u8 *dest = (u8*)file->state.swap_stack.tokens;
|
u8 *dest = (u8*)file->state.swap_stack.tokens;
|
||||||
u8 *src = (u8*)tokens.tokens;
|
u8 *src = (u8*)tokens.tokens;
|
||||||
|
|
||||||
#if 1
|
|
||||||
memcpy(dest, src, tokens.count*sizeof(Cpp_Token));
|
memcpy(dest, src, tokens.count*sizeof(Cpp_Token));
|
||||||
#else
|
|
||||||
i32 copy_amount = Kbytes(8);
|
|
||||||
i32 uncoppied = tokens.count*sizeof(Cpp_Token);
|
|
||||||
if (copy_amount > uncoppied) copy_amount = uncoppied;
|
|
||||||
|
|
||||||
while (uncoppied > 0){
|
|
||||||
system->acquire_lock(FRAME_LOCK);
|
|
||||||
memcpy(dest, src, copy_amount);
|
|
||||||
system->release_lock(FRAME_LOCK);
|
|
||||||
dest += copy_amount;
|
|
||||||
src += copy_amount;
|
|
||||||
uncoppied -= copy_amount;
|
|
||||||
if (copy_amount > uncoppied) copy_amount = uncoppied;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
system->acquire_lock(FRAME_LOCK);
|
system->acquire_lock(FRAME_LOCK);
|
||||||
{
|
{
|
||||||
file->state.token_stack.count = tokens.count;
|
file->state.token_stack.count = tokens.count;
|
||||||
|
@ -815,10 +780,6 @@ file_first_lex_parallel(System_Functions *system,
|
||||||
file->state.tokens_complete = 0;
|
file->state.tokens_complete = 0;
|
||||||
file->state.still_lexing = 1;
|
file->state.still_lexing = 1;
|
||||||
|
|
||||||
#if 0
|
|
||||||
full_lex(system, file, general);
|
|
||||||
#else
|
|
||||||
|
|
||||||
Job_Data job;
|
Job_Data job;
|
||||||
job.callback = job_full_lex;
|
job.callback = job_full_lex;
|
||||||
job.data[0] = file;
|
job.data[0] = file;
|
||||||
|
@ -906,20 +867,14 @@ file_relex_parallel(System_Functions *system,
|
||||||
|
|
||||||
file->state.still_lexing = 1;
|
file->state.still_lexing = 1;
|
||||||
|
|
||||||
#if 0
|
|
||||||
full_lex(system, file, general);
|
|
||||||
#else
|
|
||||||
|
|
||||||
Job_Data job;
|
Job_Data job;
|
||||||
job.callback = job_full_lex;
|
job.callback = job_full_lex;
|
||||||
job.data[0] = file;
|
job.data[0] = file;
|
||||||
job.data[1] = general;
|
job.data[1] = general;
|
||||||
job.memory_request = Kbytes(64);
|
job.memory_request = Kbytes(64);
|
||||||
file->state.lex_job = system->post_job(BACKGROUND_THREADS, job);
|
file->state.lex_job = system->post_job(BACKGROUND_THREADS, job);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
internal bool32
|
internal bool32
|
||||||
file_grow_as_needed_(General_Memory *general, Editing_File *file, i32 new_size){
|
file_grow_as_needed_(General_Memory *general, Editing_File *file, i32 new_size){
|
||||||
|
@ -1132,7 +1087,6 @@ file_unpost_history_block(Editing_File *file){
|
||||||
file->state.undo.history_head_block = old_head->prev_block;
|
file->state.undo.history_head_block = old_head->prev_block;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if BUFFER_EXPERIMENT_SCALPEL <= 3
|
|
||||||
internal Edit_Step*
|
internal Edit_Step*
|
||||||
file_post_history(General_Memory *general, Editing_File *file,
|
file_post_history(General_Memory *general, Editing_File *file,
|
||||||
Edit_Step step, b32 do_merge, b32 can_merge){
|
Edit_Step step, b32 do_merge, b32 can_merge){
|
||||||
|
@ -1202,7 +1156,6 @@ file_post_history(General_Memory *general, Editing_File *file,
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
inline Full_Cursor
|
inline Full_Cursor
|
||||||
view_compute_cursor_from_pos(View *view, i32 pos){
|
view_compute_cursor_from_pos(View *view, i32 pos){
|
||||||
|
@ -1368,10 +1321,6 @@ view_set_file(
|
||||||
Panel *panel;
|
Panel *panel;
|
||||||
Font_Info *fnt_info;
|
Font_Info *fnt_info;
|
||||||
|
|
||||||
f32 w, h;
|
|
||||||
f32 cursor_x, cursor_y;
|
|
||||||
f32 target_x, target_y;
|
|
||||||
|
|
||||||
panel = view->panel;
|
panel = view->panel;
|
||||||
|
|
||||||
// NOTE(allen): This is actually more like view_set_style right?
|
// NOTE(allen): This is actually more like view_set_style right?
|
||||||
|
@ -1386,11 +1335,6 @@ view_set_file(
|
||||||
view->file = file;
|
view->file = file;
|
||||||
|
|
||||||
view->cursor = {};
|
view->cursor = {};
|
||||||
view->prev_target_x = -1000.f;
|
|
||||||
view->prev_target_y = -1000.f;
|
|
||||||
|
|
||||||
target_x = 0;
|
|
||||||
target_y = 0;
|
|
||||||
|
|
||||||
// NOTE(allen): Stuff that does assume file exists.
|
// NOTE(allen): Stuff that does assume file exists.
|
||||||
|
|
||||||
|
@ -1405,29 +1349,10 @@ view_set_file(
|
||||||
view_measure_wraps(system, &view->mem->general, view);
|
view_measure_wraps(system, &view->mem->general, view);
|
||||||
view->cursor = view_compute_cursor_from_pos(view, file->state.cursor_pos);
|
view->cursor = view_compute_cursor_from_pos(view, file->state.cursor_pos);
|
||||||
|
|
||||||
cursor_x = view_get_cursor_x(view);
|
view->reinit_scrolling = 1;
|
||||||
cursor_y = view_get_cursor_y(view);
|
|
||||||
|
|
||||||
w = (f32)(panel->inner.x1 - panel->inner.x0);
|
|
||||||
h = (f32)(panel->inner.y1 - panel->inner.y0);
|
|
||||||
|
|
||||||
Assert(cursor_x >= target_x);
|
|
||||||
if (cursor_x >= target_x + w){
|
|
||||||
target_x = (f32)(cursor_x - w*.5f);
|
|
||||||
}
|
|
||||||
|
|
||||||
target_y = (f32)FLOOR32(cursor_y - h*.5f);
|
|
||||||
if (target_y < 0) target_y = 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE(allen): More stuff that doesn't assume file exists, but that
|
|
||||||
// has to come after computing target_x, target_y
|
|
||||||
view->target_x = target_x;
|
|
||||||
view->target_y = target_y;
|
|
||||||
view->scroll_x = target_x;
|
|
||||||
view->scroll_y = target_y;
|
|
||||||
|
|
||||||
// TODO(allen): Bypass all this nonsense, it's a hack! Hooks need parameters!
|
// TODO(allen): Bypass all this nonsense, it's a hack! Hooks need parameters!
|
||||||
// Just accept it and pass the file to the open hook when it is loaded.
|
// Just accept it and pass the file to the open hook when it is loaded.
|
||||||
if (file){
|
if (file){
|
||||||
|
@ -1438,33 +1363,30 @@ view_set_file(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(allen): Somehow keep track of the scroll limits through this process.
|
|
||||||
// Maybe scroll limits should be stored in the view at each frame.
|
|
||||||
struct Relative_Scrolling{
|
struct Relative_Scrolling{
|
||||||
f32 scroll_x, scroll_y;
|
f32 scroll_x, scroll_y;
|
||||||
f32 target_x, target_y;
|
f32 target_x, target_y;
|
||||||
|
f32 scroll_min_limit;
|
||||||
};
|
};
|
||||||
|
|
||||||
internal Relative_Scrolling
|
internal Relative_Scrolling
|
||||||
view_get_relative_scrolling(View *view){
|
view_get_relative_scrolling(View *view){
|
||||||
Relative_Scrolling result;
|
Relative_Scrolling result;
|
||||||
f32 cursor_x, cursor_y;
|
f32 cursor_y;
|
||||||
cursor_x = view_get_cursor_x(view);
|
|
||||||
cursor_y = view_get_cursor_y(view);
|
cursor_y = view_get_cursor_y(view);
|
||||||
result.scroll_x = cursor_x - view->scroll_x;
|
|
||||||
result.scroll_y = cursor_y - view->scroll_y;
|
result.scroll_y = cursor_y - view->scroll_y;
|
||||||
result.target_x = cursor_x - view->target_x;
|
|
||||||
result.target_y = cursor_y - view->target_y;
|
result.target_y = cursor_y - view->target_y;
|
||||||
|
result.scroll_min_limit = view->scroll_min_limit;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
view_set_relative_scrolling(View *view, Relative_Scrolling scrolling){
|
view_set_relative_scrolling(View *view, Relative_Scrolling scrolling){
|
||||||
f32 cursor_x, cursor_y;
|
f32 cursor_y;
|
||||||
cursor_x = view_get_cursor_x(view);
|
|
||||||
cursor_y = view_get_cursor_y(view);
|
cursor_y = view_get_cursor_y(view);
|
||||||
view->scroll_y = cursor_y - scrolling.scroll_y;
|
view->scroll_y = cursor_y - scrolling.scroll_y;
|
||||||
view->target_y = cursor_y - scrolling.target_y;
|
view->target_y = cursor_y - scrolling.target_y;
|
||||||
|
if (view->target_y < scrolling.scroll_min_limit) view->target_y = scrolling.scroll_min_limit;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
|
@ -1517,20 +1439,6 @@ view_widget_rect(View *view, i32 font_height){
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if FRED_SLOW
|
|
||||||
inline b32
|
|
||||||
debug_edit_step_check(Edit_Step a, Edit_Step b){
|
|
||||||
Assert(a.type == b.type);
|
|
||||||
Assert(a.can_merge == b.can_merge);
|
|
||||||
Assert(a.pre_pos == b.pre_pos);
|
|
||||||
Assert(a.post_pos == b.post_pos);
|
|
||||||
Assert(a.edit.start == b.edit.start);
|
|
||||||
Assert(a.edit.end == b.edit.end);
|
|
||||||
Assert(a.edit.len == b.edit.len);
|
|
||||||
return(1);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
enum History_Mode{
|
enum History_Mode{
|
||||||
hist_normal,
|
hist_normal,
|
||||||
hist_backward,
|
hist_backward,
|
||||||
|
@ -1541,28 +1449,8 @@ internal void
|
||||||
file_update_history_before_edit(Mem_Options *mem, Editing_File *file, Edit_Step step, u8 *str,
|
file_update_history_before_edit(Mem_Options *mem, Editing_File *file, Edit_Step step, u8 *str,
|
||||||
History_Mode history_mode){
|
History_Mode history_mode){
|
||||||
if (!file->state.undo.undo.edits) return;
|
if (!file->state.undo.undo.edits) return;
|
||||||
#if BUFFER_EXPERIMENT_SCALPEL <= 3
|
|
||||||
General_Memory *general = &mem->general;
|
General_Memory *general = &mem->general;
|
||||||
|
|
||||||
#if FRED_SLOW
|
|
||||||
if (history_mode == hist_backward)
|
|
||||||
debug_edit_step_check(step, file->state.undo.history.edits[file->state.undo.edit_history_cursor]);
|
|
||||||
else if (history_mode == hist_forward)
|
|
||||||
debug_edit_step_check(step, file->state.undo.history.edits[file->state.undo.history.edit_count]);
|
|
||||||
switch (step.type){
|
|
||||||
case ED_UNDO:
|
|
||||||
{
|
|
||||||
Assert(file->state.undo.undo.edit_count > 0);
|
|
||||||
debug_edit_step_check(step, file->state.undo.undo.edits[file->state.undo.undo.edit_count-1]);
|
|
||||||
}break;
|
|
||||||
case ED_REDO:
|
|
||||||
{
|
|
||||||
Assert(file->state.undo.redo.edit_count > 0);
|
|
||||||
debug_edit_step_check(step, file->state.undo.redo.edits[file->state.undo.redo.edit_count-1]);
|
|
||||||
}break;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
b32 can_merge = 0, do_merge = 0;
|
b32 can_merge = 0, do_merge = 0;
|
||||||
switch (step.type){
|
switch (step.type){
|
||||||
case ED_NORMAL:
|
case ED_NORMAL:
|
||||||
|
@ -1709,21 +1597,6 @@ file_update_history_before_edit(Mem_Options *mem, Editing_File *file, Edit_Step
|
||||||
if (history_mode == hist_normal){
|
if (history_mode == hist_normal){
|
||||||
file->state.undo.edit_history_cursor = file->state.undo.history.edit_count;
|
file->state.undo.edit_history_cursor = file->state.undo.history.edit_count;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
inline b32
|
|
||||||
debug_step_match(Edit_Step a, Edit_Step b){
|
|
||||||
Assert(a.type == b.type);
|
|
||||||
Assert(a.can_merge == b.can_merge);
|
|
||||||
Assert(a.pre_pos == b.pre_pos);
|
|
||||||
Assert(a.post_pos == b.post_pos);
|
|
||||||
Assert(a.next_block == b.next_block);
|
|
||||||
Assert(a.prev_block == b.prev_block);
|
|
||||||
Assert(a.edit.start == b.edit.start);
|
|
||||||
Assert(a.edit.end == b.edit.end);
|
|
||||||
Assert(a.edit.len == b.edit.len);
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
|
@ -1803,19 +1676,22 @@ file_edit_cursor_fix(System_Functions *system,
|
||||||
view->preferred_x = view_get_cursor_x(view);
|
view->preferred_x = view_get_cursor_x(view);
|
||||||
|
|
||||||
view->mark = cursors[cursor_count++].pos + 1;
|
view->mark = cursors[cursor_count++].pos + 1;
|
||||||
view->scroll_i = cursors[cursor_count++].pos + 1;
|
i32 new_scroll_i = cursors[cursor_count++].pos + 1;
|
||||||
temp_cursor = view_compute_cursor_from_pos(view, view->scroll_i);
|
if (view->scroll_i != new_scroll_i){
|
||||||
y_offset = MOD(view->scroll_y, view->font_height);
|
view->scroll_i = new_scroll_i;
|
||||||
|
temp_cursor = view_compute_cursor_from_pos(view, view->scroll_i);
|
||||||
if (view->unwrapped_lines){
|
y_offset = MOD(view->scroll_y, view->font_height);
|
||||||
y_position = temp_cursor.unwrapped_y + y_offset;
|
|
||||||
view->target_y += (y_position - view->scroll_y);
|
if (view->unwrapped_lines){
|
||||||
view->scroll_y = y_position;
|
y_position = temp_cursor.unwrapped_y + y_offset;
|
||||||
}
|
view->target_y += (y_position - view->scroll_y);
|
||||||
else{
|
view->scroll_y = y_position;
|
||||||
y_position = temp_cursor.wrapped_y + y_offset;
|
}
|
||||||
view->target_y += (y_position - view->scroll_y);
|
else{
|
||||||
view->scroll_y = y_position;
|
y_position = temp_cursor.wrapped_y + y_offset;
|
||||||
|
view->target_y += (y_position - view->scroll_y);
|
||||||
|
view->scroll_y = y_position;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1900,7 +1776,6 @@ internal void
|
||||||
view_do_white_batch_edit(System_Functions *system, Mem_Options *mem, View *view, Editing_File *file,
|
view_do_white_batch_edit(System_Functions *system, Mem_Options *mem, View *view, Editing_File *file,
|
||||||
Editing_Layout *layout, Edit_Spec spec, History_Mode history_mode){
|
Editing_Layout *layout, Edit_Spec spec, History_Mode history_mode){
|
||||||
if (view->locked) return;
|
if (view->locked) return;
|
||||||
#if BUFFER_EXPERIMENT_SCALPEL <= 3
|
|
||||||
Assert(file);
|
Assert(file);
|
||||||
ProfileMomentFunction();
|
ProfileMomentFunction();
|
||||||
|
|
||||||
|
@ -1977,7 +1852,6 @@ view_do_white_batch_edit(System_Functions *system, Mem_Options *mem, View *view,
|
||||||
desc.batch_size = batch_size;
|
desc.batch_size = batch_size;
|
||||||
|
|
||||||
file_edit_cursor_fix(system, part, general, file, layout, desc);
|
file_edit_cursor_fix(system, part, general, file, layout, desc);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
|
@ -3420,6 +3294,7 @@ interactive_shit(System_Functions *system, View *view, UI_State *state, UI_Layou
|
||||||
if (complete){
|
if (complete){
|
||||||
view->finished = 1;
|
view->finished = 1;
|
||||||
interactive_view_complete(view);
|
interactive_view_complete(view);
|
||||||
|
result= 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return(result);
|
return(result);
|
||||||
|
@ -3506,6 +3381,41 @@ do_file_bar(View *view, Editing_File *file, UI_Layout *layout, Render_Target *ta
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal void
|
||||||
|
view_reinit_scrolling(View *view){
|
||||||
|
Editing_File *file = view->file;
|
||||||
|
f32 w, h;
|
||||||
|
f32 cursor_x, cursor_y;
|
||||||
|
f32 target_x, target_y;
|
||||||
|
|
||||||
|
view->reinit_scrolling = 0;
|
||||||
|
|
||||||
|
target_x = 0;
|
||||||
|
target_y = 0;
|
||||||
|
|
||||||
|
if (file && file_is_ready(file)){
|
||||||
|
cursor_x = view_get_cursor_x(view);
|
||||||
|
cursor_y = view_get_cursor_y(view);
|
||||||
|
|
||||||
|
w = view_compute_width(view);
|
||||||
|
h = view_compute_height(view);
|
||||||
|
|
||||||
|
if (cursor_x >= target_x + w){
|
||||||
|
target_x = (f32)(cursor_x - w*.5f);
|
||||||
|
}
|
||||||
|
|
||||||
|
target_y = (f32)FLOOR32(cursor_y - h*.5f);
|
||||||
|
if (target_y < view->scroll_min_limit) target_y = view->scroll_min_limit;
|
||||||
|
}
|
||||||
|
|
||||||
|
view->target_x = target_x;
|
||||||
|
view->target_y = target_y;
|
||||||
|
view->scroll_x = target_x;
|
||||||
|
view->scroll_y = target_y;
|
||||||
|
view->prev_target_x = -1000.f;
|
||||||
|
view->prev_target_y = -1000.f;
|
||||||
|
}
|
||||||
|
|
||||||
internal i32
|
internal i32
|
||||||
step_file_view(System_Functions *system, Exchange *exchange, View *view, i32_Rect rect,
|
step_file_view(System_Functions *system, Exchange *exchange, View *view, i32_Rect rect,
|
||||||
b32 is_active, Input_Summary *user_input){
|
b32 is_active, Input_Summary *user_input){
|
||||||
|
@ -3548,7 +3458,12 @@ step_file_view(System_Functions *system, Exchange *exchange, View *view, i32_Rec
|
||||||
result = 1;
|
result = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
view->scroll_min_limit = (f32)-widget_height;
|
||||||
|
if (view->reinit_scrolling){
|
||||||
|
view_reinit_scrolling(view);
|
||||||
|
}
|
||||||
|
|
||||||
// TODO(allen): Split this into passive step and step that depends on input
|
// TODO(allen): Split this into passive step and step that depends on input
|
||||||
if (file && !file->state.is_loading){
|
if (file && !file->state.is_loading){
|
||||||
f32 line_height = (f32)view->font_height;
|
f32 line_height = (f32)view->font_height;
|
||||||
|
@ -3892,6 +3807,7 @@ draw_file_view(System_Functions *system, Exchange *exchange,
|
||||||
widget_height = layout.y - rect.y0;
|
widget_height = layout.y - rect.y0;
|
||||||
ui_finish_frame(&view->widget.state, &state, &layout, rect, 0, 0);
|
ui_finish_frame(&view->widget.state, &state, &layout, rect, 0, 0);
|
||||||
}
|
}
|
||||||
|
view->scroll_min_limit = (f32)-widget_height;
|
||||||
|
|
||||||
{
|
{
|
||||||
rect.y0 += widget_height;
|
rect.y0 += widget_height;
|
||||||
|
@ -3910,6 +3826,9 @@ draw_file_view(System_Functions *system, Exchange *exchange,
|
||||||
case VUI_None:
|
case VUI_None:
|
||||||
{
|
{
|
||||||
if (file && file_is_ready(file)){
|
if (file && file_is_ready(file)){
|
||||||
|
if (view->reinit_scrolling){
|
||||||
|
view_reinit_scrolling(view);
|
||||||
|
}
|
||||||
result = draw_file_loaded(view, rect, is_active, target);
|
result = draw_file_loaded(view, rect, is_active, target);
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
@ -3970,39 +3889,12 @@ free_file_view(View *view){
|
||||||
general_memory_free(&view->mem->general, view->line_wrap_y);
|
general_memory_free(&view->mem->general, view->line_wrap_y);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal
|
|
||||||
Do_View_Sig(do_file_view){
|
|
||||||
i32 result = 0;
|
|
||||||
switch (message){
|
|
||||||
case VMSG_RESIZE:
|
|
||||||
case VMSG_STYLE_CHANGE:
|
|
||||||
{
|
|
||||||
remeasure_file_view(system, view, rect);
|
|
||||||
}break;
|
|
||||||
case VMSG_DRAW:
|
|
||||||
{
|
|
||||||
result = draw_file_view(system, exchange, view, active, rect, (view == active), target, user_input);
|
|
||||||
}break;
|
|
||||||
case VMSG_STEP:
|
|
||||||
{
|
|
||||||
result = step_file_view(system, exchange, view, rect, (view == active), user_input);
|
|
||||||
}break;
|
|
||||||
case VMSG_FREE:
|
|
||||||
{
|
|
||||||
free_file_view(view);
|
|
||||||
}break;
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
internal View*
|
internal View*
|
||||||
file_view_init(View *view, Editing_Layout *layout,
|
file_view_init(View *view, Editing_Layout *layout,
|
||||||
Working_Set *working_set, Delay *delay,
|
Working_Set *working_set, Delay *delay,
|
||||||
App_Settings *settings, Hot_Directory *hot_directory,
|
App_Settings *settings, Hot_Directory *hot_directory,
|
||||||
Mem_Options *mem, Style_Library *styles){
|
Mem_Options *mem, Style_Library *styles){
|
||||||
|
|
||||||
view->do_view = do_file_view;
|
|
||||||
|
|
||||||
view->layout = layout;
|
view->layout = layout;
|
||||||
view->working_set = working_set;
|
view->working_set = working_set;
|
||||||
view->delay = delay;
|
view->delay = delay;
|
||||||
|
@ -4303,7 +4195,7 @@ inline void
|
||||||
live_set_free_view(System_Functions *system, Exchange *exchange, Live_Views *live_set, View *view){
|
live_set_free_view(System_Functions *system, Exchange *exchange, Live_Views *live_set, View *view){
|
||||||
Assert(live_set->count > 0);
|
Assert(live_set->count > 0);
|
||||||
--live_set->count;
|
--live_set->count;
|
||||||
view->do_view(system, exchange, view, {}, 0, VMSG_FREE, 0, {}, 0);
|
free_file_view(view);
|
||||||
dll_insert(&live_set->free_sentinel, view);
|
dll_insert(&live_set->free_sentinel, view);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -527,17 +527,6 @@ DIRECTORY_CD_SIG(system_directory_cd){
|
||||||
return(result);
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
Sys_File_Paths_Equal_Sig(system_file_paths_equal){
|
|
||||||
b32 result = 0;
|
|
||||||
|
|
||||||
// TODO(someone who knows windows): implement me
|
|
||||||
|
|
||||||
AllowLocal(path_a);
|
|
||||||
AllowLocal(path_b);
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
internal
|
internal
|
||||||
Sys_Post_Clipboard_Sig(system_post_clipboard){
|
Sys_Post_Clipboard_Sig(system_post_clipboard){
|
||||||
if (OpenClipboard(win32vars.window_handle)){
|
if (OpenClipboard(win32vars.window_handle)){
|
||||||
|
|
Loading…
Reference in New Issue