feat(lexer): usefull functions

This commit is contained in:
Matteo Flebus 2026-01-08 16:32:48 +01:00
parent e7784b8df1
commit 453a8ab0da
2 changed files with 103 additions and 0 deletions

View file

@ -0,0 +1,67 @@
#include "lexer.h"
#include <stdbool.h>
#include "io_backend/io_backend.h"
static char *end_last_token;
static ssize_t remaining_chars;
char *new_token(char *begin, size_t size)
{
char *res = calloc(size + 1, sizeof(char));
if (res == NULL)
return NULL;
strncpy(res, begin, size);
return res;
}
char *stream_init(void)
{
char *stream;
if (remaining_chars == 0)
{
remaining_chars = stream_read(&stream);
}
else
{
stream = end_last_token;
}
return stream;
}
char *get_token(void)
{
char *stream = stream_init();
bool inquotes = false;
ssize_t i = 0;
while (i < remaining_chars)
{
switch (stream[i])
{
case '\'':
inquotes = !inquotes;
break;
case ' ' | '\n' | '\t':
if (inquotes)
break;
else
{
// token creation
// skip blank char
// exit from loop
char *token = new_token(stream, i);
}
default:
break;
}
i++;
}
remaining_chars -= i;
}

View file

@ -0,0 +1,36 @@
#ifndef LEXER_H
#define LEXER_H
/* @return: char*, the next token
*
*/
char *get_token(void);
/*
* @warning: NOT IMPLEMENTED.
*
* @note: maybe usefull for subshells.
*/
char *get_token_str(void);
/*
* @brief: return a newly allocated token.
* This token contains [size] chars, starting from [begin].
*
* @return: NULL on error, null-terminated char* otherwise.
*
*/
char *new_token(char *begin, ssize_t size);
/*
* @brief: checks if the stream used for the last token creation is empty.
* If it is, it calls stream_read() from IO_backend,
* and sets [remaing_chars].
* If not, it starts from the end of the last token.
*
* @return: char* stream from which we tokenise.
*/
char *stream_init(void);
#endif /* LEXER_H */