From 39fcc9a984e2820e4ea0fa2ac4abd17d9f3a31df Mon Sep 17 00:00:00 2001 From: dim Date: Sun, 20 Feb 2011 13:06:31 +0000 Subject: Vendor import of clang trunk r126079: http://llvm.org/svn/llvm-project/cfe/trunk@126079 --- test/SemaCXX/conversion-function.cpp | 30 +++++++++++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) (limited to 'test/SemaCXX/conversion-function.cpp') diff --git a/test/SemaCXX/conversion-function.cpp b/test/SemaCXX/conversion-function.cpp index 07281e1..61c8ada 100644 --- a/test/SemaCXX/conversion-function.cpp +++ b/test/SemaCXX/conversion-function.cpp @@ -50,7 +50,7 @@ class A { }; class B : public A { public: operator A&() const; // expected-warning{{conversion function converting 'B' to its base class 'A' will never be used}} - operator const void() const; // expected-warning{{conversion function converting 'B' to 'void const' will never be used}} + operator const void() const; // expected-warning{{conversion function converting 'B' to 'const void' will never be used}} operator const B(); // expected-warning{{conversion function converting 'B' to itself will never be used}} }; @@ -325,3 +325,31 @@ namespace rdar8018274 { int i = ed; } } + +namespace PR8065 { + template struct Iterator; + template struct Container; + + template<> + struct Iterator { + typedef Container container_type; + }; + + template + struct Container { + typedef typename Iterator::container_type X; + operator X(void) { return X(); } + }; + + Container test; +} + +namespace PR8034 { + struct C { + operator int(); + + private: + template operator T(); + }; + int x = C().operator int(); +} -- cgit v1.1