diff --git a/chapi-ast-c/src/main/antlr/C.g4 b/chapi-ast-c/src/main/antlr/C.g4 index 016894f9..7b2a3011 100644 --- a/chapi-ast-c/src/main/antlr/C.g4 +++ b/chapi-ast-c/src/main/antlr/C.g4 @@ -35,7 +35,7 @@ grammar C; compilationUnit // statement for macro support - : (externalDeclaration | statement)* EOF + : (externalDeclaration | statement | macroPostixCall)* EOF ; MultiLineMacro @@ -84,12 +84,17 @@ postfixExpression extensionExpression : '__extension__'? '(' typeName ')' '{' initializerList ','? '}' ; postixCall - :'[' (macroStatement expression)? expression ']' #arrayAccessPostfixExpression + :'[' (macroStatement expression)? expression ']' #arrayAccessPostfixExpression // for macro support: ph_gen(, hpdata_age_heap, hpdata_t, age_link, hpdata_age_comp) | '(' ','? argumentExpressionList? ')' #functionCallPostfixExpression | ('.' | '->') Identifier #memberAccessPostfixExpression ; +macroPostixCall + : postixCall + | Identifier '(' statement* ')' + ; + argumentExpressionList : assignmentExpression (',' assignmentExpression)* ; @@ -167,8 +172,11 @@ conditionalExpression assignmentExpression : conditionalExpression | unaryExpression assignmentOperator assignmentExpression - | DigitSequence // for + | DigitSequence + // for support macro like: ph_gen(, hpdata_age_heap, &=) | macroStatement + | assignmentOperator + | macroPostixCall ; assignmentOperator diff --git a/chapi-ast-c/src/test/kotlin/chapi/ast/cast/CFullIdentListenerTest.kt b/chapi-ast-c/src/test/kotlin/chapi/ast/cast/CFullIdentListenerTest.kt index a554e1db..e5603414 100644 --- a/chapi-ast-c/src/test/kotlin/chapi/ast/cast/CFullIdentListenerTest.kt +++ b/chapi-ast-c/src/test/kotlin/chapi/ast/cast/CFullIdentListenerTest.kt @@ -611,4 +611,21 @@ typedef struct { val codeFile = CAnalyser().analysis(code, "helloworld.c") assertEquals(codeFile.DataStructures.size, 0) } + + @Test + fun shouldHandleMacroCall() { + val code = """ + #define Protect(x) { L->savedpc = pc; {x;}; base = L->base; } + + Protect(luaV_gettable(L, &g, rb, ra)); + + Protect( + if (!call_binTM(L, rb, luaO_nilobject, ra, TM_LEN)) + luaG_typeerror(L, rb, "get length of"); + ) + """.trimIndent() + + val codeFile = CAnalyser().analysis(code, "helloworld.c") + assertEquals(codeFile.DataStructures.size, 0) + } }