summaryrefslogtreecommitdiffstats
path: root/src/b_sqb_err.c
diff options
context:
space:
mode:
authorsalad <fmoenne-@student.le-101.fr>2020-10-26 13:42:56 +0100
committersalad <fmoenne-@student.le-101.fr>2020-10-26 13:42:56 +0100
commit0277ddfac754ab4ad5bdd2b692e31a717efbe569 (patch)
tree49d7c5fd3a12248af85e2c3a3254bc1538ae5775 /src/b_sqb_err.c
parentreqdy for MERGE (diff)
parentTODO update (diff)
download42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.tar.gz
42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.tar.bz2
42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.tar.xz
42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.tar.zst
42-minishell-0277ddfac754ab4ad5bdd2b692e31a717efbe569.zip
merge wif master
Diffstat (limited to 'src/b_sqb_err.c')
-rw-r--r--src/b_sqb_err.c113
1 files changed, 113 insertions, 0 deletions
diff --git a/src/b_sqb_err.c b/src/b_sqb_err.c
new file mode 100644
index 0000000..6c68841
--- /dev/null
+++ b/src/b_sqb_err.c
@@ -0,0 +1,113 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* b_sqb_err.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */
+/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */
+/* */
+/* ************************************************************************** */
+
+#include <libft.h>
+#include <stdint.h>
+#include <unistd.h>
+
+#include "d_define.h"
+#include "u_utils.h"
+
+static uint8_t
+ b_single_op(const uint64_t argc,
+ char *argv[])
+{
+ if (argc > 3)
+ {
+ ft_dprintf(STDERR_FILENO, "[: %s: unexpected operator\n", argv[1]);
+ return (1);
+ }
+ return (0);
+}
+
+static uint8_t
+ b_expect_arg(const uint64_t argc,
+ char *argv[])
+{
+ if (argc == 3)
+ {
+ ft_dprintf(STDERR_FILENO, "[: %s: argument expected\n", argv[1]);
+ return (1);
+ }
+ return (0);
+}
+
+static uint8_t
+ b_double_op(const uint64_t argc,
+ char *argv[])
+{
+ if (argc > 4)
+ {
+ ft_dprintf(STDERR_FILENO, "[: %s: unexpected operator\n", argv[2]);
+ return (1);
+ }
+ return (0);
+}
+
+static uint8_t
+ b_bad_nbr(char *argv[])
+{
+ char *ptr;
+
+ if (ft_ischarset("+-0123456789", argv[0][0]) == FALSE ||
+ ft_ischarset("+-0123456789", argv[2][0]) == FALSE)
+ return (1);
+ ptr = argv[0] + 1;
+ while (*ptr != '\0')
+ {
+ if (ft_isdigit(*ptr) == FALSE)
+ {
+ ft_dprintf(STDERR_FILENO, "[: %s: bad number\n", argv[0]);
+ return (1);
+ }
+ ptr++;
+ }
+ ptr = argv[2] + 1;
+ while (*ptr != '\0')
+ {
+ if (ft_isdigit(*ptr) == FALSE)
+ ft_dprintf(STDERR_FILENO, "[: %s: bad number\n", argv[2]);
+ if (ft_isdigit(*ptr) == FALSE)
+ return (1);
+ ptr++;
+ }
+ return (0);
+}
+
+uint8_t
+ b_sqb_err_check(uint8_t id,
+ char *argv[])
+{
+ const uint64_t argc = u_builtins_get_argc((const char**)argv);
+
+ if (id >= FT_ID_SQB_NT)
+ {
+ if (b_expect_arg(argc, argv) != 0)
+ return (1);
+ }
+ if (id >= FT_ID_SQB_EQ)
+ {
+ if (b_bad_nbr(argv) != 0)
+ return (1);
+ }
+ if (id < FT_ID_SQB_NT)
+ {
+ if (b_single_op(argc, argv) != 0)
+ return (1);
+ }
+ else if (id >= FT_ID_SQB_NT)
+ {
+ if (b_double_op(argc, argv) != 0)
+ return (1);
+ }
+ return (0);
+}