summaryrefslogtreecommitdiffstats
path: root/src/e_externs_next.c
diff options
context:
space:
mode:
authorJozanLeClerc <bousset.rudy@gmail.com>2020-09-15 19:59:41 +0200
committerJozanLeClerc <bousset.rudy@gmail.com>2020-09-15 19:59:41 +0200
commitca2e36781039eb7e9901ccde395600e7af87ff4f (patch)
tree8a9d85433e943fbbd079bc55700e048a54d9bf24 /src/e_externs_next.c
parenttype builtin fix (diff)
download42-minishell-ca2e36781039eb7e9901ccde395600e7af87ff4f.tar.gz
42-minishell-ca2e36781039eb7e9901ccde395600e7af87ff4f.tar.bz2
42-minishell-ca2e36781039eb7e9901ccde395600e7af87ff4f.tar.xz
42-minishell-ca2e36781039eb7e9901ccde395600e7af87ff4f.tar.zst
42-minishell-ca2e36781039eb7e9901ccde395600e7af87ff4f.zip
Huge fixes and stack stuff
Diffstat (limited to '')
-rw-r--r--src/e_externs_next.c102
1 files changed, 0 insertions, 102 deletions
diff --git a/src/e_externs_next.c b/src/e_externs_next.c
deleted file mode 100644
index ed3ee84..0000000
--- a/src/e_externs_next.c
+++ /dev/null
@@ -1,102 +0,0 @@
-/* ************************************************************************** */
-/* */
-/* ::: :::::::: */
-/* e_externs_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 <dirent.h>
-#include <stdlib.h>
-#include <stddef.h>
-
-#include "f_fail.h"
-#include "s_destroy.h"
-#include "s_line.h"
-#include "s_struct.h"
-#include "u_utils.h"
-
-static char
- *get_fullpath(const char p_path[],
- const char d_name[],
- t_msh *msh)
-{
- char *fullpath;
- const size_t path_len = ft_strlen(p_path);
- const size_t name_len = ft_strlen(d_name);
-
- if (!(fullpath = (char*)malloc((path_len + name_len + 2) * sizeof(char))))
- {
- f_alloc_and_destroy_msh(msh);
- }
- (void)ft_memcpy(fullpath, p_path, path_len);
- *(fullpath + (path_len)) = '/';
- (void)ft_memcpy(fullpath + path_len + 1, d_name, name_len);
- *(fullpath + (path_len + name_len + 1)) = '\0';
- return (fullpath);
-}
-
-char
- *search_in_path(const char com[],
- char *envpath[],
- t_msh *msh)
-{
- struct dirent *ent;
- char **p_path;
- char *fullpath;
- DIR *dir;
-
- p_path = envpath;
- while (*p_path)
- {
- if ((dir = opendir(*p_path)) != NULL)
- {
- while ((ent = readdir(dir)) != NULL)
- {
- /* TODO: check for not bins (dirs, etc) */
- if (ft_strncmp(com, ent->d_name, ft_strlen(com) + 1) == 0)
- {
- fullpath = get_fullpath(*p_path, ent->d_name, msh);
- closedir(dir);
- return (fullpath);
- }
- }
- closedir(dir);
- }
- p_path++;
- }
- return (NULL);
-}
-
-char
- **get_env_path(t_msh *msh)
-{
- size_t i;
- char **env_dup;
- char **envpath;
- char *envline;
-
- env_dup = u_get_env_var_names(msh);
- i = 0;
- while (env_dup[i] && ft_strncmp("PATH", env_dup[i], 5) != 0)
- i++;
- if (env_dup[i] == NULL)
- return (NULL);
- ft_delwords(env_dup);
- envline = ft_strchr(msh->envp[i], '=');
- envline += 1;
- if (*envline != '\0')
- {
- if ((envpath = ft_split(envline, ':')) == NULL)
- {
- f_alloc_and_destroy_msh(msh);
- }
- return (envpath);
- }
- return (NULL);
-}