-
Notifications
You must be signed in to change notification settings - Fork 122
/
CommentHandling.cpp
117 lines (99 loc) · 3.43 KB
/
CommentHandling.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#include <iostream>
#include <vector>
#include <memory>
#include "llvm/Support/CommandLine.h"
#include "clang/Basic/SourceLocation.h"
#include "clang/AST/ASTConsumer.h"
#include "clang/AST/ASTContext.h"
#include "clang/Parse/Parser.h"
#include "clang/Frontend/CompilerInstance.h"
#include "clang/Tooling/CommonOptionsParser.h"
#include "clang/Tooling/Tooling.h"
using namespace clang::driver;
using namespace clang::tooling;
using clang::FileID;
static llvm::cl::OptionCategory MyToolCategory("");
/******************************************************************************
*
*****************************************************************************/
namespace tooling {
class MyCommentHandler : public clang::CommentHandler
{
private:
llvm::StringRef m_inFile;
public:
void set_InFile(llvm::StringRef inFile)
{
m_inFile = inFile;
}
virtual bool HandleComment( clang::Preprocessor &pp, clang::SourceRange rng)
{
clang::SourceManager &sm = pp.getSourceManager();
if( sm.getFilename(rng.getBegin()) == m_inFile)
{
std::pair<FileID, unsigned int> startLoc = sm.getDecomposedLoc(rng.getBegin());
std::pair<FileID, unsigned int> endLoc = sm.getDecomposedLoc(rng.getEnd());
llvm::StringRef fileData = sm.getBufferData(startLoc.first);
std::cout << fileData.substr(startLoc.second, endLoc.second - startLoc.second).str();
std::cout << std::endl;
}
return false;
}
};
/******************************************************************************
*
*****************************************************************************/
class MyASTConsumer : public clang::ASTConsumer
{
public:
MyASTConsumer() : clang::ASTConsumer() { }
virtual ~MyASTConsumer() { }
virtual bool HandleTopLevelDecl( clang::DeclGroupRef d)
{
static int count = 0;
clang::DeclGroupRef::iterator it;
for( it = d.begin(); it != d.end(); it++)
{
count++;
clang::VarDecl *vd = llvm::dyn_cast<clang::VarDecl>(*it);
if(!vd)
{
continue;
}
if( vd->isFileVarDecl() && !vd->hasExternalStorage() )
{
std::cerr << "Read top-level variable decl: '";
std::cerr << vd->getDeclName().getAsString() ;
std::cerr << std::endl;
}
}
return true;
}
};
/******************************************************************************
*
*****************************************************************************/
class MyFactory : public clang::ASTFrontendAction
{
private:
MyCommentHandler ch;
public:
std::unique_ptr<clang::ASTConsumer> CreateASTConsumer(clang::CompilerInstance &ci, llvm::StringRef inFile) {
ch.set_InFile(inFile);
ci.getPreprocessor().addCommentHandler(&ch);
return llvm::make_unique<MyASTConsumer>();
}
};
} // Namespace tooling
/******************************************************************************
*
*****************************************************************************/
int main(int argc, const char **argv)
{
CommonOptionsParser OptionsParser(argc, argv, MyToolCategory);
ClangTool Tool(OptionsParser.getCompilations(),
OptionsParser.getSourcePathList());
std::unique_ptr<FrontendActionFactory> factory = newFrontendActionFactory<tooling::MyFactory>();
Tool.run(factory.get());
return 0;
}