annotate clang-tools-extra/clang-tidy/abseil/DurationSubtractionCheck.cpp @ 204:e348f3e5c8b2

ReadFromString worked.
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 05 Jun 2021 15:35:13 +0900
parents 1d019706d866
children 1f2b6ac9f198
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===--- DurationSubtractionCheck.cpp - clang-tidy ------------------------===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #include "DurationSubtractionCheck.h"
anatofuz
parents:
diff changeset
10 #include "DurationRewriter.h"
anatofuz
parents:
diff changeset
11 #include "clang/AST/ASTContext.h"
anatofuz
parents:
diff changeset
12 #include "clang/ASTMatchers/ASTMatchFinder.h"
anatofuz
parents:
diff changeset
13 #include "clang/Tooling/FixIt.h"
anatofuz
parents:
diff changeset
14
anatofuz
parents:
diff changeset
15 using namespace clang::ast_matchers;
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 namespace clang {
anatofuz
parents:
diff changeset
18 namespace tidy {
anatofuz
parents:
diff changeset
19 namespace abseil {
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 void DurationSubtractionCheck::registerMatchers(MatchFinder *Finder) {
anatofuz
parents:
diff changeset
22 Finder->addMatcher(
anatofuz
parents:
diff changeset
23 binaryOperator(
anatofuz
parents:
diff changeset
24 hasOperatorName("-"),
anatofuz
parents:
diff changeset
25 hasLHS(callExpr(callee(functionDecl(DurationConversionFunction())
anatofuz
parents:
diff changeset
26 .bind("function_decl")),
anatofuz
parents:
diff changeset
27 hasArgument(0, expr().bind("lhs_arg")))))
anatofuz
parents:
diff changeset
28 .bind("binop"),
anatofuz
parents:
diff changeset
29 this);
anatofuz
parents:
diff changeset
30 }
anatofuz
parents:
diff changeset
31
anatofuz
parents:
diff changeset
32 void DurationSubtractionCheck::check(const MatchFinder::MatchResult &Result) {
anatofuz
parents:
diff changeset
33 const auto *Binop = Result.Nodes.getNodeAs<BinaryOperator>("binop");
anatofuz
parents:
diff changeset
34 const auto *FuncDecl = Result.Nodes.getNodeAs<FunctionDecl>("function_decl");
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 // Don't try to replace things inside of macro definitions.
anatofuz
parents:
diff changeset
37 if (Binop->getExprLoc().isMacroID() || Binop->getExprLoc().isInvalid())
anatofuz
parents:
diff changeset
38 return;
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 llvm::Optional<DurationScale> Scale =
anatofuz
parents:
diff changeset
41 getScaleForDurationInverse(FuncDecl->getName());
anatofuz
parents:
diff changeset
42 if (!Scale)
anatofuz
parents:
diff changeset
43 return;
anatofuz
parents:
diff changeset
44
anatofuz
parents:
diff changeset
45 std::string RhsReplacement =
anatofuz
parents:
diff changeset
46 rewriteExprFromNumberToDuration(Result, *Scale, Binop->getRHS());
anatofuz
parents:
diff changeset
47
anatofuz
parents:
diff changeset
48 const Expr *LhsArg = Result.Nodes.getNodeAs<Expr>("lhs_arg");
anatofuz
parents:
diff changeset
49
anatofuz
parents:
diff changeset
50 diag(Binop->getBeginLoc(), "perform subtraction in the duration domain")
anatofuz
parents:
diff changeset
51 << FixItHint::CreateReplacement(
anatofuz
parents:
diff changeset
52 Binop->getSourceRange(),
anatofuz
parents:
diff changeset
53 (llvm::Twine("absl::") + FuncDecl->getName() + "(" +
anatofuz
parents:
diff changeset
54 tooling::fixit::getText(*LhsArg, *Result.Context) + " - " +
anatofuz
parents:
diff changeset
55 RhsReplacement + ")")
anatofuz
parents:
diff changeset
56 .str());
anatofuz
parents:
diff changeset
57 }
anatofuz
parents:
diff changeset
58
anatofuz
parents:
diff changeset
59 } // namespace abseil
anatofuz
parents:
diff changeset
60 } // namespace tidy
anatofuz
parents:
diff changeset
61 } // namespace clang