[gtksourceview/wip/chergert/vim: 129/363] abstract commands a bit
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtksourceview/wip/chergert/vim: 129/363] abstract commands a bit
- Date: Mon, 8 Nov 2021 19:53:48 +0000 (UTC)
commit be4e65c68e21bfeb4335615f843481fb2cd1aaee
Author: Christian Hergert <chergert redhat com>
Date: Fri Oct 29 12:11:43 2021 -0700
abstract commands a bit
and add undo/redo
gtksourceview/vim/gtk-source-vim-command.c | 68 +++++++++++++++++++++++++-----
1 file changed, 58 insertions(+), 10 deletions(-)
---
diff --git a/gtksourceview/vim/gtk-source-vim-command.c b/gtksourceview/vim/gtk-source-vim-command.c
index c1e7e988..01bfa9e6 100644
--- a/gtksourceview/vim/gtk-source-vim-command.c
+++ b/gtksourceview/vim/gtk-source-vim-command.c
@@ -25,6 +25,8 @@
#include "gtk-source-vim-command.h"
+typedef void (*Command) (GtkSourceVimCommand *self);
+
struct _GtkSourceVimCommand
{
GtkSourceVimState parent_instance;
@@ -44,6 +46,7 @@ enum {
};
static GParamSpec *properties[N_PROPS];
+static GHashTable *commands;
static void
gtk_source_vim_command_join (GtkSourceVimCommand *self)
@@ -69,6 +72,42 @@ gtk_source_vim_command_join (GtkSourceVimCommand *self)
gtk_text_buffer_select_range (GTK_TEXT_BUFFER (buffer), &iter, &iter);
}
+static void
+gtk_source_vim_command_undo (GtkSourceVimCommand *self)
+{
+ GtkSourceBuffer *buffer;
+ int count;
+
+ buffer = gtk_source_vim_state_get_buffer (GTK_SOURCE_VIM_STATE (self), NULL, NULL);
+ count = gtk_source_vim_state_get_count (GTK_SOURCE_VIM_STATE (self));
+
+ for (int i = 0; i < count; i++)
+ {
+ if (gtk_text_buffer_get_can_undo (GTK_TEXT_BUFFER (buffer)))
+ {
+ gtk_text_buffer_undo (GTK_TEXT_BUFFER (buffer));
+ }
+ }
+}
+
+static void
+gtk_source_vim_command_redo (GtkSourceVimCommand *self)
+{
+ GtkSourceBuffer *buffer;
+ int count;
+
+ buffer = gtk_source_vim_state_get_buffer (GTK_SOURCE_VIM_STATE (self), NULL, NULL);
+ count = gtk_source_vim_state_get_count (GTK_SOURCE_VIM_STATE (self));
+
+ for (int i = 0; i < count; i++)
+ {
+ if (gtk_text_buffer_get_can_redo (GTK_TEXT_BUFFER (buffer)))
+ {
+ gtk_text_buffer_redo (GTK_TEXT_BUFFER (buffer));
+ }
+ }
+}
+
static void
gtk_source_vim_command_append_command (GtkSourceVimState *state,
GString *string)
@@ -82,11 +121,18 @@ gtk_source_vim_command_repeat (GtkSourceVimState *state)
{
GtkSourceVimCommand *self = (GtkSourceVimCommand *)state;
GtkSourceBuffer *buffer;
+ Command command;
GtkTextIter iter;
GtkTextIter selection;
g_assert (GTK_SOURCE_IS_VIM_COMMAND (self));
+ if (self->command == NULL)
+ return;
+
+ if (!(command = g_hash_table_lookup (commands, self->command)))
+ return;
+
buffer = gtk_source_vim_state_get_buffer (state, &iter, &selection);
if (self->motion)
@@ -102,16 +148,7 @@ gtk_source_vim_command_repeat (GtkSourceVimState *state)
gtk_source_vim_state_select (state, &iter, &selection);
gtk_text_buffer_begin_user_action (GTK_TEXT_BUFFER (buffer));
-
- /* XXX: obviously need to add an abstraction here for
- * registered commands (and possible options on them).
- */
-
- if (g_strcmp0 (self->command, ":join") == 0)
- {
- gtk_source_vim_command_join (self);
- }
-
+ command (self);
gtk_text_buffer_end_user_action (GTK_TEXT_BUFFER (buffer));
}
@@ -223,6 +260,17 @@ gtk_source_vim_command_class_init (GtkSourceVimCommandClass *klass)
(G_PARAM_READWRITE | G_PARAM_EXPLICIT_NOTIFY | G_PARAM_STATIC_STRINGS));
g_object_class_install_properties (object_class, N_PROPS, properties);
+
+ commands = g_hash_table_new (g_str_hash, g_str_equal);
+
+#define ADD_COMMAND(name, func) \
+ g_hash_table_insert(commands, (char*)name, (gpointer)func)
+ ADD_COMMAND (":join", gtk_source_vim_command_join);
+ ADD_COMMAND (":j", gtk_source_vim_command_join);
+ ADD_COMMAND (":undo", gtk_source_vim_command_undo);
+ ADD_COMMAND (":u", gtk_source_vim_command_undo);
+ ADD_COMMAND (":redo", gtk_source_vim_command_redo);
+#undef ADD_COMMAND
}
static void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]