From 2cf018f14dd9e03efcd301ce9d3542998a0a1f15 Mon Sep 17 00:00:00 2001 From: Oleksandr Kuksenko Date: Fri, 31 May 2024 00:18:40 +0300 Subject: [PATCH] added __typeof expression type_specifier, it is another alias for __typeof__; test added too --- pycparserext/ext_c_lexer.py | 2 +- pycparserext/ext_c_parser.py | 2 ++ test/test_pycparserext.py | 13 +++++++++---- 3 files changed, 12 insertions(+), 5 deletions(-) diff --git a/pycparserext/ext_c_lexer.py b/pycparserext/ext_c_lexer.py index eb237b6..0d740c9 100644 --- a/pycparserext/ext_c_lexer.py +++ b/pycparserext/ext_c_lexer.py @@ -65,7 +65,7 @@ def add_lexer_keywords(cls, keywords): '__asm__', '__asm', 'asm'] _GNU_KEYWORDS = [ - '__typeof__', 'typeof', + '__typeof__', 'typeof', '__typeof', '__real__', '__imag__', '__builtin_types_compatible_p', '__const', diff --git a/pycparserext/ext_c_parser.py b/pycparserext/ext_c_parser.py index 157e63e..949b95d 100644 --- a/pycparserext/ext_c_parser.py +++ b/pycparserext/ext_c_parser.py @@ -512,6 +512,7 @@ def p_type_qualifier_gnu(self, p): def p_type_specifier_gnu_typeof_expr(self, p): """ type_specifier : __TYPEOF__ LPAREN expression RPAREN | TYPEOF LPAREN expression RPAREN + | __TYPEOF LPAREN expression RPAREN """ if isinstance(p[3], c_ast.TypeDecl): pass @@ -521,6 +522,7 @@ def p_type_specifier_gnu_typeof_expr(self, p): def p_type_specifier_gnu_typeof_decl(self, p): """ type_specifier : __TYPEOF__ LPAREN parameter_declaration RPAREN | TYPEOF LPAREN parameter_declaration RPAREN + | __TYPEOF LPAREN parameter_declaration RPAREN """ p[0] = TypeOfDeclaration(p[1], p[3]) diff --git a/test/test_pycparserext.py b/test/test_pycparserext.py index 183769f..bf03c3b 100644 --- a/test/test_pycparserext.py +++ b/test/test_pycparserext.py @@ -509,7 +509,7 @@ def test_node_visitor(): "Asm": [0, 1], # PreprocessorLine is OpenCL, not GNU "PreprocessorLine": [0, 0], - "TypeOfDeclaration": [0, 4], + "TypeOfDeclaration": [0, 6], "TypeOfExpression": [0, 1], "FuncDeclExt": [0, 1], } @@ -548,6 +548,7 @@ def visit_FuncDeclExt(self, node): __typeof__(a) _a = __builtin_types_compatible_p(long char, short int); __typeof__ (__typeof__ (char *)[4]) y; typeof (typeof (char *)[4]) z; + __typeof (__typeof (char *)[4]) g; asm("rdtsc" : "=A" (val)); __attribute__((unused)) static int c; } @@ -569,9 +570,11 @@ def test_typeof_reproduction(): int func(int a, int b) { __typeof__(a) _a = a; typeof(b) _b = b; + __typeof(c) _c = c; __typeof__ (__typeof__ (char *)[4]) y; typeof (typeof (char *)[4]) z; + __typeof (__typeof (char *)[4]) g; } """ assert _round_trip_matches(src) @@ -581,10 +584,12 @@ def test_typeof_reproduction(): # key is type of visit, value is # [actual # __typeof__, expected # __typeof__, - # actual # typeof, expected # typeof] + # actual # typeof, expected # typeof, + # actual # __typeof, expected # __typeof + # ] visits = { - "TypeOfDeclaration": [0, 2, 0, 2], - "TypeOfExpression": [0, 1, 0, 1], + "TypeOfDeclaration": [0, 2, 0, 4], + "TypeOfExpression": [0, 1, 0, 2], } class TestVisitor(NodeVisitor):