aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/ft_get_darkness.c30
-rw-r--r--src/ft_init_map.c1
-rw-r--r--src/ft_select_get.c2
3 files changed, 32 insertions, 1 deletions
diff --git a/src/ft_get_darkness.c b/src/ft_get_darkness.c
index e9c3966..7f1bc00 100644
--- a/src/ft_get_darkness.c
+++ b/src/ft_get_darkness.c
@@ -10,10 +10,40 @@
/* */
/* ************************************************************************** */
+#include <libft.h>
#include <cub3d.h>
+static int8_t
+ ft_checkdigit(const char *word, t_cub *clist)
+{
+ size_t i;
+
+ i = 0;
+ while (ft_isdigit(word[i]))
+ i++;
+ if (i != ft_strlen(word))
+ {
+ ft_sprintf(clist->errmsg, FT_ERR_SH_ALPHA);
+ return (-1);
+ }
+ return (0);
+}
+
int8_t
ft_get_darkness(char **words, t_cub *clist)
{
+ if (!(*words) || !words[1] || words[2])
+ {
+ ft_sprintf(clist->errmsg, FT_ERR_ARGS);
+ return (-1);
+ }
+ if (ft_checkdigit(words[1], clist))
+ return (-1);
+ if (ft_atoi(words[1]) < 0 || ft_atoi(words[1]) > 10)
+ {
+ ft_sprintf(clist->errmsg, FT_ERR_SH_RANGE);
+ return (-1);
+ }
+ clist->mlist.darklvl = ft_atoi(words[1]);
return (0);
}
diff --git a/src/ft_init_map.c b/src/ft_init_map.c
index 3daa3b7..68a3b6d 100644
--- a/src/ft_init_map.c
+++ b/src/ft_init_map.c
@@ -58,6 +58,7 @@ int8_t
mlist->isctex = 0;
mlist->isnlvl = 0;
mlist->ismusic = 0;
+ mlist->darklvl = 0;
mlist->scale = 0;
mlist->nlx = 0;
mlist->nly = 0;
diff --git a/src/ft_select_get.c b/src/ft_select_get.c
index 64ba14b..2ed439c 100644
--- a/src/ft_select_get.c
+++ b/src/ft_select_get.c
@@ -80,7 +80,7 @@ static int8_t
ret = 0;
while (ft_strncmp(words[0], ref[ret], 3) && ref[ret][0])
ret++;
- if (ret == 11)
+ if (ret == 12)
ret = FT_PARSE_END_RET;
ret = ft_check_exists(ret, clist);
ret = ft_check_exists_two(ret, clist);