extract into helper for norminette
This commit is contained in:
parent
abdab3156c
commit
e366689f91
@ -12,15 +12,10 @@
|
||||
|
||||
#include "minishell.h"
|
||||
|
||||
char *executor_absolute_path(t_minishell *msh, char *cmd)
|
||||
static char *resolve_relative(t_minishell *msh, char *cmd)
|
||||
{
|
||||
char **path;
|
||||
t_environment *path_env;
|
||||
char *executable;
|
||||
int i;
|
||||
|
||||
if (cmd[0] == '/' || cmd[0] == '.')
|
||||
{
|
||||
if (access(cmd, F_OK) == 0)
|
||||
{
|
||||
executable = ft_strdup_safe(msh, cmd);
|
||||
@ -30,6 +25,30 @@ char *executor_absolute_path(t_minishell *msh, char *cmd)
|
||||
}
|
||||
return (NULL);
|
||||
}
|
||||
|
||||
static char *resolve_path(t_minishell *msh, char *path, char *cmd)
|
||||
{
|
||||
char *executable;
|
||||
|
||||
executable = malloc_safe(msh, ft_strlen(path) + ft_strlen(cmd) + 2);
|
||||
ft_strlcpy(executable, path, ft_strlen(path) + 1);
|
||||
ft_strlcat(executable, "/", ft_strlen(path) + 2);
|
||||
ft_strlcat(executable, cmd, ft_strlen(path) + ft_strlen(cmd) + 2);
|
||||
if (access(executable, F_OK) == 0)
|
||||
return (executable);
|
||||
free_safe(msh, (void **)&executable);
|
||||
return (NULL);
|
||||
}
|
||||
|
||||
char *executor_absolute_path(t_minishell *msh, char *cmd)
|
||||
{
|
||||
char **path;
|
||||
t_environment *path_env;
|
||||
char *executable;
|
||||
int i;
|
||||
|
||||
if (cmd[0] == '/' || cmd[0] == '.')
|
||||
return (resolve_relative(msh, cmd));
|
||||
path_env = environment_get(msh, "PATH");
|
||||
if (!path_env)
|
||||
return (NULL);
|
||||
@ -37,16 +56,9 @@ char *executor_absolute_path(t_minishell *msh, char *cmd)
|
||||
i = 0;
|
||||
while (path[i] != NULL)
|
||||
{
|
||||
executable = malloc_safe(msh, ft_strlen(path[i]) + ft_strlen(cmd) + 2);
|
||||
ft_strlcpy(executable, path[i], ft_strlen(path[i]) + 1);
|
||||
ft_strlcat(executable, "/", ft_strlen(path[i]) + 2);
|
||||
ft_strlcat(executable, cmd, ft_strlen(path[i]) + ft_strlen(cmd) + 2);
|
||||
if (access(executable, F_OK) == 0)
|
||||
{
|
||||
ft_free_arr(path);
|
||||
executable = resolve_path(msh, path[i], cmd);
|
||||
if (executable)
|
||||
return (executable);
|
||||
}
|
||||
free_safe(msh, (void **)&executable);
|
||||
i++;
|
||||
}
|
||||
return (ft_free_arr(path), NULL);
|
||||
|
||||
Loading…
Reference in New Issue
Block a user