mirror of
https://github.com/Kitware/CMake.git
synced 2025-10-14 10:47:59 +08:00

Run the `clang-format.bash` script to update all our C and C++ code to a new style defined by `.clang-format`, now with "east const" enforcement. Use `clang-format` version 18. * If you reached this commit for a line in `git blame`, re-run the blame operation starting at the parent of this commit to see older history for the content. * See the parent commit for instructions to rebase a change across this style transition commit. Issue: #26123
53 lines
1.5 KiB
C++
53 lines
1.5 KiB
C++
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
|
#include "OstringstreamUseCmstrcatCheck.h"
|
|
|
|
#include <clang/AST/Type.h>
|
|
#include <clang/ASTMatchers/ASTMatchFinder.h>
|
|
|
|
namespace clang {
|
|
namespace tidy {
|
|
namespace cmake {
|
|
using namespace ast_matchers;
|
|
|
|
OstringstreamUseCmstrcatCheck::OstringstreamUseCmstrcatCheck(
|
|
StringRef Name, ClangTidyContext* Context)
|
|
: ClangTidyCheck(Name, Context)
|
|
{
|
|
}
|
|
|
|
void OstringstreamUseCmstrcatCheck::registerMatchers(MatchFinder* Finder)
|
|
{
|
|
Finder->addMatcher(
|
|
typeLoc(unless(elaboratedTypeLoc()),
|
|
optionally(hasParent(elaboratedTypeLoc().bind("parentType"))),
|
|
loc(qualType(
|
|
hasDeclaration(namedDecl(hasName("::std::ostringstream"))))))
|
|
.bind("ostringstream"),
|
|
this);
|
|
}
|
|
|
|
void OstringstreamUseCmstrcatCheck::check(
|
|
MatchFinder::MatchResult const& Result)
|
|
{
|
|
TypeLoc const* ParentTypeNode =
|
|
Result.Nodes.getNodeAs<TypeLoc>("parentType");
|
|
TypeLoc const* RootNode = Result.Nodes.getNodeAs<TypeLoc>("ostringstream");
|
|
|
|
if (ParentTypeNode != nullptr) {
|
|
if (ParentTypeNode->getBeginLoc().isValid()) {
|
|
this->diag(ParentTypeNode->getBeginLoc(),
|
|
"use strings and cmStrCat() instead of std::ostringstream");
|
|
}
|
|
|
|
} else if (RootNode != nullptr) {
|
|
if (RootNode->getBeginLoc().isValid()) {
|
|
this->diag(RootNode->getBeginLoc(),
|
|
"use strings and cmStrCat() instead of std::ostringstream");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|