make the parser reentrant
This commit is contained in:
parent
baeea3eee6
commit
25227d5c6c
@ -2,10 +2,10 @@ AM_YFLAGS = -d
|
|||||||
BUILT_SOURCES = lib/dice_parse.h
|
BUILT_SOURCES = lib/dice_parse.h
|
||||||
|
|
||||||
lib_LTLIBRARIES = libdice.la
|
lib_LTLIBRARIES = libdice.la
|
||||||
libdice_la_SOURCES = lib/dice.h \
|
libdice_la_SOURCES = lib/dice_lexer.l \
|
||||||
lib/dice.c \
|
|
||||||
lib/dice_parse.y \
|
lib/dice_parse.y \
|
||||||
lib/dice_lexer.l
|
lib/dice.h \
|
||||||
|
lib/dice.c
|
||||||
|
|
||||||
AM_CFLAGS = -Ilib
|
AM_CFLAGS = -Ilib
|
||||||
|
|
||||||
|
27
lib/dice.c
27
lib/dice.c
@ -8,11 +8,17 @@
|
|||||||
#include <bsd/stdlib.h>
|
#include <bsd/stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern void *yy_scan_string(char const *s);
|
extern int yylex_init(void **state);
|
||||||
extern void yy_delete_buffer(void *b);
|
extern int yylex_destroy(void *state);
|
||||||
|
extern void yylex(void *state);
|
||||||
|
extern void yy_switch_to_buffer(void *buffer, void *scanner);
|
||||||
|
extern void *yy_scan_string(char const *s, void *scanner);
|
||||||
|
extern void yy_delete_buffer(void *b, void *scanner);
|
||||||
|
|
||||||
struct dice_
|
struct dice_
|
||||||
{
|
{
|
||||||
|
int consumed;
|
||||||
|
|
||||||
uint32_t amount;
|
uint32_t amount;
|
||||||
uint32_t sides;
|
uint32_t sides;
|
||||||
|
|
||||||
@ -77,6 +83,7 @@ dice_t dice_simple(uint32_t amount, uint32_t sides)
|
|||||||
|
|
||||||
dice_t dice_parse(char const *s)
|
dice_t dice_parse(char const *s)
|
||||||
{
|
{
|
||||||
|
void *scanner = NULL;
|
||||||
dice_t d = NULL;
|
dice_t d = NULL;
|
||||||
void *buffer = NULL;
|
void *buffer = NULL;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@ -86,9 +93,14 @@ dice_t dice_parse(char const *s)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
buffer = yy_scan_string(s);
|
yylex_init(&scanner);
|
||||||
ret = yyparse(d);
|
buffer = yy_scan_string(s, scanner);
|
||||||
yy_delete_buffer(buffer);
|
yy_switch_to_buffer(buffer, scanner);
|
||||||
|
|
||||||
|
ret = yyparse(scanner, d);
|
||||||
|
|
||||||
|
yy_delete_buffer(buffer, scanner);
|
||||||
|
yylex_destroy(scanner);
|
||||||
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dice_free(d);
|
dice_free(d);
|
||||||
@ -176,3 +188,8 @@ bool dice_evaluate(dice_t d, dice_result_t **res, size_t *reslen)
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void dice_update_consumned(dice_t d, int offset)
|
||||||
|
{
|
||||||
|
d->consumed += offset;
|
||||||
|
}
|
||||||
|
@ -1,9 +1,19 @@
|
|||||||
|
%option bison-bridge
|
||||||
|
%option reentrant
|
||||||
|
|
||||||
%{
|
%{
|
||||||
#include "dice.h"
|
#include "dice.h"
|
||||||
#include "dice_parse.h"
|
#include "dice_parse.h"
|
||||||
|
|
||||||
%}
|
%}
|
||||||
|
|
||||||
%%
|
%%
|
||||||
[0-9]+ { yylval.integer = atoi(yytext); return TOK_INTEGER; }
|
[0-9]+ {
|
||||||
[d] return TOK_DICESEP;
|
yylval->integer = atoi(yytext);
|
||||||
|
return TOK_INTEGER;
|
||||||
|
}
|
||||||
|
|
||||||
|
[d] {
|
||||||
|
return TOK_DICESEP;
|
||||||
|
}
|
||||||
%%
|
%%
|
||||||
|
@ -1,11 +1,14 @@
|
|||||||
%parse-param {dice_t dice}
|
%define api.pure full
|
||||||
|
|
||||||
|
%parse-param {void *scanner} {dice_t dice}
|
||||||
|
%lex-param {void *scanner}
|
||||||
|
|
||||||
%{
|
%{
|
||||||
#include "dice.h"
|
#include "dice.h"
|
||||||
|
|
||||||
extern int yylex(void);
|
extern int yylex(void *lval, void *scanner);
|
||||||
|
|
||||||
void yyerror(dice_t dice, char const *err)
|
void yyerror(void *scanner, dice_t dice, char const *err)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user