forked from OSchip/llvm-project
Re-applied r198807, r198808 with an additional change to fix linking in configure Release+Asserts build.
llvm-svn: 198875
This commit is contained in:
parent
219719a2da
commit
0ba86b73aa
|
@ -5,6 +5,7 @@ set(LLVM_LINK_COMPONENTS
|
||||||
add_clang_library(clangTidy
|
add_clang_library(clangTidy
|
||||||
ClangTidy.cpp
|
ClangTidy.cpp
|
||||||
ClangTidyModule.cpp
|
ClangTidyModule.cpp
|
||||||
|
ClangTidyDiagnosticConsumer.cpp
|
||||||
)
|
)
|
||||||
target_link_libraries(clangTidy
|
target_link_libraries(clangTidy
|
||||||
clangAST
|
clangAST
|
||||||
|
|
|
@ -174,38 +174,6 @@ bool ChecksFilter::IsCheckEnabled(StringRef Name) {
|
||||||
return EnableChecks.match(Name) && !DisableChecks.match(Name);
|
return EnableChecks.match(Name) && !DisableChecks.match(Name);
|
||||||
}
|
}
|
||||||
|
|
||||||
ClangTidyMessage::ClangTidyMessage(StringRef Message) : Message(Message) {}
|
|
||||||
|
|
||||||
ClangTidyMessage::ClangTidyMessage(StringRef Message,
|
|
||||||
const SourceManager &Sources,
|
|
||||||
SourceLocation Loc)
|
|
||||||
: Message(Message) {
|
|
||||||
FilePath = Sources.getFilename(Loc);
|
|
||||||
FileOffset = Sources.getFileOffset(Loc);
|
|
||||||
}
|
|
||||||
|
|
||||||
ClangTidyError::ClangTidyError(const ClangTidyMessage &Message)
|
|
||||||
: Message(Message) {}
|
|
||||||
|
|
||||||
DiagnosticBuilder ClangTidyContext::Diag(SourceLocation Loc,
|
|
||||||
StringRef Message) {
|
|
||||||
return DiagEngine->Report(
|
|
||||||
Loc, DiagEngine->getCustomDiagID(DiagnosticsEngine::Warning, Message));
|
|
||||||
}
|
|
||||||
|
|
||||||
void ClangTidyContext::setDiagnosticsEngine(DiagnosticsEngine *Engine) {
|
|
||||||
DiagEngine = Engine;
|
|
||||||
}
|
|
||||||
|
|
||||||
void ClangTidyContext::setSourceManager(SourceManager *SourceMgr) {
|
|
||||||
DiagEngine->setSourceManager(SourceMgr);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// \brief Store a \c ClangTidyError.
|
|
||||||
void ClangTidyContext::storeError(const ClangTidyError &Error) {
|
|
||||||
Errors->push_back(Error);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ClangTidyCheck::run(const ast_matchers::MatchFinder::MatchResult &Result) {
|
void ClangTidyCheck::run(const ast_matchers::MatchFinder::MatchResult &Result) {
|
||||||
Context->setSourceManager(Result.SourceManager);
|
Context->setSourceManager(Result.SourceManager);
|
||||||
check(Result);
|
check(Result);
|
||||||
|
|
|
@ -0,0 +1,117 @@
|
||||||
|
//===--- tools/extra/clang-tidy/ClangTidyDiagnosticConsumer.cpp ----------=== //
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
///
|
||||||
|
/// \file This file implements ClangTidyDiagnosticConsumer, ClangTidyMessage,
|
||||||
|
/// ClangTidyContext and ClangTidyError classes.
|
||||||
|
///
|
||||||
|
/// This tool uses the Clang Tooling infrastructure, see
|
||||||
|
/// http://clang.llvm.org/docs/HowToSetupToolingForLLVM.html
|
||||||
|
/// for details on setting it up with LLVM source tree.
|
||||||
|
///
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "ClangTidyDiagnosticConsumer.h"
|
||||||
|
|
||||||
|
#include "llvm/ADT/SmallString.h"
|
||||||
|
|
||||||
|
namespace clang {
|
||||||
|
namespace tidy {
|
||||||
|
|
||||||
|
ClangTidyMessage::ClangTidyMessage(StringRef Message) : Message(Message) {}
|
||||||
|
|
||||||
|
ClangTidyMessage::ClangTidyMessage(StringRef Message,
|
||||||
|
const SourceManager &Sources,
|
||||||
|
SourceLocation Loc)
|
||||||
|
: Message(Message) {
|
||||||
|
FilePath = Sources.getFilename(Loc);
|
||||||
|
FileOffset = Sources.getFileOffset(Loc);
|
||||||
|
}
|
||||||
|
|
||||||
|
ClangTidyError::ClangTidyError(const ClangTidyMessage &Message)
|
||||||
|
: Message(Message) {}
|
||||||
|
|
||||||
|
DiagnosticBuilder ClangTidyContext::Diag(SourceLocation Loc,
|
||||||
|
StringRef Message) {
|
||||||
|
return DiagEngine->Report(
|
||||||
|
Loc, DiagEngine->getCustomDiagID(DiagnosticsEngine::Warning, Message));
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClangTidyContext::setDiagnosticsEngine(DiagnosticsEngine *Engine) {
|
||||||
|
DiagEngine = Engine;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClangTidyContext::setSourceManager(SourceManager *SourceMgr) {
|
||||||
|
DiagEngine->setSourceManager(SourceMgr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// \brief Store a \c ClangTidyError.
|
||||||
|
void ClangTidyContext::storeError(const ClangTidyError &Error) {
|
||||||
|
Errors->push_back(Error);
|
||||||
|
}
|
||||||
|
|
||||||
|
ClangTidyDiagnosticConsumer::ClangTidyDiagnosticConsumer(ClangTidyContext &Ctx)
|
||||||
|
: Context(Ctx) {
|
||||||
|
IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts = new DiagnosticOptions();
|
||||||
|
Diags.reset(new DiagnosticsEngine(
|
||||||
|
IntrusiveRefCntPtr<DiagnosticIDs>(new DiagnosticIDs), &*DiagOpts, this,
|
||||||
|
/*ShouldOwnClient=*/false));
|
||||||
|
Context.setDiagnosticsEngine(Diags.get());
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClangTidyDiagnosticConsumer::HandleDiagnostic(
|
||||||
|
DiagnosticsEngine::Level DiagLevel, const Diagnostic &Info) {
|
||||||
|
// FIXME: Demultiplex diagnostics.
|
||||||
|
// FIXME: Ensure that we don't get notes from user code related to errors
|
||||||
|
// from non-user code.
|
||||||
|
if (Diags->getSourceManager().isInSystemHeader(Info.getLocation()))
|
||||||
|
return;
|
||||||
|
if (DiagLevel != DiagnosticsEngine::Note) {
|
||||||
|
Errors.push_back(ClangTidyError(getMessage(Info)));
|
||||||
|
} else {
|
||||||
|
assert(!Errors.empty() &&
|
||||||
|
"A diagnostic note can only be appended to a message.");
|
||||||
|
Errors.back().Notes.push_back(getMessage(Info));
|
||||||
|
}
|
||||||
|
addFixes(Info, Errors.back());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Flushes the internal diagnostics buffer to the ClangTidyContext.
|
||||||
|
void ClangTidyDiagnosticConsumer::finish() {
|
||||||
|
for (unsigned i = 0, e = Errors.size(); i != e; ++i) {
|
||||||
|
Context.storeError(Errors[i]);
|
||||||
|
}
|
||||||
|
Errors.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClangTidyDiagnosticConsumer::addFixes(const Diagnostic &Info,
|
||||||
|
ClangTidyError &Error) {
|
||||||
|
if (!Info.hasSourceManager())
|
||||||
|
return;
|
||||||
|
SourceManager &SourceMgr = Info.getSourceManager();
|
||||||
|
tooling::Replacements Replacements;
|
||||||
|
for (unsigned i = 0, e = Info.getNumFixItHints(); i != e; ++i) {
|
||||||
|
Error.Fix.insert(tooling::Replacement(
|
||||||
|
SourceMgr, Info.getFixItHint(i).RemoveRange.getBegin(), 0,
|
||||||
|
Info.getFixItHint(i).CodeToInsert));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ClangTidyMessage
|
||||||
|
ClangTidyDiagnosticConsumer::getMessage(const Diagnostic &Info) const {
|
||||||
|
SmallString<100> Buf;
|
||||||
|
Info.FormatDiagnostic(Buf);
|
||||||
|
if (!Info.hasSourceManager()) {
|
||||||
|
return ClangTidyMessage(Buf.str());
|
||||||
|
}
|
||||||
|
return ClangTidyMessage(Buf.str(), Info.getSourceManager(),
|
||||||
|
Info.getLocation());
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace tidy
|
||||||
|
} // namespace clang
|
|
@ -13,7 +13,6 @@
|
||||||
#include "clang/Basic/Diagnostic.h"
|
#include "clang/Basic/Diagnostic.h"
|
||||||
#include "clang/Basic/SourceManager.h"
|
#include "clang/Basic/SourceManager.h"
|
||||||
#include "clang/Tooling/Refactoring.h"
|
#include "clang/Tooling/Refactoring.h"
|
||||||
#include "llvm/ADT/SmallString.h"
|
|
||||||
|
|
||||||
namespace clang {
|
namespace clang {
|
||||||
|
|
||||||
|
@ -103,63 +102,20 @@ private:
|
||||||
// implementation file.
|
// implementation file.
|
||||||
class ClangTidyDiagnosticConsumer : public DiagnosticConsumer {
|
class ClangTidyDiagnosticConsumer : public DiagnosticConsumer {
|
||||||
public:
|
public:
|
||||||
ClangTidyDiagnosticConsumer(ClangTidyContext &Ctx) : Context(Ctx) {
|
ClangTidyDiagnosticConsumer(ClangTidyContext &Ctx);
|
||||||
IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts = new DiagnosticOptions();
|
|
||||||
Diags.reset(new DiagnosticsEngine(
|
|
||||||
IntrusiveRefCntPtr<DiagnosticIDs>(new DiagnosticIDs), &*DiagOpts, this,
|
|
||||||
/*ShouldOwnClient=*/false));
|
|
||||||
Context.setDiagnosticsEngine(Diags.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
// FIXME: The concept of converting between FixItHints and Replacements is
|
// FIXME: The concept of converting between FixItHints and Replacements is
|
||||||
// more generic and should be pulled out into a more useful Diagnostics
|
// more generic and should be pulled out into a more useful Diagnostics
|
||||||
// library.
|
// library.
|
||||||
virtual void HandleDiagnostic(DiagnosticsEngine::Level DiagLevel,
|
virtual void HandleDiagnostic(DiagnosticsEngine::Level DiagLevel,
|
||||||
const Diagnostic &Info) LLVM_OVERRIDE {
|
const Diagnostic &Info) LLVM_OVERRIDE;
|
||||||
// FIXME: Ensure that we don't get notes from user code related to errors
|
|
||||||
// from non-user code.
|
|
||||||
if (Diags->getSourceManager().isInSystemHeader(Info.getLocation()))
|
|
||||||
return;
|
|
||||||
if (DiagLevel != DiagnosticsEngine::Note) {
|
|
||||||
Errors.push_back(ClangTidyError(getMessage(Info)));
|
|
||||||
} else {
|
|
||||||
assert(!Errors.empty() &&
|
|
||||||
"A diagnostic note can only be appended to a message.");
|
|
||||||
Errors.back().Notes.push_back(getMessage(Info));
|
|
||||||
}
|
|
||||||
addFixes(Info, Errors.back());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Flushes the internal diagnostics buffer to the ClangTidyContext.
|
// Flushes the internal diagnostics buffer to the ClangTidyContext.
|
||||||
virtual void finish() LLVM_OVERRIDE {
|
virtual void finish() LLVM_OVERRIDE;
|
||||||
for (unsigned i = 0, e = Errors.size(); i != e; ++i) {
|
|
||||||
Context.storeError(Errors[i]);
|
|
||||||
}
|
|
||||||
Errors.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void addFixes(const Diagnostic &Info, ClangTidyError &Error) {
|
void addFixes(const Diagnostic &Info, ClangTidyError &Error);
|
||||||
if (!Info.hasSourceManager())
|
ClangTidyMessage getMessage(const Diagnostic &Info) const;
|
||||||
return;
|
|
||||||
SourceManager &SourceMgr = Info.getSourceManager();
|
|
||||||
tooling::Replacements Replacements;
|
|
||||||
for (unsigned i = 0, e = Info.getNumFixItHints(); i != e; ++i) {
|
|
||||||
Error.Fix.insert(tooling::Replacement(
|
|
||||||
SourceMgr, Info.getFixItHint(i).RemoveRange.getBegin(), 0,
|
|
||||||
Info.getFixItHint(i).CodeToInsert));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ClangTidyMessage getMessage(const Diagnostic &Info) const {
|
|
||||||
SmallString<100> Buf;
|
|
||||||
Info.FormatDiagnostic(Buf);
|
|
||||||
if (!Info.hasSourceManager()) {
|
|
||||||
return ClangTidyMessage(Buf.str());
|
|
||||||
}
|
|
||||||
return ClangTidyMessage(Buf.str(), Info.getSourceManager(),
|
|
||||||
Info.getLocation());
|
|
||||||
}
|
|
||||||
|
|
||||||
ClangTidyContext &Context;
|
ClangTidyContext &Context;
|
||||||
OwningPtr<DiagnosticsEngine> Diags;
|
OwningPtr<DiagnosticsEngine> Diags;
|
||||||
|
|
|
@ -14,6 +14,7 @@ TESTNAME = ClangTidy
|
||||||
LINK_COMPONENTS := asmparser bitreader support MC MCParser option \
|
LINK_COMPONENTS := asmparser bitreader support MC MCParser option \
|
||||||
TransformUtils
|
TransformUtils
|
||||||
USEDLIBS = clangTidy.a clangTidyLLVMModule.a clangTidyGoogleModule.a \
|
USEDLIBS = clangTidy.a clangTidyLLVMModule.a clangTidyGoogleModule.a \
|
||||||
|
clangTidy.a \
|
||||||
clangStaticAnalyzerFrontend.a clangStaticAnalyzerCheckers.a \
|
clangStaticAnalyzerFrontend.a clangStaticAnalyzerCheckers.a \
|
||||||
clangStaticAnalyzerCore.a \
|
clangStaticAnalyzerCore.a \
|
||||||
clangFormat.a clangTooling.a clangFrontend.a clangSerialization.a \
|
clangFormat.a clangTooling.a clangFrontend.a clangSerialization.a \
|
||||||
|
|
Loading…
Reference in New Issue