diff options
author | thegeorg <thegeorg@yandex-team.com> | 2024-03-13 13:58:24 +0300 |
---|---|---|
committer | thegeorg <thegeorg@yandex-team.com> | 2024-03-13 14:11:53 +0300 |
commit | 11a895b7e15d1c5a1f52706396b82e3f9db953cb (patch) | |
tree | fabc6d883b0f946151f61ae7865cee9f529a1fdd /contrib/libs/clang16/tools/extra/clang-tidy/utils/ASTUtils.cpp | |
parent | 9685917341315774aad5733b1793b1e533a88bbb (diff) | |
download | ydb-11a895b7e15d1c5a1f52706396b82e3f9db953cb.tar.gz |
Export clang-format16 via ydblib project
6e6be3a95868fde888d801b7590af4044049563f
Diffstat (limited to 'contrib/libs/clang16/tools/extra/clang-tidy/utils/ASTUtils.cpp')
-rw-r--r-- | contrib/libs/clang16/tools/extra/clang-tidy/utils/ASTUtils.cpp | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/contrib/libs/clang16/tools/extra/clang-tidy/utils/ASTUtils.cpp b/contrib/libs/clang16/tools/extra/clang-tidy/utils/ASTUtils.cpp new file mode 100644 index 0000000000..9fda73e904 --- /dev/null +++ b/contrib/libs/clang16/tools/extra/clang-tidy/utils/ASTUtils.cpp @@ -0,0 +1,91 @@ +//===---------- ASTUtils.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 "ASTUtils.h" + +#include "clang/ASTMatchers/ASTMatchFinder.h" +#include "clang/ASTMatchers/ASTMatchers.h" +#include "clang/Lex/Lexer.h" + +namespace clang::tidy::utils { +using namespace ast_matchers; + +const FunctionDecl *getSurroundingFunction(ASTContext &Context, + const Stmt &Statement) { + return selectFirst<const FunctionDecl>( + "function", match(stmt(hasAncestor(functionDecl().bind("function"))), + Statement, Context)); +} + +bool isBinaryOrTernary(const Expr *E) { + const Expr *EBase = E->IgnoreImpCasts(); + if (isa<BinaryOperator>(EBase) || isa<ConditionalOperator>(EBase)) { + return true; + } + + if (const auto *Operator = dyn_cast<CXXOperatorCallExpr>(EBase)) { + return Operator->isInfixBinaryOp(); + } + + return false; +} + +bool exprHasBitFlagWithSpelling(const Expr *Flags, const SourceManager &SM, + const LangOptions &LangOpts, + StringRef FlagName) { + // If the Flag is an integer constant, check it. + if (isa<IntegerLiteral>(Flags)) { + if (!SM.isMacroBodyExpansion(Flags->getBeginLoc()) && + !SM.isMacroArgExpansion(Flags->getBeginLoc())) + return false; + + // Get the macro name. + auto MacroName = Lexer::getSourceText( + CharSourceRange::getTokenRange(Flags->getSourceRange()), SM, LangOpts); + + return MacroName == FlagName; + } + // If it's a binary OR operation. + if (const auto *BO = dyn_cast<BinaryOperator>(Flags)) + if (BO->getOpcode() == BinaryOperatorKind::BO_Or) + return exprHasBitFlagWithSpelling(BO->getLHS()->IgnoreParenCasts(), SM, + LangOpts, FlagName) || + exprHasBitFlagWithSpelling(BO->getRHS()->IgnoreParenCasts(), SM, + LangOpts, FlagName); + + // Otherwise, assume it has the flag. + return true; +} + +bool rangeIsEntirelyWithinMacroArgument(SourceRange Range, + const SourceManager *SM) { + // Check if the range is entirely contained within a macro argument. + SourceLocation MacroArgExpansionStartForRangeBegin; + SourceLocation MacroArgExpansionStartForRangeEnd; + bool RangeIsEntirelyWithinMacroArgument = + SM && + SM->isMacroArgExpansion(Range.getBegin(), + &MacroArgExpansionStartForRangeBegin) && + SM->isMacroArgExpansion(Range.getEnd(), + &MacroArgExpansionStartForRangeEnd) && + MacroArgExpansionStartForRangeBegin == MacroArgExpansionStartForRangeEnd; + + return RangeIsEntirelyWithinMacroArgument; +} + +bool rangeContainsMacroExpansion(SourceRange Range, const SourceManager *SM) { + return rangeIsEntirelyWithinMacroArgument(Range, SM) || + Range.getBegin().isMacroID() || Range.getEnd().isMacroID(); +} + +bool rangeCanBeFixed(SourceRange Range, const SourceManager *SM) { + return utils::rangeIsEntirelyWithinMacroArgument(Range, SM) || + !utils::rangeContainsMacroExpansion(Range, SM); +} + +} // namespace clang::tidy::utils |