[cfe-commits] r112369 - /cfe/trunk/test/SemaTemplate/inject-templated-friend-post.cpp

Gabor Greif ggreif at gmail.com
Sat Aug 28 05:12:45 PDT 2010


Author: ggreif
Date: Sat Aug 28 07:12:45 2010
New Revision: 112369

URL: http://llvm.org/viewvc/llvm-project?rev=112369&view=rev
Log:
add another test for PR8007
this is still failing, need to come up with a fix
(but we are in good company as the first gcc version
 pass this test will be v4.6)

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

Added: cfe/trunk/test/SemaTemplate/inject-templated-friend-post.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaTemplate/inject-templated-friend-post.cpp?rev=112369&view=auto
==============================================================================
--- cfe/trunk/test/SemaTemplate/inject-templated-friend-post.cpp (added)
+++ cfe/trunk/test/SemaTemplate/inject-templated-friend-post.cpp Sat Aug 28 07:12:45 2010
@@ -0,0 +1,58 @@
+// 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, reordered version.
+// Corresponds to http://gcc.gnu.org/bugzilla/show_bug.cgi?id=38392
+// XFAIL: *
+
+struct std_ostream
+{
+  int dummy;
+};
+
+std_ostream cout;
+
+template <typename STRUCT_TYPE>
+struct Streamer;
+
+typedef struct Foo {} Foo;
+
+std_ostream& operator << (std_ostream&, const Streamer<Foo>&);
+void test(const Streamer<Foo>& foo)
+{
+    cout << foo;
+}
+
+template <typename STRUCT_TYPE>
+struct Streamer
+{
+    friend std_ostream& operator << (std_ostream& o, const Streamer& f) // expected-error{{redefinition of 'operator<<'}}
+        {
+            Streamer s(f);
+            s(o);
+            return o;
+        }
+
+    Streamer(const STRUCT_TYPE& s) : s(s) {}
+
+    const STRUCT_TYPE& s;
+    void operator () (std_ostream&) const;
+};
+
+template <>
+void Streamer<Foo>::operator () (std_ostream& o) const // expected-note{{requested here}}
+{
+}
+
+int main(void)
+{
+    Foo foo;
+    test(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





More information about the cfe-commits mailing list