update: made some changes
This commit is contained in:
parent
32afaabbbc
commit
3ee9c00d5a
6 changed files with 100 additions and 25 deletions
12
flake.lock
generated
12
flake.lock
generated
|
|
@ -5,11 +5,11 @@
|
||||||
"systems": "systems"
|
"systems": "systems"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1710146030,
|
"lastModified": 1726560853,
|
||||||
"narHash": "sha256-SZ5L6eA7HJ/nmkzGG7/ISclqe6oZdOZTNoesiInkXPQ=",
|
"narHash": "sha256-X6rJYSESBVr3hBoH0WbKE5KvhPU5bloyZ2L4K60/fPQ=",
|
||||||
"owner": "numtide",
|
"owner": "numtide",
|
||||||
"repo": "flake-utils",
|
"repo": "flake-utils",
|
||||||
"rev": "b1d9ab70662946ef0850d488da1c9019f3a9752a",
|
"rev": "c1dfcf08411b08f6b8615f7d8971a2bfa81d5e8a",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
@ -141,11 +141,11 @@
|
||||||
},
|
},
|
||||||
"nixpkgs_4": {
|
"nixpkgs_4": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1723047874,
|
"lastModified": 1727525597,
|
||||||
"narHash": "sha256-i6shgus4+OUD8vg0TZ1qhDvKBfvaWi+SK1xbBSY0z+c=",
|
"narHash": "sha256-7cdO6lWNE54nxGk4l9BrVjPAAuKaRFQw9H03nkxWKk8=",
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "472701edc3fc64e8c5a36a98e6f61146eea37c69",
|
"rev": "ae432fd808730915310847bfc8bcb279e27c5330",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,8 @@
|
||||||
SRC_FILES = \
|
SRC_FILES = \
|
||||||
|
dollar \
|
||||||
|
quotes \
|
||||||
token \
|
token \
|
||||||
|
token_lifetime \
|
||||||
|
|
||||||
GEN_FILES = \
|
GEN_FILES = \
|
||||||
\
|
\
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/09/26 17:59:23 by maiboyer #+# #+# */
|
/* Created: 2024/09/26 17:59:23 by maiboyer #+# #+# */
|
||||||
/* Updated: 2024/09/28 11:45:54 by rparodi ### ########.fr */
|
/* Updated: 2024/09/28 14:52:09 by maiboyer ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -18,17 +18,25 @@
|
||||||
|
|
||||||
enum e_token
|
enum e_token
|
||||||
{
|
{
|
||||||
AMP,
|
AMP, // ampersand == &
|
||||||
CARRET,
|
AND, // and == &&
|
||||||
DOLLAR,
|
CARRET, // any carret == < > << >>
|
||||||
DQUOTE,
|
DLCARRET, // double left carret == <<
|
||||||
LPAREN,
|
DOLLAR, // dollar == $
|
||||||
NQUOTE,
|
DQUOTE, // double quote string
|
||||||
PIPE,
|
DRCARRET, // double right carret == >>
|
||||||
RPAREN,
|
EXPENSION, // an expension == $<no_quote_word>
|
||||||
SEMICOLON,
|
LCARRET, // left carret == <
|
||||||
SQUOTE,
|
LPAREN, // left parenthesis == (
|
||||||
WHITESPACE
|
NQUOTE, // no quote string
|
||||||
|
OR, // or == ||
|
||||||
|
PIPE, // pipe == |
|
||||||
|
RCARRET, // right carret == >
|
||||||
|
RPAREN, // right parenthesis == )
|
||||||
|
SEMICOLON, // semicolor == ;
|
||||||
|
SQUOTE, // single quote string
|
||||||
|
WHITESPACE, // whitespace outside of quoted strings
|
||||||
|
WORD, // a meta token, which contains subtokens
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct s_token
|
typedef struct s_token
|
||||||
|
|
@ -38,6 +46,15 @@ typedef struct s_token
|
||||||
enum e_token type;
|
enum e_token type;
|
||||||
} t_token;
|
} t_token;
|
||||||
|
|
||||||
|
/* LIFETIME */
|
||||||
|
// This create a "meta" token consisting of multiple tokens
|
||||||
|
t_token token_new_meta(enum e_token type);
|
||||||
|
// This create a "simple" token consisting of a string
|
||||||
|
t_token token_new(enum e_token type);
|
||||||
|
void token_free(t_token tok);
|
||||||
|
bool token_is_meta(t_token tok);
|
||||||
|
|
||||||
|
/* PARSING */
|
||||||
bool is_dollar(char c);
|
bool is_dollar(char c);
|
||||||
bool is_quote(char c);
|
bool is_quote(char c);
|
||||||
bool is_space(char c);
|
bool is_space(char c);
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/09/27 22:18:46 by rparodi #+# #+# */
|
/* Created: 2024/09/27 22:18:46 by rparodi #+# #+# */
|
||||||
/* Updated: 2024/09/28 11:47:09 by rparodi ### ########.fr */
|
/* Updated: 2024/09/28 14:50:56 by maiboyer ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -16,6 +16,12 @@
|
||||||
#include "me/types.h"
|
#include "me/types.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
// MAIX: C'est necessaire de split ca dans une fonction a par vu que ca retourne
|
||||||
|
// la valeur de la comparaion ?
|
||||||
|
// Ca serai pas mieux de faire une fonction du genre
|
||||||
|
// "bool create_single_char_token(char c, t_token *tok)" qui cree un token
|
||||||
|
// dans `tok` et retourne true si il a match un char qui correspond
|
||||||
|
// a un token specific (genre $ ou parentheses par example)
|
||||||
/**
|
/**
|
||||||
* @brief boolean function that's say if it's a dollar or not
|
* @brief boolean function that's say if it's a dollar or not
|
||||||
*
|
*
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/09/25 16:27:03 by rparodi #+# #+# */
|
/* Created: 2024/09/25 16:27:03 by rparodi #+# #+# */
|
||||||
/* Updated: 2024/09/28 12:16:45 by rparodi ### ########.fr */
|
/* Updated: 2024/09/28 14:48:31 by maiboyer ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -18,6 +18,9 @@
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include "me/mem/mem.h"
|
#include "me/mem/mem.h"
|
||||||
|
|
||||||
|
|
||||||
|
// MAIX: attention les whitespace peuvent aussi etre des tab. de memoire il y a
|
||||||
|
// une fonction "me_isspace" qui check ce qu'on veut dans "me/char/char.h"
|
||||||
/**
|
/**
|
||||||
* @brief boolean function that's say if it's a space or not
|
* @brief boolean function that's say if it's a space or not
|
||||||
*
|
*
|
||||||
|
|
@ -31,22 +34,27 @@ bool is_space(char c)
|
||||||
return (false);
|
return (false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// MAIX: tu peux faire un token par character "whitespace", vu qu'on va
|
||||||
|
// manipuler la list de token apres pour faire des truc plus simple a process
|
||||||
|
// on se debrouillera pour plus avoir plein de token whitespace :)
|
||||||
t_error start_analyse(t_const_str raw, enum e_token list, t_vec_token *output)
|
t_error start_analyse(t_const_str raw, enum e_token list, t_vec_token *output)
|
||||||
{
|
{
|
||||||
t_usize i;
|
t_usize i;
|
||||||
t_token token;
|
t_token token;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
mem_alloc(sizeof(t_token));
|
|
||||||
while (raw[i] != '\0')
|
while (raw[i] != '\0')
|
||||||
{
|
{
|
||||||
if (is_space(raw[i]))
|
if (is_space(raw[i]))
|
||||||
token =
|
token = token_new(WHITESPACE);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
return (NO_ERROR);
|
return (NO_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// MAIX: attention tu ne fais rien avec le vec_token ici :D
|
||||||
|
// aussi l'argument list est censer faire quoi ?
|
||||||
|
// c'est un reste d'une version ancienne ?
|
||||||
t_error tokeniser(t_const_str raw, enum e_token list)
|
t_error tokeniser(t_const_str raw, enum e_token list)
|
||||||
{
|
{
|
||||||
t_vec_token output;
|
t_vec_token output;
|
||||||
|
|
|
||||||
41
parser/src/token_lifetime.c
Normal file
41
parser/src/token_lifetime.c
Normal file
|
|
@ -0,0 +1,41 @@
|
||||||
|
/* ************************************************************************** */
|
||||||
|
/* */
|
||||||
|
/* ::: :::::::: */
|
||||||
|
/* token_lifetime.c :+: :+: :+: */
|
||||||
|
/* +:+ +:+ +:+ */
|
||||||
|
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
|
||||||
|
/* +#+#+#+#+#+ +#+ */
|
||||||
|
/* Created: 2024/09/28 14:37:13 by maiboyer #+# #+# */
|
||||||
|
/* Updated: 2024/09/28 14:57:17 by maiboyer ### ########.fr */
|
||||||
|
/* */
|
||||||
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
#include "me/vec/vec_token.h"
|
||||||
|
#include "parser/token.h"
|
||||||
|
|
||||||
|
void token_free(t_token tok)
|
||||||
|
{
|
||||||
|
if (tok.string.buf != NULL)
|
||||||
|
string_free(tok.string);
|
||||||
|
if (tok.subtokens.buffer != NULL)
|
||||||
|
vec_token_free(tok.subtokens);
|
||||||
|
}
|
||||||
|
|
||||||
|
t_token token_new(enum e_token type)
|
||||||
|
{
|
||||||
|
return ((t_token){.type = type, .string = string_new(16), \
|
||||||
|
.subtokens = {NULL, 0, 0, NULL}});
|
||||||
|
}
|
||||||
|
|
||||||
|
t_token token_new_meta(enum e_token type)
|
||||||
|
{
|
||||||
|
return ((t_token){.type = type, .string = {NULL, 0, 0}, \
|
||||||
|
.subtokens = vec_token_new(16, token_free)});
|
||||||
|
}
|
||||||
|
|
||||||
|
bool token_is_meta(t_token tok)
|
||||||
|
{
|
||||||
|
if (tok.type == WORD)
|
||||||
|
return (true);
|
||||||
|
return (false);
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue