use insert_char for insert_string, free console log, move actions to edit field

master
isidentical 2019-12-18 17:22:36 +03:00
parent c67cfe91de
commit eb3088a323
4 changed files with 42 additions and 26 deletions

View File

@ -213,24 +213,6 @@ int console_handle_event(Console *console,
}
} break;
case SDLK_w: {
if (event->key.keysym.mod & (KMOD_CTRL | KMOD_ALT)) {
SDL_SetClipboardText(edit_field_as_text(console->edit_field));
if (event->key.keysym.mod & KMOD_CTRL) {
edit_field_clean(console->edit_field);
}
return 0;
}
} break;
case SDLK_y: {
if (event->key.keysym.mod & KMOD_CTRL) {
char *text = SDL_GetClipboardText();
edit_field_append(console->edit_field, text);
return 0;
}
} break;
case SDLK_DOWN:
edit_field_replace(
console->edit_field,

View File

@ -114,6 +114,7 @@ void console_log_clear(Console_Log *console_log)
console_log->cursor = 0;
for (size_t i = 0; i < console_log->capacity; ++i) {
if (console_log->buffer[i]) {
free(console_log->buffer[i]);
console_log->buffer[i] = 0;
}
}

View File

@ -38,6 +38,9 @@ static void delete_backward_char(Edit_field *edit_field);
static void kill_word(Edit_field *edit_field);
static void backward_kill_word(Edit_field *edit_field);
static void kill_to_end_of_line(Edit_field *edit_field);
static void field_buffer_cut(Edit_field *edit_field);
static void field_buffer_copy(Edit_field *edit_field);
static void field_buffer_paste(Edit_field *edit_field);
static void handle_keydown(Edit_field *edit_field, const SDL_Event *event);
static void handle_keydown_alt(Edit_field *edit_field, const SDL_Event *event);
@ -56,6 +59,15 @@ static void edit_field_insert_char(Edit_field *edit_field, char c)
edit_field->buffer[++edit_field->buffer_size] = 0;
}
static inline
void edit_field_insert_string(Edit_field *edit_field, const char *text)
{
size_t n = strlen(text);
for (size_t i = 0; i < n; ++i) {
edit_field_insert_char(edit_field, text[i]);
}
}
// See: https://www.gnu.org/software/emacs/manual/html_node/emacs/Moving-Point.html
// For an explanation of the naming terminology for these helper methods
@ -201,6 +213,23 @@ static void kill_to_end_of_line(Edit_field *edit_field) {
edit_field->buffer_size);
}
static void field_buffer_cut(Edit_field *edit_field) {
// "C-w"
SDL_SetClipboardText(edit_field_as_text(edit_field));
edit_field_clean(edit_field);
}
static void field_buffer_copy(Edit_field *edit_field) {
// "M-w"
SDL_SetClipboardText(edit_field_as_text(edit_field));
}
static void field_buffer_paste(Edit_field *edit_field) {
// "C-y"
char *text = SDL_GetClipboardText();
edit_field_insert_string(edit_field, text);
}
static void handle_keydown(Edit_field *edit_field, const SDL_Event *event)
{
switch (event->key.keysym.sym) {
@ -251,6 +280,10 @@ static void handle_keydown_alt(Edit_field *edit_field, const SDL_Event *event)
case SDLK_d: {
kill_word(edit_field);
} break;
case SDLK_w: {
field_buffer_copy(edit_field);
} break;
}
}
@ -296,6 +329,14 @@ static void handle_keydown_ctrl(Edit_field *edit_field, const SDL_Event *event)
case SDLK_k: {
kill_to_end_of_line(edit_field);
} break;
case SDLK_w: {
field_buffer_cut(edit_field);
} break;
case SDLK_y: {
field_buffer_paste(edit_field);
} break;
}
}
@ -449,13 +490,6 @@ void edit_field_replace(Edit_field *edit_field, const char *text)
}
}
void edit_field_append(Edit_field *edit_field, const char *text)
{
size_t n = strlen(text);
edit_field->buffer = strcat(edit_field->buffer, text);
edit_field->cursor += n;
}
void edit_field_clean(Edit_field *edit_field)
{
trace_assert(edit_field);

View File

@ -26,7 +26,6 @@ int edit_field_event(Edit_field *edit_field, const SDL_Event *event);
const char *edit_field_as_text(const Edit_field *edit_field);
void edit_field_replace(Edit_field *edit_field, const char *text);
void edit_field_append(Edit_field *edit_field, const char *text);
void edit_field_clean(Edit_field *edit_field);
void edit_field_restyle(Edit_field *edit_field,
Vec2f font_size,