CDT 预处理器后的 IASTNode getRawSignature

CDT IASTNode getRawSignature after preprocessor

在CDT核心插件中,有接口IASTNode的一个方法getRawSignature被描述为:

Returns the raw signature of the IASTNode before it is processed by the preprocessor.
Example:
#define ONE 1
int x=ONE; // getRawSignature() for this declaration would return "int x=ONE;"

但是我想在节点被预处理器处理
之后得到字符串签名 在上面的例子中,预期的字符串是:int x=1
如何得到这个字符串?我看过其他一些方法,但没有人可以。

好问题!

首先要注意的是,在 CDT 的处理过程中,代码绝不会以预处理字符串的形式存在。

处理流程是这样的:

   Unpreprocessed string
-> [Lexer]
-> Unpreprocessed token stream
-> [Preprocessor]
-> Preprocessed token stream
-> [Parser]
-> Abstract syntax tree

请注意,在预处理形式中,代码仅作为标记流存在,而不是字符串。

就是说,如果您有经过预处理的令牌流,您可能可以使用它来构造经过预处理的字符串。

不幸的是,我不知道有一种获取预处理令牌的简单方法,this mailing list thread 表明可能没有。

我认为最接近的是re-preprocess文件,从而获得整个文件的预处理令牌流。这可以通过调用 AbstractCLikeLanguage.createScanner() 来获得 IScanner 来完成(这是一个受保护的方法,因此您需要从 GCCLanguageGPPLanguage 派生才能访问它),并且重复调用 IScanner.nextToken() 以获得预处理的标记。

这仍然不能完全满足您的需求,因为您需要与特定 AST 节点相对应的预处理标记。我相信您可以通过将预处理标记(使用IToken.getOffset()IToken.getLength()获得)的偏移量和长度与AST节点的偏移量和长度进行比较来计算(使用 ASTNode.getOffset()ASTNode.getLength() 获得),我认为它们的编号相同 space.