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