CXXOperatorCallExprTraverser.cpp 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. //===- unittest/Tooling/RecursiveASTVisitorTests/CXXOperatorCallExprTraverser.cpp -===//
  2. //
  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
  6. //
  7. //===----------------------------------------------------------------------===//
  8. #include "TestVisitor.h"
  9. using namespace clang;
  10. namespace {
  11. class CXXOperatorCallExprTraverser
  12. : public ExpectedLocationVisitor<CXXOperatorCallExprTraverser> {
  13. public:
  14. // Use Traverse, not Visit, to check that data recursion optimization isn't
  15. // bypassing the call of this function.
  16. bool TraverseCXXOperatorCallExpr(CXXOperatorCallExpr *CE) {
  17. Match(getOperatorSpelling(CE->getOperator()), CE->getExprLoc());
  18. return ExpectedLocationVisitor<CXXOperatorCallExprTraverser>::
  19. TraverseCXXOperatorCallExpr(CE);
  20. }
  21. };
  22. TEST(RecursiveASTVisitor, TraversesOverloadedOperator) {
  23. CXXOperatorCallExprTraverser Visitor;
  24. Visitor.ExpectMatch("()", 4, 9);
  25. EXPECT_TRUE(Visitor.runOver(
  26. "struct A {\n"
  27. " int operator()();\n"
  28. "} a;\n"
  29. "int k = a();\n"));
  30. }
  31. } // end anonymous namespace