1 //===--- DurationSubtractionCheck.cpp - clang-tidy ------------------------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 #include "DurationSubtractionCheck.h"
10 #include "DurationRewriter.h"
11 #include "clang/AST/ASTContext.h"
12 #include "clang/ASTMatchers/ASTMatchFinder.h"
13 #include "clang/Tooling/FixIt.h"
16 using namespace clang::ast_matchers
;
18 namespace clang::tidy::abseil
{
20 void DurationSubtractionCheck::registerMatchers(MatchFinder
*Finder
) {
24 hasLHS(callExpr(callee(functionDecl(DurationConversionFunction())
25 .bind("function_decl")),
26 hasArgument(0, expr().bind("lhs_arg")))))
31 void DurationSubtractionCheck::check(const MatchFinder::MatchResult
&Result
) {
32 const auto *Binop
= Result
.Nodes
.getNodeAs
<BinaryOperator
>("binop");
33 const auto *FuncDecl
= Result
.Nodes
.getNodeAs
<FunctionDecl
>("function_decl");
35 // Don't try to replace things inside of macro definitions.
36 if (Binop
->getExprLoc().isMacroID() || Binop
->getExprLoc().isInvalid())
39 std::optional
<DurationScale
> Scale
=
40 getScaleForDurationInverse(FuncDecl
->getName());
44 std::string RhsReplacement
=
45 rewriteExprFromNumberToDuration(Result
, *Scale
, Binop
->getRHS());
47 const Expr
*LhsArg
= Result
.Nodes
.getNodeAs
<Expr
>("lhs_arg");
49 diag(Binop
->getBeginLoc(), "perform subtraction in the duration domain")
50 << FixItHint::CreateReplacement(
51 Binop
->getSourceRange(),
52 (llvm::Twine("absl::") + FuncDecl
->getName() + "(" +
53 tooling::fixit::getText(*LhsArg
, *Result
.Context
) + " - " +
58 } // namespace clang::tidy::abseil