minix/external/bsd/llvm/dist/clang/test/SemaCXX/cxx0x-delegating-ctors.cpp
Lionel Sambuc f4a2713ac8 Importing netbsd clang -- pristine
Change-Id: Ia40e9ffdf29b5dab2f122f673ff6802a58bc690f
2014-07-28 17:05:57 +02:00

50 lines
1 KiB
C++

// RUN: %clang_cc1 -fsyntax-only -std=c++11 -verify %s
struct foo {
int i;
foo();
foo(int);
foo(int, int);
foo(bool);
foo(char);
foo(const float*);
foo(const float&);
foo(void*);
};
// Good
foo::foo (int i) : i(i) {
}
// Good
foo::foo () : foo(-1) {
}
// Good
foo::foo (int, int) : foo() {
}
foo::foo (bool) : foo(true) { // expected-error{{creates a delegation cycle}}
}
// Good
foo::foo (const float* f) : foo(*f) { // expected-note{{it delegates to}}
}
foo::foo (const float &f) : foo(&f) { //expected-error{{creates a delegation cycle}} \
//expected-note{{which delegates to}}
}
foo::foo (char) :
i(3),
foo(3) { // expected-error{{must appear alone}}
}
// This should not cause an infinite loop
foo::foo (void*) : foo(4.0f) {
}
struct deleted_dtor {
~deleted_dtor() = delete; // expected-note{{function has been explicitly marked deleted here}}
deleted_dtor();
deleted_dtor(int) : deleted_dtor() // expected-error{{attempt to use a deleted function}}
{}
};