summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/ft_b_type.c72
-rw-r--r--src/ft_e_externs_next.c1
2 files changed, 57 insertions, 16 deletions
diff --git a/src/ft_b_type.c b/src/ft_b_type.c
index f6601d8..4338b32 100644
--- a/src/ft_b_type.c
+++ b/src/ft_b_type.c
@@ -12,13 +12,37 @@
#include <libft.h>
#include <stdint.h>
+#include <dirent.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include "ft_f_fail.h"
+#include "ft_s_lcom.h"
#include "ft_s_struct.h"
#include "ft_e_externs_next.h"
#include "ft_u_utils.h"
+static int8_t
+ ft_absolute_path_exists(char com[])
+{
+ int32_t fd;
+ DIR *dir;
+
+ if ((dir = opendir(com)) != NULL)
+ {
+ closedir(dir);
+ return (0);
+ }
+ if ((fd = open(com, O_RDONLY)) != -1)
+ {
+ close(fd);
+ return (1);
+ }
+ return (0);
+}
+
static char
- *ft_type_get_path(char *com,
+ *ft_type_get_path(char com[],
t_msh *msh)
{
char **envpath;
@@ -28,7 +52,16 @@ static char
fullpath = NULL;
if (ft_ischarset("/.", com[0]))
{
- /* TODO: ft_get_absolute_path(ptr->com); */
+ if (ft_absolute_path_exists(com))
+ {
+ if (!(fullpath = ft_strdup(com)))
+ {
+ ft_lcom_clear(&msh->curr);
+ ft_fail_alloc(msh);
+ }
+ return (fullpath);
+ }
+ return (NULL);
}
else if ((envpath = ft_get_env_path(msh)) != NULL)
{
@@ -38,19 +71,37 @@ static char
return (fullpath);
}
+static uint8_t
+ ft_chk_nonbuilt(char **ptr,
+ t_msh *msh)
+{
+ char *fullpath;
+ int32_t ret;
+
+ ret = 0;
+ fullpath = ft_type_get_path(*ptr, msh);
+ if (fullpath)
+ ft_printf("%s is %s\n", *ptr, fullpath);
+ else
+ {
+ ft_printf("minishell: type: %s: not found\n", *ptr);
+ ret = 1;
+ }
+ ft_memdel((void*)&fullpath);
+ return (ret);
+}
+
uint8_t
ft_b_type(char *args[],
t_msh *msh)
{
- /* TODO: norme */
char **ptr;
char **p_bu;
- char *fullpath;
int32_t ret;
ptr = args;
if (!*ptr)
- return (1);
+ return (0);
ret = 0;
while (*ptr)
{
@@ -61,18 +112,9 @@ uint8_t
ft_printf("%s is a shell builtin\n", *ptr);
else
{
- fullpath = ft_type_get_path(*ptr, msh);
- if (fullpath)
- ft_printf("%s is %s\n", *ptr, fullpath);
- else
- {
- ft_printf("minishell: type: %s: not found\n", *ptr);
- ret = 1;
- }
- ft_memdel((void*)&fullpath);
+ ret = ft_chk_nonbuilt(ptr, msh);
}
ptr++;
}
- /* TODO: finish type */
return (ret);
}
diff --git a/src/ft_e_externs_next.c b/src/ft_e_externs_next.c
index ab5f150..36bf5e6 100644
--- a/src/ft_e_externs_next.c
+++ b/src/ft_e_externs_next.c
@@ -53,7 +53,6 @@ char
char *fullpath;
DIR *dir;
- (void)com;
p_path = envpath;
while (*p_path)
{