forked from OSchip/llvm-project
71 lines
3.1 KiB
C++
71 lines
3.1 KiB
C++
//===--- HeaderGuard.h - clang-tidy -----------------------------*- C++ -*-===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_UTILS_HEADERGUARD_H
|
|
#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_UTILS_HEADERGUARD_H
|
|
|
|
#include "../ClangTidyCheck.h"
|
|
#include "../utils/FileExtensionsUtils.h"
|
|
|
|
namespace clang {
|
|
namespace tidy {
|
|
namespace utils {
|
|
|
|
/// Finds and fixes header guards.
|
|
/// The check supports these options:
|
|
/// - `HeaderFileExtensions`: a semicolon-separated list of filename
|
|
/// extensions of header files (The filename extension should not contain
|
|
/// "." prefix). ";h;hh;hpp;hxx" by default.
|
|
///
|
|
/// For extension-less header files, using an empty string or leaving an
|
|
/// empty string between ";" if there are other filename extensions.
|
|
class HeaderGuardCheck : public ClangTidyCheck {
|
|
public:
|
|
HeaderGuardCheck(StringRef Name, ClangTidyContext *Context)
|
|
: ClangTidyCheck(Name, Context),
|
|
RawStringHeaderFileExtensions(Options.getLocalOrGlobal(
|
|
"HeaderFileExtensions", utils::defaultHeaderFileExtensions())) {
|
|
utils::parseFileExtensions(RawStringHeaderFileExtensions,
|
|
HeaderFileExtensions,
|
|
utils::defaultFileExtensionDelimiters());
|
|
}
|
|
void storeOptions(ClangTidyOptions::OptionMap &Opts) override;
|
|
void registerPPCallbacks(const SourceManager &SM, Preprocessor *PP,
|
|
Preprocessor *ModuleExpanderPP) override;
|
|
|
|
/// Ensure that the provided header guard is a non-reserved identifier.
|
|
std::string sanitizeHeaderGuard(StringRef Guard);
|
|
|
|
/// Returns ``true`` if the check should suggest inserting a trailing comment
|
|
/// on the ``#endif`` of the header guard. It will use the same name as
|
|
/// returned by ``HeaderGuardCheck::getHeaderGuard``.
|
|
virtual bool shouldSuggestEndifComment(StringRef Filename);
|
|
/// Returns ``true`` if the check should suggest changing an existing header
|
|
/// guard to the string returned by ``HeaderGuardCheck::getHeaderGuard``.
|
|
virtual bool shouldFixHeaderGuard(StringRef Filename);
|
|
/// Returns ``true`` if the check should add a header guard to the file
|
|
/// if it has none.
|
|
virtual bool shouldSuggestToAddHeaderGuard(StringRef Filename);
|
|
/// Returns a replacement for the ``#endif`` line with a comment mentioning
|
|
/// \p HeaderGuard. The replacement should start with ``endif``.
|
|
virtual std::string formatEndIf(StringRef HeaderGuard);
|
|
/// Gets the canonical header guard for a file.
|
|
virtual std::string getHeaderGuard(StringRef Filename,
|
|
StringRef OldGuard = StringRef()) = 0;
|
|
|
|
private:
|
|
std::string RawStringHeaderFileExtensions;
|
|
utils::FileExtensionsSet HeaderFileExtensions;
|
|
};
|
|
|
|
} // namespace utils
|
|
} // namespace tidy
|
|
} // namespace clang
|
|
|
|
#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_UTILS_HEADERGUARD_H
|