return true;
}
-gboolean command_history(const Arg *arg)
-{
- char *input = vb_get_input_text();
- char *entry = history_get(input, arg->i);
- g_free(input);
-
- if (!entry) {
- return false;
- }
-
- vb_echo_force(VB_MSG_NORMAL, false, "%s", entry);
- g_free(entry);
-
- return true;
-}
-
gboolean command_yank(const Arg *arg)
{
static char *tmpl = "Yanked: %s";
#endif
gboolean command_search(const Arg *arg);
-gboolean command_history(const Arg *arg);
gboolean command_yank(const Arg *arg);
gboolean command_save(const Arg *arg);
#ifdef FEATURE_QUEUE
static gboolean ex_complete(short direction);
static void ex_completion_select(char *match);
+static gboolean ex_history(short direction);
/* The order of following command names is significant. If there exists
* ambiguous commands matching to the users input, the first defined will be
break;
case CTRL('P'): /* up */
- /* TODO don't emit input change event when stepping though history in search mode */
- command_history(&((Arg){1}));
+ ex_history(-1);
break;
case CTRL('N'): /* down */
- command_history(&((Arg){0}));
+ ex_history(1);
break;
/* basic command line editing */
}
vb_set_input_text(excomp.current);
}
+
+static gboolean ex_history(short direction)
+{
+ char *input = vb_get_input_text();
+ char *entry = history_get(input, direction < 0);
+ g_free(input);
+
+ if (entry) {
+ vb_set_input_text(entry);
+ g_free(entry);
+
+ return true;
+ }
+
+ return false;
+}