summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/test/clang-tidy/checkers/google-overloaded-unary-and.cpp
blob: 16893d2725ad91e4e29ebc56b6e931375661fc1e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
// RUN: %check_clang_tidy %s google-runtime-operator %t

struct Foo {
  void *operator&();
// CHECK-MESSAGES: :[[@LINE-1]]:3: warning: do not overload unary operator&, it is dangerous. [google-runtime-operator]
};

template <typename T>
struct TFoo {
  T *operator&();
// CHECK-MESSAGES: :[[@LINE-1]]:3: warning: do not overload unary operator&
};

TFoo<int> tfoo;

struct Bar;
void *operator&(Bar &b);
// CHECK-MESSAGES: :[[@LINE-1]]:1: warning: do not overload unary operator&

// No warnings on binary operators.
struct Qux {
  void *operator&(Qux &q);
};

void *operator&(Qux &q, Qux &r);
OpenPOWER on IntegriCloud