updated ast
This commit is contained in:
parent
078055d0aa
commit
32941a0c7e
4 changed files with 92 additions and 67 deletions
|
|
@ -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/11 14:05:20 by rparodi ### ########.fr */
|
/* Updated: 2024/07/21 16:28:16 by maiboyer ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -18,43 +18,38 @@
|
||||||
|
|
||||||
enum e_ast_node_kind
|
enum e_ast_node_kind
|
||||||
{
|
{
|
||||||
S_AST_CATEGORY_MASK = 0xFFFF0000,
|
AST_ARITHMETIC_BINARY,
|
||||||
S_AST_NODETYPE_MASK = 0x0000FFFF,
|
AST_ARITHMETIC_EXPANSION,
|
||||||
S_AST_NONE = 0,
|
AST_CASE,
|
||||||
S_AST_COMPOUND_COMMAND = 1 << 16,
|
AST_CASE_ITEM,
|
||||||
S_AST_COMMAND = 1 << 17,
|
AST_COMMAND,
|
||||||
S_AST_REDIRECT = 1 << 18,
|
AST_COMMAND_SUBSTITUTION,
|
||||||
S_AST_EXPANSION = 1 << 19,
|
AST_COMPOUND_STATEMENT,
|
||||||
AST_ARITHMETIC_EXPANSION = S_AST_EXPANSION | 0x0001,
|
AST_ELIF,
|
||||||
AST_COMMAND_SUBSTITUTION = S_AST_EXPANSION | 0x0002,
|
AST_ELSE,
|
||||||
AST_EXPANSION = S_AST_EXPANSION | 0x0003,
|
AST_EMPTY,
|
||||||
AST_COMMAND = S_AST_COMMAND | 0x0004,
|
AST_EXPANSION,
|
||||||
AST_CASE_ITEM = S_AST_NONE | 0x0005,
|
AST_EXTGLOB,
|
||||||
AST_ELIF = S_AST_NONE | 0x0006,
|
AST_FILE_REDIRECTION,
|
||||||
AST_ELSE = S_AST_NONE | 0x0007,
|
AST_FOR,
|
||||||
AST_EMPTY = S_AST_NONE | 0x0008,
|
AST_FUNCTION_DEFINITION,
|
||||||
AST_RAW_STRING = S_AST_NONE | 0x000A,
|
AST_HEREDOC_REDIRECTION,
|
||||||
AST_WORD = S_AST_NONE | 0x000C,
|
AST_IF,
|
||||||
AST_VARIABLE_ASSIGNMENT = S_AST_NONE | 0x000E,
|
AST_LIST,
|
||||||
AST_EXTGLOB = S_AST_NONE | 0x001A,
|
AST_PIPELINE,
|
||||||
AST_REGEX = S_AST_NONE | 0x001B,
|
AST_PROGRAM,
|
||||||
AST_FILE_REDIRECTION = S_AST_REDIRECT | 0x000F,
|
AST_RAW_STRING,
|
||||||
AST_HEREDOC_REDIRECTION = S_AST_REDIRECT | 0x0010,
|
AST_REGEX,
|
||||||
AST_FOR = S_AST_COMPOUND_COMMAND | 0x0011,
|
AST_SUBSHELL,
|
||||||
AST_CASE = S_AST_COMPOUND_COMMAND | 0x0012,
|
AST_UNTIL,
|
||||||
AST_COMPOUND_STATEMENT = S_AST_COMPOUND_COMMAND | 0x0013,
|
AST_VARIABLE_ASSIGNMENT,
|
||||||
AST_IF = S_AST_COMPOUND_COMMAND | 0x0014,
|
AST_WHILE,
|
||||||
AST_FUNCTION_DEFINITION = S_AST_COMPOUND_COMMAND | 0x000D,
|
AST_WORD,
|
||||||
AST_LIST = S_AST_COMPOUND_COMMAND | 0x0009,
|
|
||||||
AST_PIPELINE = S_AST_COMPOUND_COMMAND | 0x00015,
|
|
||||||
AST_PROGRAM = S_AST_COMPOUND_COMMAND | 0x0016,
|
|
||||||
AST_SUBSHELL = S_AST_COMPOUND_COMMAND | 0x00017,
|
|
||||||
AST_UNTIL = S_AST_COMPOUND_COMMAND | 0x0018,
|
|
||||||
AST_WHILE = S_AST_COMPOUND_COMMAND | 0x0019,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
union u_ast_node_data
|
union u_ast_node_data
|
||||||
{
|
{
|
||||||
|
t_ast_arithmetic_binary arithmetic_binary;
|
||||||
t_ast_arithmetic_expansion arithmetic_expansion;
|
t_ast_arithmetic_expansion arithmetic_expansion;
|
||||||
t_ast_case case_;
|
t_ast_case case_;
|
||||||
t_ast_case_item case_item;
|
t_ast_case_item case_item;
|
||||||
|
|
@ -89,14 +84,4 @@ struct s_ast_node
|
||||||
t_ast_node_data data;
|
t_ast_node_data data;
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline bool ast_category(t_ast_node node)
|
|
||||||
{
|
|
||||||
return (node->kind & S_AST_CATEGORY_MASK);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline bool ast_nodetype(t_ast_node node)
|
|
||||||
{
|
|
||||||
return (node->kind & S_AST_NODETYPE_MASK);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* AST_H */
|
#endif /* AST_H */
|
||||||
|
|
|
||||||
|
|
@ -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/11 14:04:34 by rparodi ### ########.fr */
|
/* Updated: 2024/07/21 16:26:36 by maiboyer ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -17,6 +17,7 @@ typedef enum e_ast_node_kind t_ast_node_kind;
|
||||||
typedef enum e_ast_word_kind t_ast_word_kind;
|
typedef enum e_ast_word_kind t_ast_word_kind;
|
||||||
typedef enum e_ast_list_kind t_ast_list_kind;
|
typedef enum e_ast_list_kind t_ast_list_kind;
|
||||||
typedef enum e_ast_expansion_operator t_ast_expansion_operator;
|
typedef enum e_ast_expansion_operator t_ast_expansion_operator;
|
||||||
|
typedef enum e_ast_arithmetic_operator t_ast_arithmetic_operator;
|
||||||
typedef enum e_ast_terminator_kind t_ast_terminator_kind;
|
typedef enum e_ast_terminator_kind t_ast_terminator_kind;
|
||||||
typedef enum e_ast_redirection_kind t_ast_redirection_kind;
|
typedef enum e_ast_redirection_kind t_ast_redirection_kind;
|
||||||
typedef union u_ast_node_data t_ast_node_data;
|
typedef union u_ast_node_data t_ast_node_data;
|
||||||
|
|
@ -24,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_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;
|
||||||
typedef struct s_ast_command t_ast_command;
|
typedef struct s_ast_command t_ast_command;
|
||||||
|
|
|
||||||
|
|
@ -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 15:29:33 by rparodi ### ########.fr */
|
/* Updated: 2024/07/21 16:26:17 by maiboyer ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -39,6 +39,14 @@ enum e_ast_terminator_kind
|
||||||
AST_TERM_FORK,
|
AST_TERM_FORK,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum e_ast_arithmetic_operator
|
||||||
|
{
|
||||||
|
ARITH_PLUS,
|
||||||
|
ARITH_MINUS,
|
||||||
|
ARITH_DIVIDE,
|
||||||
|
ARITH_MULT,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
E_OP_NONE = 0,= ${var}
|
E_OP_NONE = 0,= ${var}
|
||||||
E_OP_DEFAULT, = ${var-word}
|
E_OP_DEFAULT, = ${var-word}
|
||||||
|
|
@ -409,14 +417,13 @@ struct s_ast_arithmetic_expansion
|
||||||
t_ast_node expr;
|
t_ast_node expr;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct s_ast_binary_op
|
struct s_ast_arithmetic_binary
|
||||||
{
|
{
|
||||||
t_ast_node operator;
|
t_ast_node lhs;
|
||||||
|
t_ast_arithmetic_operator op;
|
||||||
|
t_ast_node rhs;
|
||||||
};
|
};
|
||||||
|
|
||||||
{
|
|
||||||
t_ast_node expr;
|
|
||||||
};
|
|
||||||
/// Command Substitution
|
/// Command Substitution
|
||||||
/// ```shell
|
/// ```shell
|
||||||
/// $(command)
|
/// $(command)
|
||||||
|
|
|
||||||
|
|
@ -83,6 +83,11 @@ void ast_free(t_ast_node elem)
|
||||||
{
|
{
|
||||||
ast_free(elem->data.arithmetic_expansion.expr);
|
ast_free(elem->data.arithmetic_expansion.expr);
|
||||||
}
|
}
|
||||||
|
if (elem->kind == AST_ARITHMETIC_BINARY)
|
||||||
|
{
|
||||||
|
ast_free(elem->data.arithmetic_binary.lhs);
|
||||||
|
ast_free(elem->data.arithmetic_binary.rhs);
|
||||||
|
}
|
||||||
if (elem->kind == AST_CASE)
|
if (elem->kind == AST_CASE)
|
||||||
{
|
{
|
||||||
ast_free(elem->data.case_.word);
|
ast_free(elem->data.case_.word);
|
||||||
|
|
@ -221,6 +226,12 @@ t_ast_node ast_alloc(t_ast_node_kind kind)
|
||||||
{
|
{
|
||||||
ret->data.arithmetic_expansion.expr = NULL;
|
ret->data.arithmetic_expansion.expr = NULL;
|
||||||
}
|
}
|
||||||
|
if (kind == AST_ARITHMETIC_BINARY)
|
||||||
|
{
|
||||||
|
ret->data.arithmetic_binary.lhs = NULL;
|
||||||
|
ret->data.arithmetic_binary.op = 0;
|
||||||
|
ret->data.arithmetic_binary.rhs = NULL;
|
||||||
|
}
|
||||||
if (kind == AST_CASE)
|
if (kind == AST_CASE)
|
||||||
{
|
{
|
||||||
ret->data.case_.cases = vec_ast_new(16, ast_free);
|
ret->data.case_.cases = vec_ast_new(16, ast_free);
|
||||||
|
|
@ -560,6 +571,23 @@ t_ast_redirection_kind _get_redirection_op(t_parse_node self)
|
||||||
return (me_abort("invalid redirection symbol"), 0);
|
return (me_abort("invalid redirection symbol"), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
t_ast_arithmetic_operator _parse_operator(t_parse_node self)
|
||||||
|
{
|
||||||
|
t_symbol symbol;
|
||||||
|
|
||||||
|
symbol = ts_node_grammar_symbol(self);
|
||||||
|
if (symbol == anon_sym_PLUS)
|
||||||
|
return (ARITH_PLUS);
|
||||||
|
if (symbol == anon_sym_DASH)
|
||||||
|
return (ARITH_MINUS);
|
||||||
|
if (symbol == anon_sym_STAR)
|
||||||
|
return (ARITH_MULT);
|
||||||
|
if (symbol == anon_sym_SLASH)
|
||||||
|
return (ARITH_DIVIDE);
|
||||||
|
// anon_sym_PERCENT
|
||||||
|
return (me_abort("invalid arithmetic operator"), 0);
|
||||||
|
}
|
||||||
|
|
||||||
t_error ast_from_node(t_parse_node node, t_const_str input, t_ast_node *out);
|
t_error ast_from_node(t_parse_node node, t_const_str input, t_ast_node *out);
|
||||||
|
|
||||||
/* FUNCTION THAT ARE DONE */
|
/* FUNCTION THAT ARE DONE */
|
||||||
|
|
@ -615,27 +643,30 @@ t_error build_sym_heredoc_start(t_parse_node self, t_const_str input, t_ast_node
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
t_error build_sym_arithmetic_binary_expression(t_parse_node self, t_const_str input, t_ast_node *out);
|
t_error build_sym_arithmetic_binary_expression(t_parse_node self, t_const_str input, t_ast_node *out)
|
||||||
{
|
{
|
||||||
t_usize i;
|
t_usize i;
|
||||||
t_ast_node *ret;
|
t_ast_node ret;
|
||||||
|
|
||||||
|
if (out == NULL)
|
||||||
|
return (ERROR);
|
||||||
|
if (ts_node_symbol(self) != sym_arithmetic_binary_expression)
|
||||||
|
return (ERROR);
|
||||||
i = 0;
|
i = 0;
|
||||||
ret = ast_alloc(AST_ARITHMETIC_EXPANSION);
|
ret = ast_alloc(AST_ARITHMETIC_BINARY);
|
||||||
while (str[i] == '\0')
|
while (i < ts_node_child_count(self))
|
||||||
{
|
{
|
||||||
if (str[i] == '+')
|
if (ts_node_field_id_for_child(self, i) == field_lhs)
|
||||||
ret->operator = '+';
|
if (ast_from_node(ts_node_child(self, i), input, &ret->data.arithmetic_binary.lhs))
|
||||||
if (str[i] == '-')
|
return (ERROR);
|
||||||
ret->operator = '-';
|
if (ts_node_field_id_for_child(self, i) == field_op)
|
||||||
if (str[i] == '/')
|
ret->data.arithmetic_binary.op = _parse_operator(ts_node_child(self, i));
|
||||||
ret->operator = '/';
|
if (ts_node_field_id_for_child(self, i) == field_rhs)
|
||||||
if (str[i] == '%')
|
if (ast_from_node(ts_node_child(self, i), input, &ret->data.arithmetic_binary.rhs))
|
||||||
ret->operator = '%';
|
return (ERROR);
|
||||||
if (str[i] == '*')
|
i++;
|
||||||
ret->operator = '*';
|
|
||||||
}
|
}
|
||||||
|
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)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue