summaryrefslogtreecommitdiffstats
path: root/src/c_init.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/c_init.c45
1 files changed, 39 insertions, 6 deletions
diff --git a/src/c_init.c b/src/c_init.c
index 2c0b7c3..401d0e2 100644
--- a/src/c_init.c
+++ b/src/c_init.c
@@ -20,6 +20,31 @@
#include "c_init.h"
+static char
+ *ft_strjoin_m(char *s1,
+ char *s2)
+{
+ size_t i;
+ size_t j;
+ char *dst;
+ size_t size1;
+ size_t size2;
+
+ i = -1;
+ j = -1;
+ size1 = ft_strlen(s1);
+ size2 = ft_strlen(s2);
+ if (!(dst = (char*)malloc((size1 + size2 + 1) * sizeof(char))))
+ return (NULL);
+ while (++i < size1)
+ dst[i] = s1[i];
+ while (++j < size2)
+ dst[i + j] = s2[j];
+ dst[i + j] = '\0';
+ ft_memdel((void*)&s1);
+ return (dst);
+}
+
t_caps
*c_get_struct(int mode, t_caps *src)
{
@@ -55,27 +80,35 @@ int16_t
return (1);
}
-int16_t c_process_key(char *buf)
+int16_t
+ c_process_key(char *buf)
{
int i;
+ static char *line;
- /* tputs(tgetstr("cl", NULL), 1, ft_putchar); */
- i = 0;
-
+ i = -1;
+ if (line == NULL)
+ if (!(line = ft_calloc(2, sizeof(char))))
+ return (0);
if (ft_isprint(buf[0]))
{
if (*buf == 'q')
exit(0);
- write(1, buf, 1);
+ line = ft_strjoin_m(line, buf);
+ ft_printf("line [%s][%lu]\n", line, ft_strlen(line));
}
else
{
- ft_printf("escaped char inc,[%c] [%c] [%c]\n", buf[0], buf[1], buf[2]);
if(strncmp(buf, tgetstr("kr", NULL), ft_strlen(tgetstr("kr", NULL))) == 0)
{
tputs(tgetstr("nd", NULL), 1, ft_putchar);
return (1);
}
+ else if(strncmp(buf, tgetstr("kl", NULL), ft_strlen(tgetstr("kl", NULL))) == 0)
+ {
+ tputs(tgetstr("le", NULL), 1, ft_putchar);
+ return (1);
+ }
}
return (0);
}