summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/deleted-function.cpp
diff options
context:
space:
mode:
authorSebastian Redl <sebastian.redl@getdesigned.at>2009-04-12 17:16:29 +0000
committerSebastian Redl <sebastian.redl@getdesigned.at>2009-04-12 17:16:29 +0000
commit42e92c4bc3e11d4dce0aa01f0949a4a7dadeeb7a (patch)
tree83a6bdfa6d3707d0ce02ea5655d1e5378ed1771f /clang/test/SemaCXX/deleted-function.cpp
parente4bd8904f7020af2e392dddb0ab2de048678aeab (diff)
downloadbcm5719-llvm-42e92c4bc3e11d4dce0aa01f0949a4a7dadeeb7a.tar.gz
bcm5719-llvm-42e92c4bc3e11d4dce0aa01f0949a4a7dadeeb7a.zip
Parse deleted member functions. Parsing member declarations goes through a different code path that I forgot previously.
Implement the rvalue reference overload dance for returning local objects. Returning a local object first tries to find a move constructor now. The error message when no move constructor is defined (or is not applicable) and the copy constructor is deleted is quite ugly, though. llvm-svn: 68902
Diffstat (limited to 'clang/test/SemaCXX/deleted-function.cpp')
-rw-r--r--clang/test/SemaCXX/deleted-function.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/deleted-function.cpp b/clang/test/SemaCXX/deleted-function.cpp
index 59a8260334a..0e363960232 100644
--- a/clang/test/SemaCXX/deleted-function.cpp
+++ b/clang/test/SemaCXX/deleted-function.cpp
@@ -15,8 +15,20 @@ void fn3() {
void ov(int) {} // expected-note {{candidate function}}
void ov(double) = delete; // expected-note {{candidate function has been explicitly deleted}}
+struct WithDel {
+ WithDel() = delete; // expected-note {{candidate function has been explicitly deleted}}
+ void fn() = delete; // expected-note {{function has been explicitly marked deleted here}}
+ operator int() = delete;
+ void operator +(int) = delete;
+};
+
void test() {
fn(); // expected-error {{call to deleted function 'fn'}}
ov(1);
ov(1.0); // expected-error {{call to deleted function 'ov'}}
+
+ WithDel dd; // expected-error {{call to deleted constructor of 'dd'}}
+ WithDel *d = 0;
+ d->fn(); // expected-error {{attempt to use a deleted function}}
+ int i = *d; // expected-error {{incompatible type initializing}}
}
OpenPOWER on IntegriCloud