aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/wreadln.c44
1 files changed, 25 insertions, 19 deletions
diff --git a/src/wreadln.c b/src/wreadln.c
index d68185a7e..f10b8c23f 100644
--- a/src/wreadln.c
+++ b/src/wreadln.c
@@ -117,6 +117,29 @@ static inline void drawline(const struct wreadln *wr)
doupdate();
}
+static void
+wreadln_insert_byte(struct wreadln *wr, gint key)
+{
+ if (strlen(wr->line + wr->cursor)) { /* if the cursor is */
+ /* not at the last pos */
+ gchar *tmp = NULL;
+ gsize rest = strlen(wr->line + wr->cursor) + 1;
+
+ tmp = g_malloc0(rest);
+ g_strlcpy (tmp, wr->line + wr->cursor, rest);
+ wr->line[wr->cursor] = key;
+ wr->line[wr->cursor + 1] = 0;
+ g_strlcat(&wr->line[wr->cursor + 1], tmp, rest);
+ g_free(tmp);
+ cursor_move_right(wr);
+ } else {
+ wr->line[wr->cursor + 1] = 0;
+ wr->line[wr->cursor] = key;
+ }
+
+ cursor_move_right(wr);
+}
+
/* libcurses version */
static gchar *
@@ -308,25 +331,8 @@ _wreadln(WINDOW *w,
/* ignore char */
break;
default:
- if (key >= 32) {
- if (strlen(wr.line + wr.cursor)) { /* if the cursor is */
- /* not at the last pos */
- gchar *tmp = NULL;
- gsize size = strlen(wr.line + wr.cursor) + 1;
-
- tmp = g_malloc0(size);
- g_strlcpy (tmp, wr.line + wr.cursor, size);
- wr.line[wr.cursor] = key;
- wr.line[wr.cursor + 1] = 0;
- g_strlcat(&wr.line[wr.cursor + 1], tmp, size);
- g_free(tmp);
- cursor_move_right(&wr);
- } else {
- wr.line[wr.cursor + 1] = 0;
- wr.line[wr.cursor] = key;
- cursor_move_right(&wr);
- }
- }
+ if (key >= 32)
+ wreadln_insert_byte(&wr, key);
}
drawline(&wr);