summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjoe <rbousset@42lyon.fr>2020-11-30 17:34:00 +0100
committerjoe <rbousset@42lyon.fr>2020-11-30 17:34:00 +0100
commit75bad8f18024e8b4dbb9700329cfb888ae1e3dc3 (patch)
treeb8fe22aa34e578191d165ed2486b272e66e65f5e
parentget normed (diff)
download42-minishell-75bad8f18024e8b4dbb9700329cfb888ae1e3dc3.tar.gz
42-minishell-75bad8f18024e8b4dbb9700329cfb888ae1e3dc3.tar.bz2
42-minishell-75bad8f18024e8b4dbb9700329cfb888ae1e3dc3.tar.xz
42-minishell-75bad8f18024e8b4dbb9700329cfb888ae1e3dc3.tar.zst
42-minishell-75bad8f18024e8b4dbb9700329cfb888ae1e3dc3.zip
In progress
-rw-r--r--src/c_init.c3
-rw-r--r--src/c_init.h5
-rw-r--r--src/s_init_next.c46
3 files changed, 40 insertions, 14 deletions
diff --git a/src/c_init.c b/src/c_init.c
index 2ba73f5..5e09031 100644
--- a/src/c_init.c
+++ b/src/c_init.c
@@ -88,6 +88,9 @@ static short
return (c_end_key(ft_strlen(line), tcaps->plen, tcaps));
else if ((*((unsigned int *)buf)) == CTRL_L)
return (c_ctrl_l(line, tcaps, msh));
+ else if (((*((unsigned int *)buf)) == UP_K) ||
+ ((*((unsigned int *)buf)) == CTRL_P))
+ return (ft_dprintf(0, "qweqwe\n"));
else if ((*((unsigned int *)buf)) == CTRL_D &&
line[0] == '\0')
{
diff --git a/src/c_init.h b/src/c_init.h
index f563df2..a41202d 100644
--- a/src/c_init.h
+++ b/src/c_init.h
@@ -18,8 +18,10 @@
# include "s_struct.h"
-# define LEFT_K 0x445b1b
+# define UP_K 0x415b1b
+# define DOWN_K 0x425b1b
# define RIGHT_K 0x435b1b
+# define LEFT_K 0x445b1b
# define HOME_K 0x485b1b
# define END_K 0x465b1b
# define DEL_K 0x7f
@@ -32,6 +34,7 @@
# define CTRL_E 0x05
# define CTRL_F 0x06
# define CTRL_L 0x0c
+# define CTRL_P 0x10
typedef struct s_caps
{
diff --git a/src/s_init_next.c b/src/s_init_next.c
index 4521ce1..d506d9d 100644
--- a/src/s_init_next.c
+++ b/src/s_init_next.c
@@ -10,16 +10,17 @@
/* */
/* ************************************************************************** */
-#include <libft.h>
-#include <stdlib.h>
-#include <unistd.h>
#include <dirent.h>
#include <errno.h>
+#include <libft.h>
#ifdef __linux__
# include <linux/limits.h>
#else
# include <limits.h>
#endif
+#include <paths.h>
+#include <stdlib.h>
+#include <unistd.h>
#include "b_export_next.h"
#include "f_fail.h"
@@ -27,7 +28,7 @@
#include "u_vars.h"
#include "u_vars_next.h"
-void s_inc_shlvl(t_msh *msh)
+void s_inc_shlvl(t_msh *msh)
{
char fmt[8];
char tmp[255];
@@ -52,7 +53,7 @@ void s_inc_shlvl(t_msh *msh)
}
}
-char **s_dupenv_del(char **nenvp, unsigned long i)
+char **s_dupenv_del(char **nenvp, unsigned long i)
{
while (i > 0)
{
@@ -63,20 +64,37 @@ char **s_dupenv_del(char **nenvp, unsigned long i)
return (NULL);
}
-char **s_dupenv(char *const envp[])
+static char s_cpy_path(char **ptr, char *nenvp[], size_t *i)
+{
+ char tmp[255];
+
+ if (*ptr != NULL)
+ return (0);
+ if (*ptr == NULL)
+ {
+ ft_sprintf(tmp, "PATH=%s", _PATH_STDPATH);
+ if ((nenvp[*i] = ft_strdup(tmp)) == NULL)
+ return (1);
+ *(i) += 1;
+ }
+ return (0);
+}
+
+char **s_dupenv(char *const envp[])
{
- unsigned long i;
- char **nenvp;
+ size_t i;
+ char **nenvp;
+ char **ptr;
+ ptr = (char**)envp;
+ while (*ptr != NULL && ft_strncmp(*ptr, "PATH=", 5) != 0)
+ ptr++;
i = 0;
while (envp[i] != NULL)
- {
i++;
- }
+ i += (*ptr == NULL) ? (1) : (0);
if ((nenvp = (char**)malloc((i + 1) * sizeof(char*))) == NULL)
- {
return (NULL);
- }
i = 0;
while (envp[i] != NULL)
{
@@ -84,11 +102,13 @@ char **s_dupenv(char *const envp[])
return (s_dupenv_del(nenvp, i));
i++;
}
+ if (s_cpy_path(ptr, nenvp, &i) == 1)
+ return (s_dupenv_del(nenvp, i));
nenvp[i] = NULL;
return (nenvp);
}
-void s_set_cwd(char cwd[], t_msh *msh)
+void s_set_cwd(char cwd[], t_msh *msh)
{
char fmt[PATH_MAX];
DIR *dir;