Bison matching list

words demo

lexer.l:

%option noyywrap noline
%{
#include <iostream>
#include "parser.h"
#define YY_DECL yy::parser::symbol_type yylex()
#define yyterminate() return yy::parser::make_YYEOF()
#define _T(t) return yy::parser::make_##t()
#define _ST(t) return yy::parser::make_##t(std::string(yytext, yyleng))
%}
WORD (?i:[a-z]+)
%%
";" { _T(NL); }
{WORD} { _ST(WORD); }
[ \t\r\n] { }
. { printf("char error.\n"); }
%%

parser.y:

%require "3.7"
%skeleton "lalr1.cc"
%language "c++"
%defines "parser.h"
%define api.token.constructor
%define api.value.type variant
%code requires {
#include <memory>
#define M(o) std::move(o)
#define WORDS std::vector<std::string>
}
%code {
#include <iostream>
extern yy::parser::symbol_type yylex();
}
%token WORD "word" NL ";"
%type <std::string> WORD
%type <WORDS> words
%start main
%%
main: words ";" {
printf("words length %d\n", $1.size());
for(const auto& i: $1) printf("%s\n", i.data());
}
;
words: %empty { $$ = WORDS(); }
| WORD { $$ = WORDS(); $$.push_back($1); }
| words WORD { $$ = M($1); $$.push_back($2); }
;
%%
void yy::parser::error(const std::string& msg)
{
std::cout << msg << "\n";
}

test 1

aaa ddd ss o i w ;
words length 6
aaa
ddd
ss
o
i
w

test 2

;
words length 0

words: %empty { $$ = WORDS(); }等同于words: { $$ = WORDS(); }

posted @   Ajanuw  阅读(67)  评论(0编辑  收藏  举报
编辑推荐:
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
阅读排行:
· 如何给本地部署的DeepSeek投喂数据,让他更懂你
· 超详细,DeepSeek 接入PyCharm实现AI编程!(支持本地部署DeepSeek及官方Dee
· 用 DeepSeek 给对象做个网站,她一定感动坏了
· .NET 8.0 + Linux 香橙派,实现高效的 IoT 数据采集与控制解决方案
· .NET中 泛型 + 依赖注入 的实现与应用
点击右上角即可分享
微信分享提示