From fd708f9e7895f4d094ec0004afa57e4a23bb5252 Mon Sep 17 00:00:00 2001 From: JozanLeClerc Date: Wed, 26 Aug 2020 01:56:47 +0200 Subject: Some tests already --- src/b_sqb_file.c | 43 ++++++++++++++++++++++++++++++++----------- 1 file changed, 32 insertions(+), 11 deletions(-) (limited to 'src/b_sqb_file.c') diff --git a/src/b_sqb_file.c b/src/b_sqb_file.c index d6d07e0..b69f160 100644 --- a/src/b_sqb_file.c +++ b/src/b_sqb_file.c @@ -11,29 +11,50 @@ /* ************************************************************************** */ #include +#include +#include +#include #include -static uint8_t +#include "d_define.h" + +static t_bool b_file_tests_one(uint8_t id, struct stat *st) { - if (id == FT_ID_SQB_B && S_st->st_mode) - return (0); + if (id == FT_ID_SQB_B && S_ISBLK(st->st_mode) == 1) + return (TRUE); + else if (id == FT_ID_SQB_C && S_ISCHR(st->st_mode) == 1) + return (TRUE); + else if (id == FT_ID_SQB_D && S_ISDIR(st->st_mode) == 1) + return (TRUE); + else if (id == FT_ID_SQB_F && S_ISREG(st->st_mode) == 1) + return (TRUE); + else if ((id == FT_ID_SQB_H || id == FT_ID_SQB_L_MAJ) + && S_ISLNK(st->st_mode) == 1) + return (TRUE); + else if (id == FT_ID_SQB_P && S_ISFIFO(st->st_mode) == 1) + return (TRUE); + return (FALSE); } uint8_t - b_sqb_file(uint8_t id, - char *argv[]) + b_sqb_file_tests(uint8_t id, + char *argv[]) { struct stat st; - int32_t fd; - uint8_t ret; + int32_t fd; - ret = 0; - if ((fd = open(argv[1])) == -1) + if ((fd = open(argv[1], O_RDONLY)) == -1) return (1); + if (id == FT_ID_SQB_E) + { + close(fd); + return (0); + } fstat(fd, &st); - ret = b_file_tests_one(id, &st); close(fd); - return (ret); + if (b_file_tests_one(id, &st) == TRUE) + return (0); + return (1); } -- cgit v1.2.3