aboutsummaryrefslogtreecommitdiffstats
path: root/src/libs/3rdparty/cplusplus/Lexer.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/libs/3rdparty/cplusplus/Lexer.cpp')
-rw-r--r--src/libs/3rdparty/cplusplus/Lexer.cpp44
1 files changed, 43 insertions, 1 deletions
diff --git a/src/libs/3rdparty/cplusplus/Lexer.cpp b/src/libs/3rdparty/cplusplus/Lexer.cpp
index db7cb9e0f83..68f87f126c1 100644
--- a/src/libs/3rdparty/cplusplus/Lexer.cpp
+++ b/src/libs/3rdparty/cplusplus/Lexer.cpp
@@ -336,20 +336,62 @@ void Lexer::scan_helper(Token *tok)
break;
case '?':
- if (_yychar == '?') {
+ if (_yychar == '?' && f._ppMode) {
yyinp();
if (_yychar == '(') {
yyinp();
tok->f.kind = T_LBRACKET;
+ tok->f.trigraph = true;
} else if (_yychar == ')') {
yyinp();
tok->f.kind = T_RBRACKET;
+ tok->f.trigraph = true;
} else if (_yychar == '<') {
yyinp();
tok->f.kind = T_LBRACE;
+ tok->f.trigraph = true;
} else if (_yychar == '>') {
yyinp();
tok->f.kind = T_RBRACE;
+ tok->f.trigraph = true;
+ } else if (_yychar == '=') {
+ yyinp();
+ tok->f.trigraph = true;
+ if (_yychar == '?' && *(_currentChar + 1) == '?' && *(_currentChar + 2) == '=') {
+ yyinp();
+ yyinp();
+ yyinp();
+ tok->f.kind = T_POUND_POUND;
+ } else {
+ tok->f.kind = T_POUND;
+ }
+ } else if (_yychar == '\'') {
+ yyinp();
+ if (_yychar == '=') {
+ yyinp();
+ tok->f.kind = T_CARET_EQUAL;
+ } else {
+ tok->f.kind = T_CARET;
+ }
+ tok->f.trigraph = true;
+ } else if (_yychar == '!') {
+ yyinp();
+ if (_yychar == '=') {
+ yyinp();
+ tok->f.kind = T_PIPE_EQUAL;
+ } else {
+ tok->f.kind = T_PIPE;
+ }
+ tok->f.trigraph = true;
+ } else if (_yychar == '-') {
+ yyinp();
+ if (_yychar == '=') {
+ yyinp();
+ tok->f.kind = T_TILDE_EQUAL;
+ } else {
+ tok->f.kind = T_TILDE;
+ }
+ tok->f.trigraph = true;
}
} else {
tok->f.kind = T_QUESTION;