blob: 17e7584a6046b6d3e6975bec5bc09e91d966804f [file] [log] [blame]
Daniel Dunbara5728872009-12-15 20:14:24 +00001// RUN: %clang_cc1 -fsyntax-only -verify -std=c++0x %s
Sebastian Redl7c80bd62009-03-16 23:22:08 +00002
3typedef int&& irr;
4typedef irr& ilr_c1; // Collapses to int&
5typedef int& ilr;
6typedef ilr&& ilr_c2; // Collapses to int&
7
8irr ret_irr() {
9 return 0;
10}
11
12struct not_int {};
13
14int over(int&);
15not_int over(int&&);
16
Douglas Gregor2ff44782009-03-20 20:21:37 +000017int over2(const int&);
18not_int over2(int&&);
19
20struct conv_to_not_int_rvalue {
21 operator not_int &&();
22};
23
Sebastian Redl7c80bd62009-03-16 23:22:08 +000024void f() {
25 int &&virr1; // expected-error {{declaration of reference variable 'virr1' requires an initializer}}
26 int &&virr2 = 0;
Douglas Gregor2ff44782009-03-20 20:21:37 +000027 int &&virr3 = virr2; // expected-error {{rvalue reference cannot bind to lvalue}}
Sebastian Redl7c80bd62009-03-16 23:22:08 +000028 int i1 = 0;
29 int &&virr4 = i1; // expected-error {{rvalue reference cannot bind to lvalue}}
30 int &&virr5 = ret_irr();
Sebastian Redl157be832009-03-22 22:30:06 +000031 int &&virr6 = static_cast<int&&>(i1);
32 (void)static_cast<not_int&&>(i1); // expected-error {{types are not compatible}}
Sebastian Redl7c80bd62009-03-16 23:22:08 +000033
34 int i2 = over(i1);
35 not_int ni1 = over(0);
36 int i3 = over(virr2);
37 not_int ni2 = over(ret_irr());
38
Douglas Gregor2ff44782009-03-20 20:21:37 +000039 int i4 = over2(i1);
Sebastian Redla9845802009-03-29 15:27:50 +000040 not_int ni3 = over2(0);
Douglas Gregor2ff44782009-03-20 20:21:37 +000041
Sebastian Redl7c80bd62009-03-16 23:22:08 +000042 ilr_c1 vilr1 = i1;
43 ilr_c2 vilr2 = i1;
Douglas Gregor2ff44782009-03-20 20:21:37 +000044
45 conv_to_not_int_rvalue cnir;
Sebastian Redla9845802009-03-29 15:27:50 +000046 not_int &&ni4 = cnir; // expected-error {{rvalue reference cannot bind to lvalue}}
Douglas Gregor20093b42009-12-09 23:02:17 +000047 not_int &ni5 = cnir; // expected-error{{non-const lvalue reference to type 'struct not_int' cannot bind to a value of unrelated type 'struct conv_to_not_int_rvalue'}}
Sebastian Redla9845802009-03-29 15:27:50 +000048 not_int &&ni6 = conv_to_not_int_rvalue();
Sebastian Redlf2e21e52009-03-22 23:49:27 +000049
50
51 try {
52 } catch(int&&) { // expected-error {{cannot catch exceptions by rvalue reference}}
53 }
Sebastian Redl7c80bd62009-03-16 23:22:08 +000054}
Sebastian Redle2b68332009-04-12 17:16:29 +000055
56int&& should_warn(int i) {
57 // FIXME: The stack address return test doesn't reason about casts.
58 return static_cast<int&&>(i); // xpected-warning {{returning reference to temporary}}
59}
60int&& should_not_warn(int&& i) { // But GCC 4.4 does
61 return static_cast<int&&>(i);
62}
63
64
65// Test the return dance. This also tests IsReturnCopyElidable.
66struct MoveOnly {
67 MoveOnly();
Fariborz Jahaniancc5306a2009-11-18 18:26:29 +000068 MoveOnly(const MoveOnly&) = delete; // expected-note {{candidate function}}
69 MoveOnly(MoveOnly&&); // expected-note {{candidate function}}
70 MoveOnly(int&&); // expected-note {{candidate function}}
Sebastian Redle2b68332009-04-12 17:16:29 +000071};
72
73MoveOnly returning() {
74 MoveOnly mo;
75 return mo;
76}
77
78MoveOnly gmo;
79MoveOnly returningNonEligible() {
80 int i;
81 static MoveOnly mo;
82 MoveOnly &r = mo;
83 if (0) // Copy from global can't be elided
84 return gmo; // expected-error {{incompatible type returning}}
85 else if (0) // Copy from local static can't be elided
86 return mo; // expected-error {{incompatible type returning}}
87 else if (0) // Copy from reference can't be elided
88 return r; // expected-error {{incompatible type returning}}
89 else // Construction from different type can't be elided
Fariborz Jahaniancc5306a2009-11-18 18:26:29 +000090 return i; // expected-error {{no viable conversion from 'int' to 'struct MoveOnly'}}
Sebastian Redle2b68332009-04-12 17:16:29 +000091}