[cfe-commits] r74216 - /cfe/trunk/test/SemaCXX/default-assignment-operator.cpp

Fariborz Jahanian fjahanian at apple.com
Thu Jun 25 15:40:36 PDT 2009


Author: fjahanian
Date: Thu Jun 25 17:40:36 2009
New Revision: 74216

URL: http://llvm.org/viewvc/llvm-project?rev=74216&view=rev
Log:
Test case  for my last patch.

Added:
    cfe/trunk/test/SemaCXX/default-assignment-operator.cpp

Added: cfe/trunk/test/SemaCXX/default-assignment-operator.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/default-assignment-operator.cpp?rev=74216&view=auto

==============================================================================
--- cfe/trunk/test/SemaCXX/default-assignment-operator.cpp (added)
+++ cfe/trunk/test/SemaCXX/default-assignment-operator.cpp Thu Jun 25 17:40:36 2009
@@ -0,0 +1,74 @@
+// RUN: clang-cc -fsyntax-only -verify %s
+
+class Base { // expected-error {{cannot define the implicit default assignment operator for 'class Base'}} \
+             // expected-note {{synthesized method is first required here}}
+  int &ref;  // expected-note {{declared at}}
+};
+
+class X  : Base {  // // expected-error {{cannot define the implicit default assignment operator for 'class X'}}
+public:
+  X();
+  const int cint;  // expected-note {{declared at}}
+}; 
+
+struct Y  : X { 
+  Y();
+  Y& operator=(const Y&);
+  Y& operator=(volatile Y&);
+  Y& operator=(const volatile Y&);
+  Y& operator=(Y&);
+}; 
+
+class Z : Y {};
+
+Z z1;
+Z z2;
+
+// Test1
+void f(X x, const X cx) {
+  x = cx;	// expected-note {{synthesized method is first required here}}
+  x = cx;
+  z1 = z2;
+}
+
+// Test2
+class T {};
+T t1;
+T t2;
+
+void g()
+{
+  t1 = t2;
+}
+
+// Test3
+class V {
+public:
+  V();
+  V &operator = (V &b);
+};
+
+class W : V {};
+W w1, w2;
+
+void h()
+{
+  w1 = w2;
+}
+
+// Test4
+
+class B1 {
+public:
+  B1();
+  B1 &operator = (B1 b);
+};
+
+class D1 : B1 {};
+D1 d1, d2;
+
+void i()
+{
+	d1 = d2;
+}
+





More information about the cfe-commits mailing list