summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/copy-initialization.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2010-04-18 02:16:12 +0000
committerDouglas Gregor <dgregor@apple.com>2010-04-18 02:16:12 +0000
commit7566e4ad2cf1a03fccfe97a110ccf3f5e80f1988 (patch)
treeb314fd37d93965ba5a54088fcfaf78b44b4a5cb5 /clang/test/SemaCXX/copy-initialization.cpp
parent268195e1d4b5bd651654505e51a204f07bfec7b6 (diff)
downloadbcm5719-llvm-7566e4ad2cf1a03fccfe97a110ccf3f5e80f1988.tar.gz
bcm5719-llvm-7566e4ad2cf1a03fccfe97a110ccf3f5e80f1988.zip
Do not consider explicit constructors when performing a copy to a
temporary object. This is blindingly obvious from reading C++ [over.match.ctor]p1, but somehow I'd missed it and it took DR152 to educate me. Adjust one test that was relying on this non-standard behavior. llvm-svn: 101688
Diffstat (limited to 'clang/test/SemaCXX/copy-initialization.cpp')
-rw-r--r--clang/test/SemaCXX/copy-initialization.cpp13
1 files changed, 8 insertions, 5 deletions
diff --git a/clang/test/SemaCXX/copy-initialization.cpp b/clang/test/SemaCXX/copy-initialization.cpp
index ea67e6ffe20..0c4aa964cb6 100644
--- a/clang/test/SemaCXX/copy-initialization.cpp
+++ b/clang/test/SemaCXX/copy-initialization.cpp
@@ -1,18 +1,21 @@
// RUN: %clang_cc1 -fsyntax-only -verify %s
class X {
public:
- explicit X(const X&);
- X(int*); // expected-note 2{{candidate constructor}}
- explicit X(float*);
+ explicit X(const X&); // expected-note {{candidate constructor}}
+ X(int*); // expected-note 3{{candidate constructor}}
+ explicit X(float*); // expected-note {{candidate constructor}}
};
class Y : public X { };
void f(Y y, int *ip, float *fp) {
X x1 = y; // expected-error{{no matching constructor for initialization of 'X'}}
- X x2 = 0;
- X x3 = ip;
+ X x2 = 0; // expected-error{{no viable constructor copying variable}}
+ X x3 = ip; // expected-error{{no viable constructor copying variable}}
X x4 = fp; // expected-error{{no viable conversion}}
+ X x2a(0); // expected-error{{call to constructor of 'X' is ambiguous}}
+ X x3a(ip);
+ X x4a(fp);
}
struct foo {
OpenPOWER on IntegriCloud