summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/dged/buffer.c28
-rw-r--r--src/dged/buffer.h2
-rw-r--r--src/main/bindings.c2
-rw-r--r--src/main/cmds.c4
-rw-r--r--src/main/main.c6
5 files changed, 41 insertions, 1 deletions
diff --git a/src/dged/buffer.c b/src/dged/buffer.c
index f2e7eb9..e40281f 100644
--- a/src/dged/buffer.c
+++ b/src/dged/buffer.c
@@ -434,6 +434,34 @@ void buffer_backward_delete_char(struct buffer_view *view) {
}
}
+void buffer_forward_delete_word(struct buffer_view *view) {
+ if (maybe_delete_region(view)) {
+ return;
+ }
+
+ struct buffer_location start = view->dot;
+ buffer_forward_word(view);
+ struct buffer_location end = view->dot;
+
+ buffer_goto(view, start.line, start.col);
+
+ delete_with_undo(view->buffer, start, end);
+}
+
+void buffer_backward_delete_word(struct buffer_view *view) {
+ if (maybe_delete_region(view)) {
+ return;
+ }
+
+ struct buffer_location end = view->dot;
+ buffer_backward_word(view);
+ struct buffer_location start = view->dot;
+
+ buffer_goto(view, start.line, start.col);
+
+ delete_with_undo(view->buffer, start, end);
+}
+
void buffer_backward_char(struct buffer_view *view) { moveh(view, -1); }
void buffer_forward_char(struct buffer_view *view) { moveh(view, 1); }
diff --git a/src/dged/buffer.h b/src/dged/buffer.h
index 05b85de..e33733b 100644
--- a/src/dged/buffer.h
+++ b/src/dged/buffer.h
@@ -177,7 +177,9 @@ bool buffer_is_backed(struct buffer *buffer);
void buffer_kill_line(struct buffer_view *view);
void buffer_forward_delete_char(struct buffer_view *view);
+void buffer_forward_delete_word(struct buffer_view *view);
void buffer_backward_delete_char(struct buffer_view *view);
+void buffer_backward_delete_word(struct buffer_view *view);
void buffer_backward_char(struct buffer_view *view);
void buffer_backward_word(struct buffer_view *view);
void buffer_forward_char(struct buffer_view *view);
diff --git a/src/main/bindings.c b/src/main/bindings.c
index ec608fd..0e01306 100644
--- a/src/main/bindings.c
+++ b/src/main/bindings.c
@@ -50,6 +50,8 @@ void set_default_buffer_bindings(struct keymap *keymap) {
BINDING(Ctrl, 'K', "kill-line"),
BINDING(DELETE, "delete-char"),
BINDING(Ctrl, 'D', "delete-char"),
+ BINDING(Meta, 'd', "delete-word"),
+ BINDING(Meta, 'D', "backward-delete-word"),
BINDING(BACKSPACE, "backward-delete-char"),
BINDING(Ctrl, '@', "set-mark"),
diff --git a/src/main/cmds.c b/src/main/cmds.c
index 3b18869..48088b1 100644
--- a/src/main/cmds.c
+++ b/src/main/cmds.c
@@ -415,6 +415,8 @@ void register_global_commands(struct commands *commands,
BUFFER_WRAPCMD_POS(buffer_kill_line);
BUFFER_WRAPCMD_POS(buffer_forward_delete_char);
BUFFER_WRAPCMD_POS(buffer_backward_delete_char);
+BUFFER_WRAPCMD_POS(buffer_forward_delete_word);
+BUFFER_WRAPCMD_POS(buffer_backward_delete_word);
BUFFER_WRAPCMD_POS(buffer_backward_char);
BUFFER_WRAPCMD_POS(buffer_backward_word);
BUFFER_WRAPCMD_POS(buffer_forward_char);
@@ -465,6 +467,8 @@ void register_buffer_commands(struct commands *commands) {
static struct command buffer_commands[] = {
{.name = "kill-line", .fn = buffer_kill_line_cmd},
+ {.name = "delete-word", .fn = buffer_forward_delete_word_cmd},
+ {.name = "backward-delete-word", .fn = buffer_backward_delete_word_cmd},
{.name = "delete-char", .fn = buffer_forward_delete_char_cmd},
{.name = "backward-delete-char", .fn = buffer_backward_delete_char_cmd},
{.name = "backward-char", .fn = buffer_backward_char_cmd},
diff --git a/src/main/main.c b/src/main/main.c
index 3858682..59a9a59 100644
--- a/src/main/main.c
+++ b/src/main/main.c
@@ -112,7 +112,11 @@ void update_file_watches(struct reactor *reactor) {
}
}
-void usage() { printf("TODO: print usage\n"); }
+void usage() {
+ printf("dged - a text editor for datagubbar/datagummor!\n");
+ printf("usage: dged [-l/--line line_number] [-e/--end] [-h/--help] "
+ "[filename]\n");
+}
int main(int argc, char *argv[]) {