forked from OSchip/llvm-project
65 lines
2.7 KiB
C++
65 lines
2.7 KiB
C++
//===--- HeaderGuard.h - clang-tidy -----------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_UTILS_HEADERGUARD_H
|
|
#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_UTILS_HEADERGUARD_H
|
|
|
|
#include "../ClangTidy.h"
|
|
#include "../utils/HeaderFileExtensionsUtils.h"
|
|
|
|
namespace clang {
|
|
namespace tidy {
|
|
namespace utils {
|
|
|
|
/// Finds and fixes header guards.
|
|
/// The check supports these options:
|
|
/// - `HeaderFileExtensions`: a comma-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", ",h,hh,hpp,hxx")) {
|
|
utils::parseHeaderFileExtensions(RawStringHeaderFileExtensions,
|
|
HeaderFileExtensions, ',');
|
|
}
|
|
void registerPPCallbacks(CompilerInstance &Compiler) override;
|
|
|
|
/// 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::HeaderFileExtensionsSet HeaderFileExtensions;
|
|
};
|
|
|
|
} // namespace utils
|
|
} // namespace tidy
|
|
} // namespace clang
|
|
|
|
#endif // LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_UTILS_HEADERGUARD_H
|