mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-21 04:25:45 -04:00

Summary: [[ https://bugs.llvm.org/show_bug.cgi?id=39224 | PR39224 ]] As discussed, we can't always do the transform automatically due to that array-to-pointer decay of C array. In order to detect whether we can do said transform, we'd need to be able to see all usages of said array, which is, i would say, rather impossible if e.g. it is in the header. Thus right now no fixit exists. Exceptions: `extern "C"` code. References: * [[ https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines#es27-use-stdarray-or-stack_array-for-arrays-on-the-stack | CPPCG ES.27: Use std::array or stack_array for arrays on the stack ]] * [[ https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines#slcon1-prefer-using-stl-array-or-vector-instead-of-a-c-array | CPPCG SL.con.1: Prefer using STL array or vector instead of a C array ]] * HICPP `4.1.1 Ensure that a function argument does not undergo an array-to-pointer conversion` * MISRA `5-2-12 An identifier with array type passed as a function argument shall not decay to a pointer` Reviewers: aaron.ballman, JonasToth, alexfh, hokein, xazax.hun Reviewed By: JonasToth Subscribers: Eugene.Zelenko, mgorny, rnkovacs, cfe-commits Tags: #clang-tools-extra Differential Revision: https://reviews.llvm.org/D53771 llvm-svn: 346835
111 lines
4.7 KiB
C++
111 lines
4.7 KiB
C++
//===--- CppCoreGuidelinesModule.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 "../misc/NonPrivateMemberVariablesInClassesCheck.h"
|
|
#include "../misc/UnconventionalAssignOperatorCheck.h"
|
|
#include "../modernize/AvoidCArraysCheck.h"
|
|
#include "../readability/MagicNumbersCheck.h"
|
|
#include "AvoidGotoCheck.h"
|
|
#include "InterfacesGlobalInitCheck.h"
|
|
#include "MacroUsageCheck.h"
|
|
#include "NarrowingConversionsCheck.h"
|
|
#include "NoMallocCheck.h"
|
|
#include "OwningMemoryCheck.h"
|
|
#include "ProBoundsArrayToPointerDecayCheck.h"
|
|
#include "ProBoundsConstantArrayIndexCheck.h"
|
|
#include "ProBoundsPointerArithmeticCheck.h"
|
|
#include "ProTypeConstCastCheck.h"
|
|
#include "ProTypeCstyleCastCheck.h"
|
|
#include "ProTypeMemberInitCheck.h"
|
|
#include "ProTypeReinterpretCastCheck.h"
|
|
#include "ProTypeStaticCastDowncastCheck.h"
|
|
#include "ProTypeUnionAccessCheck.h"
|
|
#include "ProTypeVarargCheck.h"
|
|
#include "SlicingCheck.h"
|
|
#include "SpecialMemberFunctionsCheck.h"
|
|
|
|
namespace clang {
|
|
namespace tidy {
|
|
namespace cppcoreguidelines {
|
|
|
|
/// A module containing checks of the C++ Core Guidelines
|
|
class CppCoreGuidelinesModule : public ClangTidyModule {
|
|
public:
|
|
void addCheckFactories(ClangTidyCheckFactories &CheckFactories) override {
|
|
CheckFactories.registerCheck<modernize::AvoidCArraysCheck>(
|
|
"cppcoreguidelines-avoid-c-arrays");
|
|
CheckFactories.registerCheck<AvoidGotoCheck>(
|
|
"cppcoreguidelines-avoid-goto");
|
|
CheckFactories.registerCheck<readability::MagicNumbersCheck>(
|
|
"cppcoreguidelines-avoid-magic-numbers");
|
|
CheckFactories.registerCheck<InterfacesGlobalInitCheck>(
|
|
"cppcoreguidelines-interfaces-global-init");
|
|
CheckFactories.registerCheck<MacroUsageCheck>(
|
|
"cppcoreguidelines-macro-usage");
|
|
CheckFactories.registerCheck<NarrowingConversionsCheck>(
|
|
"cppcoreguidelines-narrowing-conversions");
|
|
CheckFactories.registerCheck<NoMallocCheck>("cppcoreguidelines-no-malloc");
|
|
CheckFactories.registerCheck<misc::NonPrivateMemberVariablesInClassesCheck>(
|
|
"cppcoreguidelines-non-private-member-variables-in-classes");
|
|
CheckFactories.registerCheck<OwningMemoryCheck>(
|
|
"cppcoreguidelines-owning-memory");
|
|
CheckFactories.registerCheck<ProBoundsArrayToPointerDecayCheck>(
|
|
"cppcoreguidelines-pro-bounds-array-to-pointer-decay");
|
|
CheckFactories.registerCheck<ProBoundsConstantArrayIndexCheck>(
|
|
"cppcoreguidelines-pro-bounds-constant-array-index");
|
|
CheckFactories.registerCheck<ProBoundsPointerArithmeticCheck>(
|
|
"cppcoreguidelines-pro-bounds-pointer-arithmetic");
|
|
CheckFactories.registerCheck<ProTypeConstCastCheck>(
|
|
"cppcoreguidelines-pro-type-const-cast");
|
|
CheckFactories.registerCheck<ProTypeCstyleCastCheck>(
|
|
"cppcoreguidelines-pro-type-cstyle-cast");
|
|
CheckFactories.registerCheck<ProTypeMemberInitCheck>(
|
|
"cppcoreguidelines-pro-type-member-init");
|
|
CheckFactories.registerCheck<ProTypeReinterpretCastCheck>(
|
|
"cppcoreguidelines-pro-type-reinterpret-cast");
|
|
CheckFactories.registerCheck<ProTypeStaticCastDowncastCheck>(
|
|
"cppcoreguidelines-pro-type-static-cast-downcast");
|
|
CheckFactories.registerCheck<ProTypeUnionAccessCheck>(
|
|
"cppcoreguidelines-pro-type-union-access");
|
|
CheckFactories.registerCheck<ProTypeVarargCheck>(
|
|
"cppcoreguidelines-pro-type-vararg");
|
|
CheckFactories.registerCheck<SpecialMemberFunctionsCheck>(
|
|
"cppcoreguidelines-special-member-functions");
|
|
CheckFactories.registerCheck<SlicingCheck>("cppcoreguidelines-slicing");
|
|
CheckFactories.registerCheck<misc::UnconventionalAssignOperatorCheck>(
|
|
"cppcoreguidelines-c-copy-assignment-signature");
|
|
}
|
|
|
|
ClangTidyOptions getModuleOptions() override {
|
|
ClangTidyOptions Options;
|
|
ClangTidyOptions::OptionMap &Opts = Options.CheckOptions;
|
|
|
|
Opts["cppcoreguidelines-non-private-member-variables-in-classes."
|
|
"IgnoreClassesWithAllMemberVariablesBeingPublic"] = "1";
|
|
|
|
return Options;
|
|
}
|
|
};
|
|
|
|
// Register the LLVMTidyModule using this statically initialized variable.
|
|
static ClangTidyModuleRegistry::Add<CppCoreGuidelinesModule>
|
|
X("cppcoreguidelines-module", "Adds checks for the C++ Core Guidelines.");
|
|
|
|
} // namespace cppcoreguidelines
|
|
|
|
// This anchor is used to force the linker to link in the generated object file
|
|
// and thus register the CppCoreGuidelinesModule.
|
|
volatile int CppCoreGuidelinesModuleAnchorSource = 0;
|
|
|
|
} // namespace tidy
|
|
} // namespace clang
|