2016-04-27 22:27:05 +08:00
|
|
|
//===-- FindAllSymbols.h - find all symbols----------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2016-04-27 22:27:05 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_CLANG_TOOLS_EXTRA_FIND_ALL_SYMBOLS_SYMBOL_MATCHER_H
|
|
|
|
#define LLVM_CLANG_TOOLS_EXTRA_FIND_ALL_SYMBOLS_SYMBOL_MATCHER_H
|
|
|
|
|
|
|
|
#include "SymbolInfo.h"
|
2016-05-20 16:04:36 +08:00
|
|
|
#include "SymbolReporter.h"
|
2016-04-27 22:27:05 +08:00
|
|
|
#include "clang/ASTMatchers/ASTMatchFinder.h"
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace find_all_symbols {
|
|
|
|
|
2016-05-18 00:48:49 +08:00
|
|
|
class HeaderMapCollector;
|
|
|
|
|
Remove \brief commands from doxygen comments.
Summary:
We've been running doxygen with the autobrief option for a couple of
years now. This makes the \brief markers into our comments
redundant. Since they are a visual distraction and we don't want to
encourage more \brief markers in new code either, this patch removes
them all.
Patch produced by
for i in $(git grep -l '\\brief'); do perl -pi -e 's/\\brief //g' $i & done
[This is analogous to LLVM r331272 and CFE r331834]
Subscribers: srhines, nemanjai, javed.absar, kbarton, MaskRay, jkorous, arphaman, jfb, kadircet, jsji, cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D66578
llvm-svn: 369643
2019-08-22 19:32:57 +08:00
|
|
|
/// FindAllSymbols collects all classes, free standing functions and
|
2016-04-27 22:27:05 +08:00
|
|
|
/// global variables with some extra information such as the path of the header
|
|
|
|
/// file, the namespaces they are contained in, the type of variables and the
|
|
|
|
/// parameter types of functions.
|
|
|
|
///
|
|
|
|
/// NOTE:
|
|
|
|
/// - Symbols declared in main files are not collected since they can not be
|
|
|
|
/// included.
|
|
|
|
/// - Member functions are not collected because accessing them must go
|
|
|
|
/// through the class. #include fixer only needs the class name to find
|
|
|
|
/// headers.
|
|
|
|
///
|
2017-02-28 16:13:15 +08:00
|
|
|
class FindAllSymbols : public ast_matchers::MatchFinder::MatchCallback {
|
2016-04-27 22:27:05 +08:00
|
|
|
public:
|
2016-05-20 16:04:36 +08:00
|
|
|
explicit FindAllSymbols(SymbolReporter *Reporter,
|
2016-05-20 17:12:01 +08:00
|
|
|
HeaderMapCollector *Collector = nullptr)
|
2016-05-18 00:48:49 +08:00
|
|
|
: Reporter(Reporter), Collector(Collector) {}
|
2016-04-27 22:27:05 +08:00
|
|
|
|
2017-02-28 16:13:15 +08:00
|
|
|
void registerMatchers(ast_matchers::MatchFinder *MatchFinder);
|
2016-04-27 22:27:05 +08:00
|
|
|
|
2017-02-28 16:13:15 +08:00
|
|
|
void run(const ast_matchers::MatchFinder::MatchResult &result) override;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
void onEndOfTranslationUnit() override;
|
2016-04-27 22:27:05 +08:00
|
|
|
|
|
|
|
private:
|
2017-02-28 16:13:15 +08:00
|
|
|
// Current source file being processed, filled by first symbol found.
|
|
|
|
std::string Filename;
|
|
|
|
// Findings for the current source file, flushed on onEndOfTranslationUnit.
|
|
|
|
SymbolInfo::SignalMap FileSymbols;
|
2016-05-18 00:48:49 +08:00
|
|
|
// Reporter for SymbolInfo.
|
2016-05-20 16:04:36 +08:00
|
|
|
SymbolReporter *const Reporter;
|
2016-05-18 00:48:49 +08:00
|
|
|
// A remapping header file collector allowing clients include a different
|
|
|
|
// header.
|
|
|
|
HeaderMapCollector *const Collector;
|
2016-04-27 22:27:05 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace find_all_symbols
|
|
|
|
} // namespace clang
|
|
|
|
|
|
|
|
#endif // LLVM_CLANG_TOOLS_EXTRA_FIND_ALL_SYMBOLS_SYMBOL_MATCHER_H
|