diff options
author | Aaron Ballman <aaron@aaronballman.com> | 2024-01-30 13:38:18 -0500 |
---|---|---|
committer | Aaron Ballman <aaron@aaronballman.com> | 2024-01-30 13:38:18 -0500 |
commit | 201eb2b5775cf193c97c60a5eb790003a1e6bedb (patch) | |
tree | f11f41d4e2747e9737dd1c7122a771f75df3e921 /clang/test/AST/ast-dump-static-operators.cpp | |
parent | 3477bcf4b94395e2c0ed77a139e54240cfe4f27d (diff) | |
download | llvm-201eb2b5775cf193c97c60a5eb790003a1e6bedb.zip llvm-201eb2b5775cf193c97c60a5eb790003a1e6bedb.tar.gz llvm-201eb2b5775cf193c97c60a5eb790003a1e6bedb.tar.bz2 |
Revert "[clang] static operators should evaluate object argument (#68485)"
This reverts commit 30155fc0ef4fbdce2d79434aaae8d58b2fabb20a.
It seems to have broken some tests in clangd:
http://45.33.8.238/linux/129484/step_9.txt
Diffstat (limited to 'clang/test/AST/ast-dump-static-operators.cpp')
-rw-r--r-- | clang/test/AST/ast-dump-static-operators.cpp | 55 |
1 files changed, 0 insertions, 55 deletions
diff --git a/clang/test/AST/ast-dump-static-operators.cpp b/clang/test/AST/ast-dump-static-operators.cpp deleted file mode 100644 index e8454bd..0000000 --- a/clang/test/AST/ast-dump-static-operators.cpp +++ /dev/null @@ -1,55 +0,0 @@ -// RUN: %clang_cc1 -std=c++23 %s -ast-dump -triple x86_64-unknown-unknown -o - | FileCheck -strict-whitespace %s - -struct Functor { - static int operator()(int x, int y) { - return x + y; - } - static int operator[](int x, int y) { - return x + y; - } -}; - -Functor& get_functor() { - static Functor functor; - return functor; -} - -void call_static_operators() { - Functor functor; - - int z1 = functor(1, 2); - // CHECK: CXXOperatorCallExpr {{.*}} 'int' '()' - // CHECK-NEXT: |-ImplicitCastExpr {{.*}} <col:19, col:24> 'int (*)(int, int)' <FunctionToPointerDecay> - // CHECK-NEXT: | `-DeclRefExpr {{.*}} <col:19, col:24> 'int (int, int)' lvalue CXXMethod {{.*}} 'operator()' 'int (int, int)' - // CHECK-NEXT: |-DeclRefExpr {{.*}} <col:12> 'Functor' lvalue Var {{.*}} 'functor' 'Functor' - // CHECK-NEXT: |-IntegerLiteral {{.*}} <col:20> 'int' 1 - // CHECK-NEXT: `-IntegerLiteral {{.*}} <col:23> 'int' 2 - - int z2 = functor[1, 2]; - // CHECK: CXXOperatorCallExpr {{.*}} 'int' '[]' - // CHECK-NEXT: |-ImplicitCastExpr {{.*}} <col:19, col:24> 'int (*)(int, int)' <FunctionToPointerDecay> - // CHECK-NEXT: | `-DeclRefExpr {{.*}} <col:19, col:24> 'int (int, int)' lvalue CXXMethod {{.*}} 'operator[]' 'int (int, int)' - // CHECK-NEXT: |-DeclRefExpr {{.*}} <col:12> 'Functor' lvalue Var {{.*}} 'functor' 'Functor' - // CHECK-NEXT: |-IntegerLiteral {{.*}} <col:20> 'int' 1 - // CHECK-NEXT: `-IntegerLiteral {{.*}} <col:23> 'int' 2 - - int z3 = get_functor()(1, 2); - // CHECK: CXXOperatorCallExpr {{.*}} 'int' '()' - // CHECK-NEXT: |-ImplicitCastExpr {{.*}} <col:25, col:30> 'int (*)(int, int)' <FunctionToPointerDecay> - // CHECK-NEXT: | `-DeclRefExpr {{.*}} <col:25, col:30> 'int (int, int)' lvalue CXXMethod {{.*}} 'operator()' 'int (int, int)' - // CHECK-NEXT: |-CallExpr {{.*}} <col:12, col:24> 'Functor' lvalue - // CHECK-NEXT: | `-ImplicitCastExpr {{.*}} <col:12> 'Functor &(*)()' <FunctionToPointerDecay> - // CHECK-NEXT: | `-DeclRefExpr {{.*}} <col:12> 'Functor &()' lvalue Function {{.*}} 'get_functor' 'Functor &()' - // CHECK-NEXT: |-IntegerLiteral {{.*}} <col:26> 'int' 1 - // CHECK-NEXT: `-IntegerLiteral {{.*}} <col:29> 'int' 2 - - int z4 = get_functor()[1, 2]; - // CHECK: CXXOperatorCallExpr {{.*}} 'int' '[]' - // CHECK-NEXT: |-ImplicitCastExpr {{.*}} <col:25, col:30> 'int (*)(int, int)' <FunctionToPointerDecay> - // CHECK-NEXT: | `-DeclRefExpr {{.*}} <col:25, col:30> 'int (int, int)' lvalue CXXMethod {{.*}} 'operator[]' 'int (int, int)' - // CHECK-NEXT: |-CallExpr {{.*}} <col:12, col:24> 'Functor' lvalue - // CHECK-NEXT: | `-ImplicitCastExpr {{.*}} <col:12> 'Functor &(*)()' <FunctionToPointerDecay> - // CHECK-NEXT: | `-DeclRefExpr {{.*}} <col:12> 'Functor &()' lvalue Function {{.*}} 'get_functor' 'Functor &()' - // CHECK-NEXT: |-IntegerLiteral {{.*}} <col:26> 'int' 1 - // CHECK-NEXT: `-IntegerLiteral {{.*}} <col:29> 'int' 2 -} |