From 3ab54c00fd08f02f246488629442866c8eb604b1 Mon Sep 17 00:00:00 2001 From: salad Date: Fri, 18 Sep 2020 14:51:08 +0200 Subject: full bugged, mais full features --- src/c_keys.c | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) (limited to 'src/c_keys.c') diff --git a/src/c_keys.c b/src/c_keys.c index d388d60..7874932 100644 --- a/src/c_keys.c +++ b/src/c_keys.c @@ -60,9 +60,16 @@ int16_t int16_t c_key_right(uint32_t len, + uint32_t plen, t_caps *tcaps) { - if (tcaps->cpos < len) + if (((tcaps->cpos + 1) % (tcaps->ws.ws_col - plen)) == 0 && tcaps->cpos < len) + { + tputs(tgetstr("do", NULL), 1, ft_putchar); + tputs(tgetstr("cr", NULL), 1, ft_putchar); + tcaps->cpos++; + } + else if (tcaps->cpos < len) { tputs(tgetstr("nd", NULL), 1, ft_putchar); tcaps->cpos++; @@ -72,9 +79,20 @@ int16_t int16_t c_key_left(uint32_t len, + uint32_t plen, t_caps *tcaps) { + int32_t pos; (void)len; + + pos = -1; + if (((tcaps->cpos) % (tcaps->ws.ws_col - plen)) == 0 && tcaps->cpos >= 1) + { + tputs(tgetstr("up", NULL), 1, ft_putchar); + while(++pos <= (tcaps->ws.ws_col)) + tputs(tgetstr("nd", NULL), 1, ft_putchar); + tcaps->cpos--; + } if (tcaps->cpos >= 1) { tputs(tgetstr("le", NULL), 1, ft_putchar); -- cgit v1.2.3