Improved arithmetic comprehension
This commit is contained in:
parent
32941a0c7e
commit
5402ec152a
5 changed files with 53 additions and 9 deletions
4
Makefile
4
Makefile
|
|
@ -1,4 +1,4 @@
|
||||||
# **************************************************************************** #
|
# **************************************************************************** #make
|
||||||
# #
|
# #
|
||||||
# ::: :::::::: #
|
# ::: :::::::: #
|
||||||
# Makefile :+: :+: :+: #
|
# Makefile :+: :+: :+: #
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
# By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ #
|
# By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ #
|
||||||
# +#+#+#+#+#+ +#+ #
|
# +#+#+#+#+#+ +#+ #
|
||||||
# Created: 2023/11/12 11:05:05 by rparodi #+# #+# #
|
# Created: 2023/11/12 11:05:05 by rparodi #+# #+# #
|
||||||
# Updated: 2024/07/03 20:37:35 by maiboyer ### ########.fr #
|
# Updated: 2024/07/17 17:05:25 by rparodi ### ########.fr #
|
||||||
# #
|
# #
|
||||||
# **************************************************************************** #
|
# **************************************************************************** #
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/06/11 14:23:40 by maiboyer #+# #+# */
|
/* Created: 2024/06/11 14:23:40 by maiboyer #+# #+# */
|
||||||
/* Updated: 2024/07/21 16:28:16 by maiboyer ### ########.fr */
|
/* Updated: 2024/07/21 17:42:37 by rparodi ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -19,7 +19,8 @@
|
||||||
enum e_ast_node_kind
|
enum e_ast_node_kind
|
||||||
{
|
{
|
||||||
AST_ARITHMETIC_BINARY,
|
AST_ARITHMETIC_BINARY,
|
||||||
AST_ARITHMETIC_EXPANSION,
|
AST_ARITHMETIC_EXPANSION, //RAPH
|
||||||
|
AST_ARITHMETIC_LITTERAL, //RAPH
|
||||||
AST_CASE,
|
AST_CASE,
|
||||||
AST_CASE_ITEM,
|
AST_CASE_ITEM,
|
||||||
AST_COMMAND,
|
AST_COMMAND,
|
||||||
|
|
@ -50,7 +51,8 @@ enum e_ast_node_kind
|
||||||
union u_ast_node_data
|
union u_ast_node_data
|
||||||
{
|
{
|
||||||
t_ast_arithmetic_binary arithmetic_binary;
|
t_ast_arithmetic_binary arithmetic_binary;
|
||||||
t_ast_arithmetic_expansion arithmetic_expansion;
|
t_ast_arithmetic_literal arithmetic_literal; //RAPH
|
||||||
|
t_ast_arithmetic_expansion arithmetic_expansion; //RAPH
|
||||||
t_ast_case case_;
|
t_ast_case case_;
|
||||||
t_ast_case_item case_item;
|
t_ast_case_item case_item;
|
||||||
t_ast_command command;
|
t_ast_command command;
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/06/11 14:24:24 by maiboyer #+# #+# */
|
/* Created: 2024/06/11 14:24:24 by maiboyer #+# #+# */
|
||||||
/* Updated: 2024/07/21 16:26:36 by maiboyer ### ########.fr */
|
/* Updated: 2024/07/21 17:43:13 by rparodi ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -25,6 +25,7 @@ typedef union u_ast_node_data t_ast_node_data;
|
||||||
typedef struct s_ast_node *t_ast_node;
|
typedef struct s_ast_node *t_ast_node;
|
||||||
|
|
||||||
typedef struct s_ast_arithmetic_expansion t_ast_arithmetic_expansion;
|
typedef struct s_ast_arithmetic_expansion t_ast_arithmetic_expansion;
|
||||||
|
typedef struct s_ast_arithmetic_literal t_ast_arithmetic_literal;
|
||||||
typedef struct s_ast_arithmetic_binary t_ast_arithmetic_binary;
|
typedef struct s_ast_arithmetic_binary t_ast_arithmetic_binary;
|
||||||
typedef struct s_ast_case t_ast_case;
|
typedef struct s_ast_case t_ast_case;
|
||||||
typedef struct s_ast_case_item t_ast_case_item;
|
typedef struct s_ast_case_item t_ast_case_item;
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/06/14 17:46:58 by maiboyer #+# #+# */
|
/* Created: 2024/06/14 17:46:58 by maiboyer #+# #+# */
|
||||||
/* Updated: 2024/07/21 16:26:17 by maiboyer ### ########.fr */
|
/* Updated: 2024/07/21 17:46:08 by rparodi ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -45,6 +45,7 @@ enum e_ast_arithmetic_operator
|
||||||
ARITH_MINUS,
|
ARITH_MINUS,
|
||||||
ARITH_DIVIDE,
|
ARITH_DIVIDE,
|
||||||
ARITH_MULT,
|
ARITH_MULT,
|
||||||
|
ARITH_MOD,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
@ -424,6 +425,17 @@ struct s_ast_arithmetic_binary
|
||||||
t_ast_node rhs;
|
t_ast_node rhs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// NUMBER
|
||||||
|
/*struct s_ast_arithmetic_literal*/
|
||||||
|
/*{*/
|
||||||
|
/* t_i64 value;*/
|
||||||
|
/*};*/
|
||||||
|
|
||||||
|
// RAPH
|
||||||
|
struct s_ast_arithmetic_literal
|
||||||
|
{
|
||||||
|
t_ast_node value;
|
||||||
|
};
|
||||||
/// Command Substitution
|
/// Command Substitution
|
||||||
/// ```shell
|
/// ```shell
|
||||||
/// $(command)
|
/// $(command)
|
||||||
|
|
|
||||||
|
|
@ -584,7 +584,8 @@ t_ast_arithmetic_operator _parse_operator(t_parse_node self)
|
||||||
return (ARITH_MULT);
|
return (ARITH_MULT);
|
||||||
if (symbol == anon_sym_SLASH)
|
if (symbol == anon_sym_SLASH)
|
||||||
return (ARITH_DIVIDE);
|
return (ARITH_DIVIDE);
|
||||||
// anon_sym_PERCENT
|
if (symbol == anon_sym_PERCENT)
|
||||||
|
return (ARITH_MOD);
|
||||||
return (me_abort("invalid arithmetic operator"), 0);
|
return (me_abort("invalid arithmetic operator"), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -622,10 +623,12 @@ t_error build_sym_word(t_parse_node self, t_const_str input, t_ast_node *out);
|
||||||
t_error build_sym_expansion(t_parse_node self, t_const_str input, t_ast_node *out);
|
t_error build_sym_expansion(t_parse_node self, t_const_str input, t_ast_node *out);
|
||||||
t_error build_sym_command_substitution(t_parse_node self, t_const_str input, t_ast_node *out);
|
t_error build_sym_command_substitution(t_parse_node self, t_const_str input, t_ast_node *out);
|
||||||
|
|
||||||
|
/* FUNCTION DONE*/
|
||||||
|
t_error build_sym_arithmetic_binary_expression(t_parse_node self, t_const_str input, t_ast_node *out);
|
||||||
|
|
||||||
/* FUNCTION THAT ARE NOT DONE */
|
/* FUNCTION THAT ARE NOT DONE */
|
||||||
|
|
||||||
// TODO: This is your homework raph
|
// TODO: This is your homework raph
|
||||||
t_error build_sym_arithmetic_binary_expression(t_parse_node self, t_const_str input, t_ast_node *out);
|
|
||||||
t_error build_sym_arithmetic_literal(t_parse_node self, t_const_str input, t_ast_node *out);
|
t_error build_sym_arithmetic_literal(t_parse_node self, t_const_str input, t_ast_node *out);
|
||||||
t_error build_sym_arithmetic_parenthesized_expression(t_parse_node self, t_const_str input, t_ast_node *out);
|
t_error build_sym_arithmetic_parenthesized_expression(t_parse_node self, t_const_str input, t_ast_node *out);
|
||||||
t_error build_sym_arithmetic_postfix_expression(t_parse_node self, t_const_str input, t_ast_node *out);
|
t_error build_sym_arithmetic_postfix_expression(t_parse_node self, t_const_str input, t_ast_node *out);
|
||||||
|
|
@ -669,6 +672,32 @@ t_error build_sym_arithmetic_binary_expression(t_parse_node self, t_const_str in
|
||||||
return (*out = ret, NO_ERROR);
|
return (*out = ret, NO_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
t_error build_sym_arithmetic_literal(t_parse_node self, t_const_str input, t_ast_node *out)
|
||||||
|
{
|
||||||
|
t_usize i;
|
||||||
|
t_ast_node ret;
|
||||||
|
|
||||||
|
if (out == NULL)
|
||||||
|
return (ERROR);
|
||||||
|
if (ts_node_symbol(self) != sym_arithmetic_literal)
|
||||||
|
return (ERROR);
|
||||||
|
i = 0;
|
||||||
|
ret = ast_alloc(AST_ARITHMETIC_LITTERAL);
|
||||||
|
while (i < ts_node_child_count(self))
|
||||||
|
{
|
||||||
|
if (ts_node_field_id_for_child(self, i) == field_lhs)
|
||||||
|
if (ast_from_node(ts_node_child(self, i), input, &ret->data.arithmetic_binary.lhs))
|
||||||
|
return (ERROR);
|
||||||
|
if (ts_node_field_id_for_child(self, i) == field_op)
|
||||||
|
ret->data.arithmetic_binary.op = _parse_operator(ts_node_child(self, i));
|
||||||
|
if (ts_node_field_id_for_child(self, i) == field_rhs)
|
||||||
|
if (ast_from_node(ts_node_child(self, i), input, &ret->data.arithmetic_binary.rhs))
|
||||||
|
return (ERROR);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
return (*out = ret, NO_ERROR);
|
||||||
|
}
|
||||||
|
|
||||||
t_error build_sym_command_substitution(t_parse_node self, t_const_str input, t_ast_node *out)
|
t_error build_sym_command_substitution(t_parse_node self, t_const_str input, t_ast_node *out)
|
||||||
{
|
{
|
||||||
t_ast_node ret;
|
t_ast_node ret;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue