summaryrefslogtreecommitdiffstats
path: root/src/c_utils_next.c
diff options
context:
space:
mode:
authorJozanLeClerc <bousset.rudy@gmail.com>2020-12-18 16:04:14 +0100
committerJozanLeClerc <bousset.rudy@gmail.com>2020-12-18 16:04:14 +0100
commit7629736298b29ad5be833c11d338ab3abe236917 (patch)
tree8c4161357ae75109bcc7b8bf38bcd8b985ea3774 /src/c_utils_next.c
parentMerge (diff)
parentPush (diff)
download42-minishell-7629736298b29ad5be833c11d338ab3abe236917.tar.gz
42-minishell-7629736298b29ad5be833c11d338ab3abe236917.tar.bz2
42-minishell-7629736298b29ad5be833c11d338ab3abe236917.tar.xz
42-minishell-7629736298b29ad5be833c11d338ab3abe236917.tar.zst
42-minishell-7629736298b29ad5be833c11d338ab3abe236917.zip
Merged branch 'gnu-compat'
Diffstat (limited to 'src/c_utils_next.c')
-rw-r--r--src/c_utils_next.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/c_utils_next.c b/src/c_utils_next.c
new file mode 100644
index 0000000..27a88db
--- /dev/null
+++ b/src/c_utils_next.c
@@ -0,0 +1,55 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* c_utils_next.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */
+/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */
+/* */
+/* ************************************************************************** */
+
+#include <libft.h>
+#include <stddef.h>
+#include <term.h>
+
+#include "c_init.h"
+#include "c_keys.h"
+#include "c_utils.h"
+#include "d_define.h"
+
+short c_set_key(char *buf)
+{
+ if (((*((unsigned int *)buf)) == UP_K) ||
+ ((*((unsigned int *)buf)) == CTRL_P))
+ return (-1);
+ else
+ return (1);
+}
+
+t_msh *c_get_msh(int mode, t_msh *src)
+{
+ static t_msh *msh;
+
+ if (mode == 1)
+ {
+ msh = src;
+ }
+ return (msh);
+}
+
+void c_key_up_down(char *line[], t_caps *tcaps, t_msh *msh)
+{
+ char tmp[ARG_MAX];
+ char *ptr;
+
+ ptr = c_set_ptr(FALSE, tcaps->key, msh);
+ c_home_key(tcaps->plen, tcaps);
+ ft_substr_s(tmp, ptr, 0, ft_strclen(ptr, '\n'));
+ ft_memdel((void*)&(*line));
+ tputs(tgetstr("ce", NULL), 1, ft_putchar);
+ *line = ft_strdup(tmp);
+ tcaps->cpos = ft_strlen(*line);
+ c_redraw_line(*line, tcaps);
+}