From: Gabor Greif Date: Sat, 28 Aug 2010 02:00:22 +0000 (+0000) Subject: check whether sema issues a redefinition error X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=aaafddba8b2b7f2f601bd86fdafaefde38da469d;p=clang check whether sema issues a redefinition error git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@112347 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/SemaTemplate/inject-templated-friend.cpp b/test/SemaTemplate/inject-templated-friend.cpp index 039f6df6ed..fbe86d9638 100644 --- a/test/SemaTemplate/inject-templated-friend.cpp +++ b/test/SemaTemplate/inject-templated-friend.cpp @@ -1,4 +1,5 @@ // RUN: %clang %s -S -emit-llvm -o - | grep -e "define linkonce_odr.*_ZlsR11std_ostreamRK8StreamerI3FooE" +// RUN: %clang -cc1 %s -DREDEFINE -verify // PR8007: friend function not instantiated. struct std_ostream @@ -11,7 +12,7 @@ std_ostream cout; template struct Streamer { - friend std_ostream& operator << (std_ostream& o, const Streamer& f) + friend std_ostream& operator << (std_ostream& o, const Streamer& f) // expected-error{{redefinition of 'operator<<'}} { Streamer s(f); s(o); @@ -26,14 +27,17 @@ struct Streamer typedef struct Foo {} Foo; -std_ostream& operator << (std_ostream& o, const Streamer& f); -/*std_ostream& operator << (std_ostream& o, const Streamer& f) +std_ostream& operator << (std_ostream&, const Streamer&); +#ifdef REDEFINE +std_ostream& operator << (std_ostream& o, const Streamer&) // expected-note{{is here}} { // Sema should flag this as a redefinition -}*/ + return o; +} +#endif template <> -void Streamer::operator () (std_ostream& o) const +void Streamer::operator () (std_ostream& o) const // expected-note{{requested here}} { }