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
来完成(这是一个受保护的方法,因此您需要从 GCCLanguage
或 GPPLanguage
派生才能访问它),并且重复调用 IScanner.nextToken()
以获得预处理的标记。
这仍然不能完全满足您的需求,因为您需要与特定 AST 节点相对应的预处理标记。我相信您可以通过将预处理标记(使用IToken.getOffset()
和IToken.getLength()
获得)的偏移量和长度与AST节点的偏移量和长度进行比较来计算(使用 ASTNode.getOffset()
和 ASTNode.getLength()
获得),我认为它们的编号相同 space.
在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
来完成(这是一个受保护的方法,因此您需要从 GCCLanguage
或 GPPLanguage
派生才能访问它),并且重复调用 IScanner.nextToken()
以获得预处理的标记。
这仍然不能完全满足您的需求,因为您需要与特定 AST 节点相对应的预处理标记。我相信您可以通过将预处理标记(使用IToken.getOffset()
和IToken.getLength()
获得)的偏移量和长度与AST节点的偏移量和长度进行比较来计算(使用 ASTNode.getOffset()
和 ASTNode.getLength()
获得),我认为它们的编号相同 space.