From 7df3f33f3c644e53577b53fed433bfe9a4ff0715 Mon Sep 17 00:00:00 2001 From: JozanLeClerc Date: Sat, 15 Aug 2020 18:20:23 +0200 Subject: Error handling ok --- Makefile | 1 + src/f_com.c | 3 ++- src/f_fail.h | 1 + src/f_file.c | 31 +++++++++++++++++++++++++++++++ src/f_file.h | 20 ++++++++++++++++++++ src/m_argv.c | 3 ++- 6 files changed, 57 insertions(+), 2 deletions(-) create mode 100644 src/f_file.c create mode 100644 src/f_file.h diff --git a/Makefile b/Makefile index 5d2aa3f..54f85fc 100644 --- a/Makefile +++ b/Makefile @@ -36,6 +36,7 @@ SRCS_NAME += f_chdir SRCS_NAME += f_com SRCS_NAME += f_errno SRCS_NAME += f_fail +SRCS_NAME += f_file SRCS_NAME += f_redir SRCS_NAME += f_shlvl SRCS_NAME += m_argv diff --git a/src/f_com.c b/src/f_com.c index 9c4e02a..5ca03eb 100644 --- a/src/f_com.c +++ b/src/f_com.c @@ -19,5 +19,6 @@ void f_fail_command_not_found(const char command[]) { - ft_dprintf(STDERR_FILENO, "%s: %s: %s\n", "minishell", command, FT_FAIL_COMMAND_NOT_FOUND); + ft_dprintf(STDERR_FILENO, "%s: %s: %s\n", "minishell", command, + FT_FAIL_COMMAND_NOT_FOUND); } diff --git a/src/f_fail.h b/src/f_fail.h index b1b3b8c..dfb46e3 100644 --- a/src/f_fail.h +++ b/src/f_fail.h @@ -17,6 +17,7 @@ #include "f_alloc.h" #include "f_chdir.h" #include "f_errno.h" +#include "f_file.h" #include "f_redir.h" #include "f_shlvl.h" #include "s_struct.h" diff --git a/src/f_file.c b/src/f_file.c new file mode 100644 index 0000000..c26596c --- /dev/null +++ b/src/f_file.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* f_file.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include +#include +#include +#include +#include + +#include "s_destroy.h" +#include "s_struct.h" + +void + f_open_file(char filename[], + t_msh *msh) +{ + ft_dprintf(STDERR_FILENO, "%s: %s: %s\n", msh->shname, + filename, + strerror(errno)); + s_destroy(msh); + exit(127); +} diff --git a/src/f_file.h b/src/f_file.h new file mode 100644 index 0000000..f34f038 --- /dev/null +++ b/src/f_file.h @@ -0,0 +1,20 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* f_file.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef F_FILE_H +#define F_FILE_H + +#include "s_struct.h" + +void f_open_file(char filename[], t_msh *msh); + +#endif diff --git a/src/m_argv.c b/src/m_argv.c index 1e23bae..0c32e3b 100644 --- a/src/m_argv.c +++ b/src/m_argv.c @@ -15,6 +15,7 @@ #include #include +#include "f_fail.h" #include "d_define.h" #include "m_comm.h" #include "m_loop.h" @@ -44,7 +45,7 @@ uint8_t else { if ((fd = open(*(argv + 1), O_RDONLY)) < 0) - f_open_file(msh); + f_open_file(*(argv + 1), msh); msh->ret = m_loop(fd, msh); close(fd); } -- cgit v1.2.3