aboutsummaryrefslogtreecommitdiff
path: root/clang/test/SemaCXX/restrict-this.cpp
blob: e78c8e0d56e2f877b2f41da32141cf5c7be478e3 (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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// RUN: %clang_cc1 -verify -fsyntax-only %s
// expected-no-diagnostics

struct C {
  void f() __restrict {
    static_assert(__is_same(decltype(this), C *__restrict));
    (void) [this]() {
      static_assert(__is_same(decltype(this), C *__restrict));
      (void) [this]() { static_assert(__is_same(decltype(this), C *__restrict)); };

      // By-value capture means 'this' is now a different object; do not
      // make it __restrict.
      (void) [*this]() { static_assert(__is_same(decltype(this), const C *)); };
      (void) [*this]() mutable { static_assert(__is_same(decltype(this), C *)); };
    };
  }
};

template <typename T> struct TC {
  void f() __restrict {
    static_assert(__is_same(decltype(this), TC<int> *__restrict));
    (void) [this]() {
      static_assert(__is_same(decltype(this), TC<int> *__restrict));
      (void) [this]() { static_assert(__is_same(decltype(this), TC<int> *__restrict)); };

      // By-value capture means 'this' is now a different object; do not
      // make it __restrict.
      (void) [*this]() { static_assert(__is_same(decltype(this), const TC<int> *)); };
      (void) [*this]() mutable { static_assert(__is_same(decltype(this), TC<int> *)); };
    };
  }
};

void f() {
  TC<int>{}.f();
}

namespace gh18121 {
struct Foo {
  void member() __restrict {
    Foo *__restrict This = this;
  }
};
}

namespace gh42411 {
struct foo {
    int v;
    void f() const __restrict {
        static_assert(__is_same(decltype((v)), const int&));
        (void) [this]() { static_assert(__is_same(decltype((v)), const int&)); };
    }
};
}

namespace gh82941 {
void f(int& x) {
    (void)x;
}

class C {
    int x;
    void g() __restrict;
};

void C::g() __restrict {
    f(this->x);
}
}