r176912 - Test for LLVM r176911

Matt Beaumont-Gay matthewbg at google.com
Tue Mar 12 16:56:17 PDT 2013


Author: matthewbg
Date: Tue Mar 12 18:56:16 2013
New Revision: 176912

URL: http://llvm.org/viewvc/llvm-project?rev=176912&view=rev
Log:
Test for LLVM r176911

Added:
    cfe/trunk/test/Misc/diagnostic-crash.cpp

Added: cfe/trunk/test/Misc/diagnostic-crash.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Misc/diagnostic-crash.cpp?rev=176912&view=auto
==============================================================================
--- cfe/trunk/test/Misc/diagnostic-crash.cpp (added)
+++ cfe/trunk/test/Misc/diagnostic-crash.cpp Tue Mar 12 18:56:16 2013
@@ -0,0 +1,39 @@
+// RUN: %clang_cc1 -verify -fsyntax-only %s
+// The diagnostics we produce for this code tickled a bug in raw_ostream.
+template <typename _Alloc> class allocator;
+template <class _CharT> struct char_traits;
+template <typename _CharT, typename _Traits = char_traits<_CharT>,
+          typename _Alloc = allocator<_CharT> >
+class basic_string;
+typedef basic_string<wchar_t> wstring;
+class Closure {
+};
+template <class A1> class Callback1 {
+};
+template <class A1, class A2> class Callback2 {
+};
+template <class R, class A2> class ResultCallback1 {
+};
+template <bool del, class R, class T, class P1, class P2, class A1>
+class AAAAAAAResultCallback_2_1 : public ResultCallback1<R, A1> {
+};
+template <bool del, class T, class P1, class P2, class A1>
+class AAAAAAAResultCallback_2_1< del, void, T, P1, P2, A1> :
+    public Callback1<A1> {
+ public:
+  typedef Callback1<A1> base;
+};
+template <class T1, class T2, class R, class P1, class P2, class A1>
+inline typename AAAAAAAResultCallback_2_1<true, R, T1, P1, P2, A1>::base*
+NewCallback(T1* obj, R(T2::* member)(P1, P2, A1), const P1& p1, const P2& p2) {}
+namespace util { class Status {}; }
+class xxxxxxxxxxxxxxxxx {
+  void Bar(wstring* s, util::Status* status,
+           Callback2<util::Status, wstring>* done);
+  void Foo();
+};
+void xxxxxxxxxxxxxxxxx::Foo() {
+  wstring* s = __null;
+  util::Status* status = __null;
+  Closure* cb = NewCallback(this, &xxxxxxxxxxxxxxxxx::Bar, s, status);  // expected-error{{cannot initialize}}
+}





More information about the cfe-commits mailing list