OSDN Git Service

new
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Sun, 24 May 1998 14:00:07 +0000 (14:00 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Sun, 24 May 1998 14:00:07 +0000 (14:00 +0000)
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@20021 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/testsuite/g++.old-deja/g++.other/delete1.C [new file with mode: 0644]
gcc/testsuite/g++.old-deja/g++.other/virtual1.C [new file with mode: 0644]
gcc/testsuite/g++.old-deja/g++.pt/auto_ptr.C [new file with mode: 0644]

diff --git a/gcc/testsuite/g++.old-deja/g++.other/delete1.C b/gcc/testsuite/g++.old-deja/g++.other/delete1.C
new file mode 100644 (file)
index 0000000..6386fe1
--- /dev/null
@@ -0,0 +1,15 @@
+//Build don't link:
+struct cl_heap_ring{
+    void operator delete (void* ptr) { }
+    cl_heap_ring ()
+    { }
+};
+
+struct cl_heap_null_ring : public cl_heap_ring {
+    void operator delete (void* ptr) { }
+};
+
+void f()
+{
+  new cl_heap_null_ring();
+}
diff --git a/gcc/testsuite/g++.old-deja/g++.other/virtual1.C b/gcc/testsuite/g++.old-deja/g++.other/virtual1.C
new file mode 100644 (file)
index 0000000..2848317
--- /dev/null
@@ -0,0 +1,13 @@
+// Build don't link:
+
+struct S0 { virtual void f1 () { } };
+
+struct S1 : virtual public S0 { virtual void f1 () { } };
+
+struct S2 : public S1 { virtual void f1 () { } };
+
+struct S3 : virtual public S0 { virtual void f1 () { } };
+
+struct S4 : public S3 { };
+
+void creator () { new S4; }
diff --git a/gcc/testsuite/g++.old-deja/g++.pt/auto_ptr.C b/gcc/testsuite/g++.old-deja/g++.pt/auto_ptr.C
new file mode 100644 (file)
index 0000000..dd5b988
--- /dev/null
@@ -0,0 +1,54 @@
+template <typename Y> struct auto_ptr_ref {
+  Y* py;
+  auto_ptr_ref(Y* p) : py(p) {}
+};
+template<typename X> struct auto_ptr {
+   X* px;
+ public:
+   typedef X element_type;
+
+   explicit auto_ptr(X* p =0) throw() : px(p) {}
+   auto_ptr(auto_ptr& r) throw() : px(r.release()) {}
+   template<typename Y>
+      auto_ptr(auto_ptr<Y>& r) throw() : px(r.release()) {}
+
+   auto_ptr& operator=(auto_ptr& r) throw() { 
+      reset(r.release()); 
+      return *this;
+   }
+   template<typename Y> auto_ptr& operator=(auto_ptr<Y>& r) throw() { 
+      reset(r.release()); 
+      return *this;
+   }
+
+   ~auto_ptr() { delete px; }
+
+   X& operator*() const throw() { return *px; }
+   X* operator->() const throw() { return px; }
+   X* get() const throw() { return px; }
+   X* release() throw() { X* p=px; px=0; return p; }
+   void reset(X* p=0) throw() { if (px != p) delete px, px = p; }
+
+   auto_ptr(auto_ptr_ref<X> r) throw() : px(r.py) {}
+   template<typename Y> operator auto_ptr_ref<Y>() throw() {
+      return auto_ptr_ref<Y>(release()); 
+   }
+   template<typename Y> operator auto_ptr<Y>() throw() { 
+      return auto_ptr<Y>(release());
+   }
+};
+
+struct Base { Base() {} virtual ~Base() {} };
+struct Derived : Base { Derived() {}; };
+
+auto_ptr<Derived> f() { auto_ptr<Derived> null(0); return null; }
+void g(auto_ptr<Derived>) { }
+void h(auto_ptr<Base>) { }
+
+int main() {
+    auto_ptr<Base> x(f());
+    auto_ptr<Derived> y(f());
+    x = y;
+    g(f());
+    h(f());
+}