//===--- CERTTidyModule.cpp - clang-tidy ----------------------------------===// // // 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 // //===----------------------------------------------------------------------===// #include "../ClangTidy.h" #include "../ClangTidyModule.h" #include "../ClangTidyModuleRegistry.h" #include "../bugprone/BadSignalToKillThreadCheck.h" #include "../bugprone/PointerArithmeticOnPolymorphicObjectCheck.h" #include "../bugprone/ReservedIdentifierCheck.h" #include "../bugprone/SignalHandlerCheck.h" #include "../bugprone/SignedCharMisuseCheck.h" #include "../bugprone/SizeofExpressionCheck.h" #include "../bugprone/SpuriouslyWakeUpFunctionsCheck.h" #include "../bugprone/SuspiciousMemoryComparisonCheck.h" #include "../bugprone/UnhandledSelfAssignmentCheck.h" #include "../bugprone/UnsafeFunctionsCheck.h" #include "../bugprone/UnusedReturnValueCheck.h" #include "../concurrency/ThreadCanceltypeAsynchronousCheck.h" #include "../google/UnnamedNamespaceInHeaderCheck.h" #include "../misc/NewDeleteOverloadsCheck.h" #include "../misc/NonCopyableObjects.h" #include "../misc/StaticAssertCheck.h" #include "../misc/ThrowByValueCatchByReferenceCheck.h" #include "../performance/MoveConstructorInitCheck.h" #include "../readability/EnumInitialValueCheck.h" #include "../readability/UppercaseLiteralSuffixCheck.h" #include "CommandProcessorCheck.h" #include "DefaultOperatorNewAlignmentCheck.h" #include "DontModifyStdNamespaceCheck.h" #include "FloatLoopCounter.h" #include "LimitedRandomnessCheck.h" #include "MutatingCopyCheck.h" #include "NonTrivialTypesLibcMemoryCallsCheck.h" #include "ProperlySeededRandomGeneratorCheck.h" #include "SetLongJmpCheck.h" #include "StaticObjectExceptionCheck.h" #include "StrToNumCheck.h" #include "ThrownExceptionTypeCheck.h" #include "VariadicFunctionDefCheck.h" namespace { // Checked functions for cert-err33-c. // The following functions are deliberately excluded because they can be called // with NULL argument and in this case the check is not applicable: // `mblen, mbrlen, mbrtowc, mbtowc, wctomb, wctomb_s`. // FIXME: The check can be improved to handle such cases. const llvm::StringRef CertErr33CCheckedFunctions = "^::aligned_alloc;" "^::asctime_s;" "^::at_quick_exit;" "^::atexit;" "^::bsearch;" "^::bsearch_s;" "^::btowc;" "^::c16rtomb;" "^::c32rtomb;" "^::calloc;" "^::clock;" "^::cnd_broadcast;" "^::cnd_init;" "^::cnd_signal;" "^::cnd_timedwait;" "^::cnd_wait;" "^::ctime_s;" "^::fclose;" "^::fflush;" "^::fgetc;" "^::fgetpos;" "^::fgets;" "^::fgetwc;" "^::fopen;" "^::fopen_s;" "^::fprintf;" "^::fprintf_s;" "^::fputc;" "^::fputs;" "^::fputwc;" "^::fputws;" "^::fread;" "^::freopen;" "^::freopen_s;" "^::fscanf;" "^::fscanf_s;" "^::fseek;" "^::fsetpos;" "^::ftell;" "^::fwprintf;" "^::fwprintf_s;" "^::fwrite;" "^::fwscanf;" "^::fwscanf_s;" "^::getc;" "^::getchar;" "^::getenv;" "^::getenv_s;" "^::gets_s;" "^::getwc;" "^::getwchar;" "^::gmtime;" "^::gmtime_s;" "^::localtime;" "^::localtime_s;" "^::malloc;" "^::mbrtoc16;" "^::mbrtoc32;" "^::mbsrtowcs;" "^::mbsrtowcs_s;" "^::mbstowcs;" "^::mbstowcs_s;" "^::memchr;" "^::mktime;" "^::mtx_init;" "^::mtx_lock;" "^::mtx_timedlock;" "^::mtx_trylock;" "^::mtx_unlock;" "^::printf_s;" "^::putc;" "^::putwc;" "^::raise;" "^::realloc;" "^::remove;" "^::rename;" "^::scanf;" "^::scanf_s;" "^::setlocale;" "^::setvbuf;" "^::signal;" "^::snprintf;" "^::snprintf_s;" "^::sprintf;" "^::sprintf_s;" "^::sscanf;" "^::sscanf_s;" "^::strchr;" "^::strerror_s;" "^::strftime;" "^::strpbrk;" "^::strrchr;" "^::strstr;" "^::strtod;" "^::strtof;" "^::strtoimax;" "^::strtok;" "^::strtok_s;" "^::strtol;" "^::strtold;" "^::strtoll;" "^::strtoul;" "^::strtoull;" "^::strtoumax;" "^::strxfrm;" "^::swprintf;" "^::swprintf_s;" "^::swscanf;" "^::swscanf_s;" "^::thrd_create;" "^::thrd_detach;" "^::thrd_join;" "^::thrd_sleep;" "^::time;" "^::timespec_get;" "^::tmpfile;" "^::tmpfile_s;" "^::tmpnam;" "^::tmpnam_s;" "^::tss_create;" "^::tss_get;" "^::tss_set;" "^::ungetc;" "^::ungetwc;" "^::vfprintf;" "^::vfprintf_s;" "^::vfscanf;" "^::vfscanf_s;" "^::vfwprintf;" "^::vfwprintf_s;" "^::vfwscanf;" "^::vfwscanf_s;" "^::vprintf_s;" "^::vscanf;" "^::vscanf_s;" "^::vsnprintf;" "^::vsnprintf_s;" "^::vsprintf;" "^::vsprintf_s;" "^::vsscanf;" "^::vsscanf_s;" "^::vswprintf;" "^::vswprintf_s;" "^::vswscanf;" "^::vswscanf_s;" "^::vwprintf_s;" "^::vwscanf;" "^::vwscanf_s;" "^::wcrtomb;" "^::wcschr;" "^::wcsftime;" "^::wcspbrk;" "^::wcsrchr;" "^::wcsrtombs;" "^::wcsrtombs_s;" "^::wcsstr;" "^::wcstod;" "^::wcstof;" "^::wcstoimax;" "^::wcstok;" "^::wcstok_s;" "^::wcstol;" "^::wcstold;" "^::wcstoll;" "^::wcstombs;" "^::wcstombs_s;" "^::wcstoul;" "^::wcstoull;" "^::wcstoumax;" "^::wcsxfrm;" "^::wctob;" "^::wctrans;" "^::wctype;" "^::wmemchr;" "^::wprintf_s;" "^::wscanf;" "^::wscanf_s;"; } // namespace namespace clang::tidy { namespace cert { class CERTModule : public ClangTidyModule { public: void addCheckFactories(ClangTidyCheckFactories &CheckFactories) override { // C++ checkers // CON CheckFactories.registerCheck( "cert-con54-cpp"); // CTR CheckFactories .registerCheck( "cert-ctr56-cpp"); // DCL CheckFactories.registerCheck("cert-dcl50-cpp"); CheckFactories.registerCheck( "cert-dcl51-cpp"); CheckFactories.registerCheck( "cert-dcl54-cpp"); CheckFactories.registerCheck( "cert-dcl58-cpp"); CheckFactories.registerCheck( "cert-dcl59-cpp"); // ERR CheckFactories.registerCheck( "cert-err09-cpp"); CheckFactories.registerCheck("cert-err52-cpp"); CheckFactories.registerCheck("cert-err58-cpp"); CheckFactories.registerCheck("cert-err60-cpp"); CheckFactories.registerCheck( "cert-err61-cpp"); // MEM CheckFactories.registerCheck( "cert-mem57-cpp"); // MSC CheckFactories.registerCheck("cert-msc50-cpp"); CheckFactories.registerCheck( "cert-msc51-cpp"); CheckFactories.registerCheck( "cert-msc54-cpp"); // OOP CheckFactories.registerCheck( "cert-oop11-cpp"); CheckFactories.registerCheck( "cert-oop54-cpp"); CheckFactories.registerCheck( "cert-oop57-cpp"); CheckFactories.registerCheck( "cert-oop58-cpp"); // C checkers // ARR CheckFactories.registerCheck( "cert-arr39-c"); // CON CheckFactories.registerCheck( "cert-con36-c"); // DCL CheckFactories.registerCheck("cert-dcl03-c"); CheckFactories.registerCheck( "cert-dcl16-c"); CheckFactories.registerCheck( "cert-dcl37-c"); // ENV CheckFactories.registerCheck("cert-env33-c"); // ERR CheckFactories.registerCheck( "cert-err33-c"); CheckFactories.registerCheck("cert-err34-c"); // EXP CheckFactories.registerCheck( "cert-exp42-c"); // FLP CheckFactories.registerCheck("cert-flp30-c"); CheckFactories.registerCheck( "cert-flp37-c"); // FIO CheckFactories.registerCheck("cert-fio38-c"); // INT CheckFactories.registerCheck( "cert-int09-c"); // MSC CheckFactories.registerCheck( "cert-msc24-c"); CheckFactories.registerCheck("cert-msc30-c"); CheckFactories.registerCheck( "cert-msc32-c"); CheckFactories.registerCheck( "cert-msc33-c"); // POS CheckFactories.registerCheck( "cert-pos44-c"); CheckFactories .registerCheck( "cert-pos47-c"); // SIG CheckFactories.registerCheck("cert-sig30-c"); // STR CheckFactories.registerCheck( "cert-str34-c"); } ClangTidyOptions getModuleOptions() override { ClangTidyOptions Options; ClangTidyOptions::OptionMap &Opts = Options.CheckOptions; Opts["cert-arr39-c.WarnOnSizeOfConstant"] = "false"; Opts["cert-arr39-c.WarnOnSizeOfIntegerExpression"] = "false"; Opts["cert-arr39-c.WarnOnSizeOfThis"] = "false"; Opts["cert-arr39-c.WarnOnSizeOfCompareToConstant"] = "false"; Opts["cert-arr39-c.WarnOnSizeOfPointer"] = "false"; Opts["cert-arr39-c.WarnOnSizeOfPointerToAggregate"] = "false"; Opts["cert-dcl16-c.NewSuffixes"] = "L;LL;LU;LLU"; Opts["cert-err33-c.CheckedFunctions"] = CertErr33CCheckedFunctions; Opts["cert-err33-c.AllowCastToVoid"] = "true"; Opts["cert-oop54-cpp.WarnOnlyIfThisHasSuspiciousField"] = "false"; Opts["cert-str34-c.DiagnoseSignedUnsignedCharComparisons"] = "false"; return Options; } }; } // namespace cert // Register the MiscTidyModule using this statically initialized variable. static ClangTidyModuleRegistry::Add X("cert-module", "Adds lint checks corresponding to CERT secure coding guidelines."); // This anchor is used to force the linker to link in the generated object file // and thus register the CERTModule. volatile int CERTModuleAnchorSource = 0; } // namespace clang::tidy