ready for distribution
parent
353d08fa2b
commit
bdd3bbe0d9
|
@ -67,7 +67,7 @@ HOOK_SIG(my_file_settings){
|
||||||
}
|
}
|
||||||
|
|
||||||
push_parameter(app, par_lex_as_cpp_file, treat_as_code);
|
push_parameter(app, par_lex_as_cpp_file, treat_as_code);
|
||||||
push_parameter(app, par_wrap_lines, !treat_as_code);
|
push_parameter(app, par_wrap_lines, wrap_lines);
|
||||||
push_parameter(app, par_key_mapid, (treat_as_code)?((int)my_code_map):((int)mapid_file));
|
push_parameter(app, par_key_mapid, (treat_as_code)?((int)my_code_map):((int)mapid_file));
|
||||||
exec_command(app, cmdid_set_settings);
|
exec_command(app, cmdid_set_settings);
|
||||||
|
|
||||||
|
@ -293,6 +293,7 @@ int get_bindings(void *data, int size){
|
||||||
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);
|
bind(context, 'z', MDFR_ALT, execute_any_cli);
|
||||||
|
bind(context, 'Z', MDFR_ALT, execute_previous_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.
|
||||||
|
|
|
@ -513,20 +513,21 @@ CUSTOM_COMMAND_SIG(open_all_code){
|
||||||
app->free_file_list(app, list);
|
app->free_file_list(app, list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char out_buffer_space[1024], command_space[1024], hot_directory_space[1024];
|
||||||
|
|
||||||
CUSTOM_COMMAND_SIG(execute_any_cli){
|
CUSTOM_COMMAND_SIG(execute_any_cli){
|
||||||
Query_Bar bar_out, bar_cmd;
|
Query_Bar bar_out, bar_cmd;
|
||||||
String hot_directory;
|
String hot_directory;
|
||||||
char space[1024], more_space[1024], even_more_space[1024];
|
|
||||||
|
|
||||||
bar_out.prompt = make_lit_string("Output Buffer: ");
|
bar_out.prompt = make_lit_string("Output Buffer: ");
|
||||||
bar_out.string = make_fixed_width_string(space);
|
bar_out.string = make_fixed_width_string(out_buffer_space);
|
||||||
if (!query_user_string(app, &bar_out)) return;
|
if (!query_user_string(app, &bar_out)) return;
|
||||||
|
|
||||||
bar_cmd.prompt = make_lit_string("Command: ");
|
bar_cmd.prompt = make_lit_string("Command: ");
|
||||||
bar_cmd.string = make_fixed_width_string(more_space);
|
bar_cmd.string = make_fixed_width_string(command_space);
|
||||||
if (!query_user_string(app, &bar_cmd)) return;
|
if (!query_user_string(app, &bar_cmd)) return;
|
||||||
|
|
||||||
hot_directory = make_fixed_width_string(even_more_space);
|
hot_directory = make_fixed_width_string(hot_directory_space);
|
||||||
hot_directory.size = app->directory_get_hot(app, hot_directory.str, hot_directory.memory_size);
|
hot_directory.size = app->directory_get_hot(app, hot_directory.str, hot_directory.memory_size);
|
||||||
|
|
||||||
push_parameter(app, par_flags, CLI_OverlapWithConflict);
|
push_parameter(app, par_flags, CLI_OverlapWithConflict);
|
||||||
|
@ -534,6 +535,26 @@ CUSTOM_COMMAND_SIG(execute_any_cli){
|
||||||
push_parameter(app, par_cli_path, hot_directory.str, hot_directory.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);
|
push_parameter(app, par_cli_command, bar_cmd.string.str, bar_cmd.string.size);
|
||||||
exec_command(app, cmdid_command_line);
|
exec_command(app, cmdid_command_line);
|
||||||
|
|
||||||
|
terminate_with_null(&bar_out.string);
|
||||||
|
terminate_with_null(&bar_cmd.string);
|
||||||
|
terminate_with_null(&hot_directory);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUSTOM_COMMAND_SIG(execute_previous_cli){
|
||||||
|
String out_buffer, cmd, hot_directory;
|
||||||
|
|
||||||
|
out_buffer = make_string_slowly(out_buffer_space);
|
||||||
|
cmd = make_string_slowly(command_space);
|
||||||
|
hot_directory = make_string_slowly(hot_directory_space);
|
||||||
|
|
||||||
|
if (out_buffer.size > 0 && cmd.size > 0 && hot_directory.size > 0){
|
||||||
|
push_parameter(app, par_flags, CLI_OverlapWithConflict);
|
||||||
|
push_parameter(app, par_name, out_buffer.str, out_buffer.size);
|
||||||
|
push_parameter(app, par_cli_path, hot_directory.str, hot_directory.size);
|
||||||
|
push_parameter(app, par_cli_command, cmd.str, cmd.size);
|
||||||
|
exec_command(app, cmdid_command_line);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CUSTOM_COMMAND_SIG(execute_arbitrary_command){
|
CUSTOM_COMMAND_SIG(execute_arbitrary_command){
|
||||||
|
|
|
@ -4783,7 +4783,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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1166,7 +1166,7 @@ gui_standard_list(GUI_Target *target, GUI_id id,
|
||||||
++*list_i;
|
++*list_i;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '\n':
|
case '\n': case '\t':
|
||||||
indirectly_activate = 1;
|
indirectly_activate = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -166,6 +166,8 @@ struct Win32_Vars{
|
||||||
// will involve more coroutines.
|
// will involve more coroutines.
|
||||||
Win32_Coroutine coroutine_data[18];
|
Win32_Coroutine coroutine_data[18];
|
||||||
Win32_Coroutine *coroutine_free;
|
Win32_Coroutine *coroutine_free;
|
||||||
|
|
||||||
|
i32 running_cli;
|
||||||
};
|
};
|
||||||
|
|
||||||
globalvar Win32_Vars win32vars;
|
globalvar Win32_Vars win32vars;
|
||||||
|
@ -932,6 +934,8 @@ Sys_CLI_Call_Sig(system_cli_call){
|
||||||
*(HANDLE*)&cli_out->proc = info.hProcess;
|
*(HANDLE*)&cli_out->proc = info.hProcess;
|
||||||
*(HANDLE*)&cli_out->out_read = out_read;
|
*(HANDLE*)&cli_out->out_read = out_read;
|
||||||
*(HANDLE*)&cli_out->out_write = out_write;
|
*(HANDLE*)&cli_out->out_write = out_write;
|
||||||
|
|
||||||
|
++win32vars.running_cli;
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
CloseHandle(out_read);
|
CloseHandle(out_read);
|
||||||
|
@ -943,6 +947,11 @@ Sys_CLI_Call_Sig(system_cli_call){
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
// TODO(allen): failed SetHandleInformation
|
// TODO(allen): failed SetHandleInformation
|
||||||
|
CloseHandle(out_read);
|
||||||
|
CloseHandle(out_write);
|
||||||
|
*(HANDLE*)&cli_out->proc = INVALID_HANDLE_VALUE;
|
||||||
|
*(HANDLE*)&cli_out->out_read = INVALID_HANDLE_VALUE;
|
||||||
|
*(HANDLE*)&cli_out->out_write = INVALID_HANDLE_VALUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
|
@ -1016,6 +1025,8 @@ Sys_CLI_End_Update_Sig(system_cli_end_update){
|
||||||
CloseHandle(*(HANDLE*)&cli->proc);
|
CloseHandle(*(HANDLE*)&cli->proc);
|
||||||
CloseHandle(*(HANDLE*)&cli->out_read);
|
CloseHandle(*(HANDLE*)&cli->out_read);
|
||||||
CloseHandle(*(HANDLE*)&cli->out_write);
|
CloseHandle(*(HANDLE*)&cli->out_write);
|
||||||
|
|
||||||
|
--win32vars.running_cli;
|
||||||
}
|
}
|
||||||
return close_me;
|
return close_me;
|
||||||
}
|
}
|
||||||
|
@ -1708,17 +1719,22 @@ UpdateLoop(LPVOID param){
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if 0
|
#if 1
|
||||||
int
|
int
|
||||||
WinMain(HINSTANCE hInstance,
|
WinMain(HINSTANCE hInstance,
|
||||||
HINSTANCE hPrevInstance,
|
HINSTANCE hPrevInstance,
|
||||||
LPSTR lpCmdLine,
|
LPSTR lpCmdLine,
|
||||||
int nCmdShow){
|
int nCmdShow){
|
||||||
|
|
||||||
|
int argc = __argc;
|
||||||
|
char **argv = __argv;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
int main(int argc, char **argv){
|
int main(int argc, char **argv){
|
||||||
#endif
|
|
||||||
|
|
||||||
HINSTANCE hInstance = GetModuleHandle(0);
|
HINSTANCE hInstance = GetModuleHandle(0);
|
||||||
|
#endif
|
||||||
|
|
||||||
HANDLE original_out = GetStdHandle(STD_OUTPUT_HANDLE);
|
HANDLE original_out = GetStdHandle(STD_OUTPUT_HANDLE);
|
||||||
|
|
||||||
win32vars = {};
|
win32vars = {};
|
||||||
|
@ -1840,70 +1856,70 @@ int main(int argc, char **argv){
|
||||||
GetProcAddress(win32vars.custom, "get_bindings");
|
GetProcAddress(win32vars.custom, "get_bindings");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//FreeConsole();
|
FreeConsole();
|
||||||
|
|
||||||
sysshared_filter_real_files(files, file_count);
|
sysshared_filter_real_files(files, file_count);
|
||||||
|
|
||||||
LARGE_INTEGER lpf;
|
LARGE_INTEGER lpf;
|
||||||
QueryPerformanceFrequency(&lpf);
|
QueryPerformanceFrequency(&lpf);
|
||||||
win32vars.performance_frequency = lpf.QuadPart;
|
win32vars.performance_frequency = lpf.QuadPart;
|
||||||
QueryPerformanceCounter(&lpf);
|
QueryPerformanceCounter(&lpf);
|
||||||
win32vars.start_pcount = lpf.QuadPart;
|
win32vars.start_pcount = lpf.QuadPart;
|
||||||
|
|
||||||
FILETIME filetime;
|
FILETIME filetime;
|
||||||
GetSystemTimeAsFileTime(&filetime);
|
GetSystemTimeAsFileTime(&filetime);
|
||||||
win32vars.start_time = ((u64)filetime.dwHighDateTime << 32) | (filetime.dwLowDateTime);
|
win32vars.start_time = ((u64)filetime.dwHighDateTime << 32) | (filetime.dwLowDateTime);
|
||||||
win32vars.start_time /= 10;
|
win32vars.start_time /= 10;
|
||||||
|
|
||||||
keycode_init();
|
keycode_init();
|
||||||
|
|
||||||
if (win32vars.custom_api.get_bindings == 0){
|
if (win32vars.custom_api.get_bindings == 0){
|
||||||
win32vars.custom_api.get_bindings = (Get_Binding_Data_Function*)get_bindings;
|
win32vars.custom_api.get_bindings = (Get_Binding_Data_Function*)get_bindings;
|
||||||
}
|
}
|
||||||
|
|
||||||
Thread_Context background[4];
|
Thread_Context background[4];
|
||||||
memset(background, 0, sizeof(background));
|
memset(background, 0, sizeof(background));
|
||||||
win32vars.groups[BACKGROUND_THREADS].threads = background;
|
win32vars.groups[BACKGROUND_THREADS].threads = background;
|
||||||
win32vars.groups[BACKGROUND_THREADS].count = ArrayCount(background);
|
win32vars.groups[BACKGROUND_THREADS].count = ArrayCount(background);
|
||||||
|
|
||||||
Thread_Memory thread_memory[ArrayCount(background)];
|
Thread_Memory thread_memory[ArrayCount(background)];
|
||||||
win32vars.thread_memory = thread_memory;
|
win32vars.thread_memory = thread_memory;
|
||||||
|
|
||||||
exchange_vars.thread.queues[BACKGROUND_THREADS].semaphore =
|
exchange_vars.thread.queues[BACKGROUND_THREADS].semaphore =
|
||||||
Win32GenHandle(
|
Win32GenHandle(
|
||||||
CreateSemaphore(0, 0, win32vars.groups[BACKGROUND_THREADS].count, 0)
|
CreateSemaphore(0, 0, win32vars.groups[BACKGROUND_THREADS].count, 0)
|
||||||
);
|
);
|
||||||
|
|
||||||
u32 creation_flag = 0;
|
u32 creation_flag = 0;
|
||||||
for (i32 i = 0; i < win32vars.groups[BACKGROUND_THREADS].count; ++i){
|
for (i32 i = 0; i < win32vars.groups[BACKGROUND_THREADS].count; ++i){
|
||||||
Thread_Context *thread = win32vars.groups[BACKGROUND_THREADS].threads + i;
|
Thread_Context *thread = win32vars.groups[BACKGROUND_THREADS].threads + i;
|
||||||
thread->id = i + 1;
|
thread->id = i + 1;
|
||||||
|
|
||||||
Thread_Memory *memory = win32vars.thread_memory + i;
|
Thread_Memory *memory = win32vars.thread_memory + i;
|
||||||
*memory = {};
|
*memory = {};
|
||||||
memory->id = thread->id;
|
memory->id = thread->id;
|
||||||
|
|
||||||
thread->queue = &exchange_vars.thread.queues[BACKGROUND_THREADS];
|
thread->queue = &exchange_vars.thread.queues[BACKGROUND_THREADS];
|
||||||
thread->handle = CreateThread(0, 0, JobThreadProc, thread, creation_flag, (LPDWORD)&thread->windows_id);
|
thread->handle = CreateThread(0, 0, JobThreadProc, thread, creation_flag, (LPDWORD)&thread->windows_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert(win32vars.locks);
|
Assert(win32vars.locks);
|
||||||
for (i32 i = 0; i < LOCK_COUNT; ++i){
|
for (i32 i = 0; i < LOCK_COUNT; ++i){
|
||||||
win32vars.locks[i] = CreateSemaphore(0, 1, 1, 0);
|
win32vars.locks[i] = CreateSemaphore(0, 1, 1, 0);
|
||||||
}
|
}
|
||||||
win32vars.DEBUG_sysmem_lock = CreateSemaphore(0, 1, 1, 0);
|
win32vars.DEBUG_sysmem_lock = CreateSemaphore(0, 1, 1, 0);
|
||||||
|
|
||||||
Win32LoadRenderCode();
|
Win32LoadRenderCode();
|
||||||
win32vars.target.max = Mbytes(1);
|
win32vars.target.max = Mbytes(1);
|
||||||
win32vars.target.push_buffer = (byte*)system_get_memory(win32vars.target.max);
|
win32vars.target.push_buffer = (byte*)system_get_memory(win32vars.target.max);
|
||||||
|
|
||||||
win32vars.cursor_ibeam = LoadCursor(NULL, IDC_IBEAM);
|
win32vars.cursor_ibeam = LoadCursor(NULL, IDC_IBEAM);
|
||||||
win32vars.cursor_arrow = LoadCursor(NULL, IDC_ARROW);
|
win32vars.cursor_arrow = LoadCursor(NULL, IDC_ARROW);
|
||||||
win32vars.cursor_leftright = LoadCursor(NULL, IDC_SIZEWE);
|
win32vars.cursor_leftright = LoadCursor(NULL, IDC_SIZEWE);
|
||||||
win32vars.cursor_updown = LoadCursor(NULL, IDC_SIZENS);
|
win32vars.cursor_updown = LoadCursor(NULL, IDC_SIZENS);
|
||||||
win32vars.prev_mouse_cursor = APP_MOUSE_CURSOR_ARROW;
|
win32vars.prev_mouse_cursor = APP_MOUSE_CURSOR_ARROW;
|
||||||
|
|
||||||
WNDCLASS window_class = {};
|
WNDCLASS window_class = {};
|
||||||
window_class.style = CS_HREDRAW|CS_VREDRAW|CS_OWNDC;
|
window_class.style = CS_HREDRAW|CS_VREDRAW|CS_OWNDC;
|
||||||
window_class.lpfnWndProc = Win32Callback;
|
window_class.lpfnWndProc = Win32Callback;
|
||||||
|
@ -2052,7 +2068,7 @@ int main(int argc, char **argv){
|
||||||
win32vars.input_chunk.pers.keep_playing = 1;
|
win32vars.input_chunk.pers.keep_playing = 1;
|
||||||
win32vars.first = 1;
|
win32vars.first = 1;
|
||||||
timeBeginPeriod(1);
|
timeBeginPeriod(1);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
win32vars.update_loop_thread =
|
win32vars.update_loop_thread =
|
||||||
CreateThread(0,
|
CreateThread(0,
|
||||||
|
@ -2062,30 +2078,37 @@ int main(int argc, char **argv){
|
||||||
CREATE_SUSPENDED,
|
CREATE_SUSPENDED,
|
||||||
&win32vars.update_loop_thread_id);
|
&win32vars.update_loop_thread_id);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
system_acquire_lock(FRAME_LOCK);
|
system_acquire_lock(FRAME_LOCK);
|
||||||
|
|
||||||
SetForegroundWindow(window_handle);
|
SetForegroundWindow(window_handle);
|
||||||
SetActiveWindow(window_handle);
|
SetActiveWindow(window_handle);
|
||||||
|
|
||||||
|
#if 0
|
||||||
ResumeThread(win32vars.update_loop_thread);
|
ResumeThread(win32vars.update_loop_thread);
|
||||||
|
#endif
|
||||||
|
|
||||||
MSG msg;
|
MSG msg;
|
||||||
for (;win32vars.input_chunk.pers.keep_playing;){
|
for (;win32vars.input_chunk.pers.keep_playing;){
|
||||||
win32vars.got_useful_event = 0;
|
// TODO(allen): Find a good way to wait on a pipe
|
||||||
for (;win32vars.got_useful_event == 0;){
|
// without interfering with the reading process
|
||||||
system_release_lock(FRAME_LOCK);
|
|
||||||
if (GetMessage(&msg, 0, 0, 0)){
|
if (win32vars.running_cli == 0){
|
||||||
system_acquire_lock(FRAME_LOCK);
|
win32vars.got_useful_event = 0;
|
||||||
if (msg.message == WM_QUIT){
|
for (;win32vars.got_useful_event == 0;){
|
||||||
win32vars.input_chunk.pers.keep_playing = 0;
|
system_release_lock(FRAME_LOCK);
|
||||||
}else{
|
if (GetMessage(&msg, 0, 0, 0)){
|
||||||
TranslateMessage(&msg);
|
system_acquire_lock(FRAME_LOCK);
|
||||||
DispatchMessage(&msg);
|
if (msg.message == WM_QUIT){
|
||||||
|
win32vars.input_chunk.pers.keep_playing = 0;
|
||||||
|
}else{
|
||||||
|
TranslateMessage(&msg);
|
||||||
|
DispatchMessage(&msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
system_acquire_lock(FRAME_LOCK);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else{
|
|
||||||
system_acquire_lock(FRAME_LOCK);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue