cpp-common/bt2c/logging.hpp: remove no-formatting ("str") alternatives
[babeltrace.git] / src / plugins / ctf / common / src / metadata / tsdl / lexer.lpp
CommitLineData
e98a2d6e
PP
1%{
2/*
0235b0db 3 * SPDX-License-Identifier: MIT
e98a2d6e 4 *
0235b0db 5 * Copyright 2010 Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
e98a2d6e 6 *
0235b0db 7 * Common Trace Formal Lexer
e98a2d6e
PP
8 */
9
0f5c5d5c 10#include "plugins/ctf/common/src/metadata/tsdl/ast.hpp"
5656cea5 11#include "plugins/ctf/common/src/metadata/tsdl/logging.hpp"
5656cea5 12#include "plugins/ctf/common/src/metadata/tsdl/parser-wrap.hpp"
0f5c5d5c 13#include "plugins/ctf/common/src/metadata/tsdl/scanner.hpp"
e98a2d6e 14
e27adb90 15#define YY_FATAL_ERROR(_msg) BT_CPPLOGF_SPEC(currentCtfScanner->logger, "{}", _msg)
f73367f8 16
e98a2d6e
PP
17#define PARSE_INTEGER_LITERAL(base) \
18 do { \
19 errno = 0; \
20 yylval->ull = strtoull(yytext, NULL, base); \
21 if (errno) { \
0f5c5d5c
SM
22 _BT_CPPLOGE_APPEND_CAUSE_LINENO( \
23 currentCtfScanner->logger, \
24 yylineno, \
f73367f8 25 "Cannot parser constant integer: " \
0f5c5d5c 26 "base={}, text=\"{}\"", base, yytext); \
f73367f8 27 return CTF_ERROR; \
e98a2d6e
PP
28 } \
29 } while (0)
0f5c5d5c
SM
30
31extern thread_local const ctf_scanner *const currentCtfScanner;
e98a2d6e
PP
32%}
33
34%x comment_ml comment_sl string_lit char_const
35%option reentrant yylineno noyywrap bison-bridge
36%option extra-type="struct ctf_scanner *"
37 /* bison-locations */
38INTEGER_SUFFIX (U|UL|ULL|LU|LLU|Ul|Ull|lU|llU|u|uL|uLL|Lu|LLu|ul|ull|lu|llu)
39DIGIT [0-9]
40NONDIGIT [a-zA-Z_]
41HEXDIGIT [0-9A-Fa-f]
42OCTALDIGIT [0-7]
43UCHARLOWERCASE \\u{HEXDIGIT}{4}
44UCHARUPPERCASE \\U{HEXDIGIT}{8}
45ID_NONDIGIT {NONDIGIT}|{UCHARLOWERCASE}|{UCHARUPPERCASE}
46IDENTIFIER {ID_NONDIGIT}({ID_NONDIGIT}|{DIGIT})*
47%%
48
49 /*
50 * Using start conditions to deal with comments
51 * and strings.
f73367f8 52 */
e98a2d6e
PP
53
54"/*" BEGIN(comment_ml);
55<comment_ml>[^*\n]* /* eat anything that's not a '*' */
56<comment_ml>"*"+[^*/\n]* /* eat up '*'s not followed by '/'s */
57<comment_ml>\n
58<comment_ml>"*"+"/" BEGIN(INITIAL);
59
60"//"[^\n]*\n /* skip comment */
61
d4c6eae5
MJ
62L?\"(\\.|[^\\"])*\" { if (import_string(yyextra, yylval, yytext, '\"') < 0) return CTF_ERROR; else return CTF_STRING_LITERAL; }
63L?\'(\\.|[^\\'])*\' { if (import_string(yyextra, yylval, yytext, '\'') < 0) return CTF_ERROR; else return CTF_CHARACTER_LITERAL; }
e98a2d6e 64
d4c6eae5
MJ
65"[" return CTF_LSBRAC;
66"]" return CTF_RSBRAC;
67"(" return CTF_LPAREN;
68")" return CTF_RPAREN;
69"{" return CTF_LBRAC;
70"}" return CTF_RBRAC;
71"->" return CTF_RARROW;
72"*" return CTF_STAR;
73"+" return CTF_PLUS;
74"-" return CTF_MINUS;
75"<" return CTF_LT;
76">" return CTF_GT;
77:= return CTF_TYPEASSIGN;
78: return CTF_COLON;
79; return CTF_SEMICOLON;
80"..." return CTF_DOTDOTDOT;
81"." return CTF_DOT;
82= return CTF_EQUAL;
83"," return CTF_COMMA;
84align setstring(yyextra, yylval, yytext); return CTF_TOK_ALIGN;
85const setstring(yyextra, yylval, yytext); return CTF_CONST;
86char setstring(yyextra, yylval, yytext); return CTF_CHAR;
87clock setstring(yyextra, yylval, yytext); return CTF_CLOCK;
88double setstring(yyextra, yylval, yytext); return CTF_DOUBLE;
89enum setstring(yyextra, yylval, yytext); return CTF_ENUM;
90env setstring(yyextra, yylval, yytext); return CTF_ENV;
91event setstring(yyextra, yylval, yytext); return CTF_EVENT;
92floating_point setstring(yyextra, yylval, yytext); return CTF_FLOATING_POINT;
93float setstring(yyextra, yylval, yytext); return CTF_FLOAT;
94integer setstring(yyextra, yylval, yytext); return CTF_INTEGER;
95int setstring(yyextra, yylval, yytext); return CTF_INT;
96long setstring(yyextra, yylval, yytext); return CTF_LONG;
97short setstring(yyextra, yylval, yytext); return CTF_SHORT;
98signed setstring(yyextra, yylval, yytext); return CTF_SIGNED;
99stream setstring(yyextra, yylval, yytext); return CTF_STREAM;
100string setstring(yyextra, yylval, yytext); return CTF_STRING;
101struct setstring(yyextra, yylval, yytext); return CTF_STRUCT;
102trace setstring(yyextra, yylval, yytext); return CTF_TRACE;
103callsite setstring(yyextra, yylval, yytext); return CTF_CALLSITE;
104typealias setstring(yyextra, yylval, yytext); return CTF_TYPEALIAS;
105typedef setstring(yyextra, yylval, yytext); return CTF_TYPEDEF;
106unsigned setstring(yyextra, yylval, yytext); return CTF_UNSIGNED;
107variant setstring(yyextra, yylval, yytext); return CTF_VARIANT;
108void setstring(yyextra, yylval, yytext); return CTF_VOID;
109_Bool setstring(yyextra, yylval, yytext); return CTF_BOOL;
110_Complex setstring(yyextra, yylval, yytext); return CTF_COMPLEX;
111_Imaginary setstring(yyextra, yylval, yytext); return CTF_IMAGINARY;
112[1-9]{DIGIT}*{INTEGER_SUFFIX}? PARSE_INTEGER_LITERAL(10); return CTF_INTEGER_LITERAL;
1130{OCTALDIGIT}*{INTEGER_SUFFIX}? PARSE_INTEGER_LITERAL(8); return CTF_INTEGER_LITERAL;
1140[xX]{HEXDIGIT}+{INTEGER_SUFFIX}? PARSE_INTEGER_LITERAL(16); return CTF_INTEGER_LITERAL;
e98a2d6e 115
0f5c5d5c 116{IDENTIFIER} BT_CPPLOGT_SPEC(currentCtfScanner->logger, "Got identifier: id=\"{}\"", yytext); setstring(yyextra, yylval, yytext); if (is_type(yyextra, yytext)) return ID_TYPE; else return IDENTIFIER;
e98a2d6e 117[ \t\r\n] ; /* ignore */
0f5c5d5c 118. _BT_CPPLOGE_APPEND_CAUSE_LINENO(currentCtfScanner->logger, yylineno, "Invalid character: char=\"{}\", val={:#02x}", isprint((unsigned char) yytext[0]) ? yytext[0] : '\0', yytext[0]); return CTF_ERROR;
e98a2d6e 119%%
This page took 0.105968 seconds and 4 git commands to generate.