Author: ggreif
Date: Fri Aug 27 21:00:22 2010
New Revision: 112347

URL: http://llvm.org/viewvc/llvm-project?rev=112347&view=rev
Log:
check whether sema issues a redefinition error

Modified:
    cfe/trunk/test/SemaTemplate/inject-templated-friend.cpp

Modified: cfe/trunk/test/SemaTemplate/inject-templated-friend.cpp
URL: 
http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaTemplate/inject-templated-friend.cpp?rev=112347&r1=112346&r2=112347&view=diff
==============================================================================
--- cfe/trunk/test/SemaTemplate/inject-templated-friend.cpp (original)
+++ cfe/trunk/test/SemaTemplate/inject-templated-friend.cpp Fri Aug 27 21:00:22 
2010
@@ -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 @@
 template <typename STRUCT_TYPE>
 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 @@
 
 typedef struct Foo {} Foo;
 
-std_ostream& operator << (std_ostream& o, const Streamer<Foo>& f);
-/*std_ostream& operator << (std_ostream& o, const Streamer<Foo>& f)
+std_ostream& operator << (std_ostream&, const Streamer<Foo>&);
+#ifdef REDEFINE
+std_ostream& operator << (std_ostream& o, const Streamer<Foo>&) // 
expected-note{{is here}}
 {
   // Sema should flag this as a redefinition
-}*/
+  return o;
+}
+#endif
 
 template <>
-void Streamer<Foo>::operator () (std_ostream& o) const
+void Streamer<Foo>::operator () (std_ostream& o) const // 
expected-note{{requested here}}
 {
 }
 


_______________________________________________
cfe-commits mailing list
[email protected]
http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits

Reply via email to