mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-28 15:58:57 -04:00

Summary: The patch adds a new ClangTidy check that detects when expensive-to-copy types are unnecessarily copy initialized from a const reference that has the same or are larger scope than the copy. It currently only detects this when the copied variable is const qualified. But this will be extended to non const variables if they are only used in a const fashion. Reviewers: alexfh Subscribers: cfe-commits Patch by Felix Berger! Differential Revision: http://reviews.llvm.org/D15623 llvm-svn: 256632
40 lines
1.2 KiB
C++
40 lines
1.2 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 "UnnecessaryCopyInitialization.h"
|
|
|
|
namespace clang {
|
|
namespace tidy {
|
|
namespace performance {
|
|
|
|
class PerformanceModule : public ClangTidyModule {
|
|
public:
|
|
void addCheckFactories(ClangTidyCheckFactories &CheckFactories) override {
|
|
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
|