如何使用clang API解析函数指针的typedef以获得函数指针名称?
How can I parse a typedef for a function pointer using clang API to get the function pointer name?
我目前正在使用clang C API为c++代码构建解析器。解析器将处理一个头文件,并为它生成一个已定义和缺失符号的列表(它忽略include指令,因此它将严格解析头文件的内容)。我的问题是,如果我有一个函数指针的typedef
,它接受未定义类型的参数,例如:
typedef SOME_TYPE (* funcPtrName)(SOME_UNDEF_TYPE x);
AST将SOME_TYPE
解析为类型定义而不是funcPtrName
。如果我用int
代替SOME_UNDEF_TYPE
,它可以正确解析funcPtrName
。
我认为我可以使用clang_tokenize
来获取游标的所有令牌,并手动获取函数指针名称,但是在指向typedef的游标上调用clang_getCursorExtent
不能正确工作(返回的范围为0,0)。
你知道解决这个问题的方法吗?
我确实设法通过构建翻译单元中所有令牌的列表并将其传递给访问者函数来解决这个问题。当我到达CXCursor_TypedefDecl
游标时,我在令牌列表中搜索typedef
名称,然后检查下一个令牌是否为(
。如果是这样,期待*
之后的第一个标记,它将是函数指针的名称。
std::string symbol = clang_getCString(clang_getCursorSpelling(Cursor));
...
case CXCursor_TypedefDecl:
{
auto finder = std::find(tokens.begin(), tokens.end(), symbol);
if (*(finder + 1) == "(")
{
auto next = std::find(finder, parserData->tokens.end(), "*") + 1;
symbol = *next;
}
symbolData[symbol] = SymbolInfo{ cursorKind, fileName };
}
相关文章:
- QMetaObject invokeMethod的基于函数指针的语法
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- c++r值引用应用于函数指针
- 模板函数指针和lambda
- 是否可以将llvm::FunctionType转换为C/C++原始函数指针
- 带有类的函数指针
- () 函子后面的括号,而不是函数指针?
- 全局作用域中函数指针的赋值
- 使用"Task"函数指针队列定义作业管理器
- 将成员函数指针作为参数传递给模板方法
- 如何创建对象函数指针C++映射?
- 匹配函数指针作为模板参数?
- 通过函数指针定义类范围之外的方法
- 存储在类中的函数指针
- C++从函数指针数组调用函数
- 将返回值存储在函数指针数组的指针中是如何工作的?
- 整数键映射到头文件中的成员函数指针
- 从类成员函数到类 C 函数指针的转换
- 如何将内联匿名函数分配给C++函数指针
- 将字符缓冲区强制转换为函数指针