diff options
author | salad <fmoenne-@student.le-101.fr> | 2020-10-26 13:42:56 +0100 |
---|---|---|
committer | salad <fmoenne-@student.le-101.fr> | 2020-10-26 13:42:56 +0100 |
commit | 0277ddfac754ab4ad5bdd2b692e31a717efbe569 (patch) | |
tree | 49d7c5fd3a12248af85e2c3a3254bc1538ae5775 /src/u_path.c | |
parent | reqdy for MERGE (diff) | |
parent | TODO update (diff) | |
download | 42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.tar.gz 42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.tar.bz2 42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.tar.xz 42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.tar.zst 42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.zip |
merge wif master
Diffstat (limited to 'src/u_path.c')
-rw-r--r-- | src/u_path.c | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/src/u_path.c b/src/u_path.c new file mode 100644 index 0000000..b43946f --- /dev/null +++ b/src/u_path.c @@ -0,0 +1,72 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* u_path.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 <dirent.h> +#include <limits.h> + +#include "s_struct.h" +#include "u_vars.h" + +static void u_get_fullpath(char fullpath[], + const char p_path[], + const char d_name[], + size_t dstsize) +{ + const size_t path_len = ft_strlen(p_path); + const size_t name_len = ft_strlen(d_name); + + fullpath[0] = C_NUL; + if (path_len + name_len < dstsize) + { + (void)ft_memcpy(fullpath, p_path, path_len); + *(fullpath + (path_len)) = '/'; + ft_memcpy(fullpath + path_len + 1, d_name, name_len); + *(fullpath + (path_len + name_len + 1)) = '\0'; + } +} + +uint8_t u_search_in_path(char fullpath[], + const char com[], + size_t dstsize, + t_msh *msh) +{ + struct dirent *ent; + char tmp[ARG_MAX]; + char *tok_path; + DIR *dir; + + if (u_get_var_value(tmp, "$PATH", ARG_MAX, msh) != 0) + return (1); + tok_path = ft_strtok(tmp, ":"); + while (tok_path != NULL) + { + if ((dir = opendir(tok_path)) != NULL) + { + while ((ent = readdir(dir)) != NULL) + { + if (ft_strncmp(com, ent->d_name, ft_strlen(com) + 1) == 0) + { + u_get_fullpath(fullpath, tok_path, ent->d_name, dstsize); + closedir(dir); + if (fullpath[0] == C_NUL) + return (1); + return (0); + } + } + closedir(dir); + } + tok_path = ft_strtok(NULL, ":"); + } + return (1); +} |