mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-29 00:08:59 -04:00

Summary: This is implemented originally by Alex Pilkiewicz (pilki@google.com). Reviewers: alexfh Subscribers: cfe-commits Patch by Haojian Wu! Differential Revision: http://reviews.llvm.org/D16721 llvm-svn: 259195
43 lines
1.4 KiB
C++
43 lines
1.4 KiB
C++
//===--- PeformanceTidyModule.cpp - clang-tidy ----------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "../ClangTidy.h"
|
|
#include "../ClangTidyModule.h"
|
|
#include "../ClangTidyModuleRegistry.h"
|
|
|
|
#include "ImplicitCastInLoopCheck.h"
|
|
#include "UnnecessaryCopyInitialization.h"
|
|
|
|
namespace clang {
|
|
namespace tidy {
|
|
namespace performance {
|
|
|
|
class PerformanceModule : public ClangTidyModule {
|
|
public:
|
|
void addCheckFactories(ClangTidyCheckFactories &CheckFactories) override {
|
|
CheckFactories.registerCheck<ImplicitCastInLoopCheck>(
|
|
"performance-implicit-cast-in-loop");
|
|
CheckFactories.registerCheck<UnnecessaryCopyInitialization>(
|
|
"performance-unnecessary-copy-initialization");
|
|
}
|
|
};
|
|
|
|
// Register the PerformanceModule using this statically initialized variable.
|
|
static ClangTidyModuleRegistry::Add<PerformanceModule>
|
|
X("performance-module", "Adds performance checks.");
|
|
|
|
} // namespace performance
|
|
|
|
// This anchor is used to force the linker to link in the generated object file
|
|
// and thus register the PerformanceModule.
|
|
volatile int PerformanceModuleAnchorSource = 0;
|
|
|
|
} // namespace tidy
|
|
} // namespace clang
|