}
} 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,
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);
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
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) {
case SDLK_d: {
kill_word(edit_field);
} break;
+
+ case SDLK_w: {
+ field_buffer_copy(edit_field);
+ } break;
}
}
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;
}
}
}
}
-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);