aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2009-07-24 23:57:20 -0400
committerJason Merrill <jason@gcc.gnu.org>2009-07-24 23:57:20 -0400
commit67a6e8167985001be8a50485a8cd8a0d0355a363 (patch)
treea1321c242570af678195bae067b31b4c26c4980e
parent05b5c4e8742e5deba247f5a68eec43b13e88ce8c (diff)
downloadgcc-67a6e8167985001be8a50485a8cd8a0d0355a363.zip
gcc-67a6e8167985001be8a50485a8cd8a0d0355a363.tar.gz
gcc-67a6e8167985001be8a50485a8cd8a0d0355a363.tar.bz2
Core issue 901
Core issue 901 * libsupc++/vec.cc (__cxa_vec_new2, __cxa_vec_new3): Handle NULL dealloc. * call.c (build_op_delete_call): If this is for a new-expression and the op delete is deleted, do nothing. From-SVN: r150073
-rw-r--r--gcc/cp/ChangeLog4
-rw-r--r--gcc/cp/call.c4
-rw-r--r--gcc/testsuite/ChangeLog2
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/defaulted11.C15
-rw-r--r--libstdc++-v3/ChangeLog6
-rw-r--r--libstdc++-v3/libsupc++/vec.cc8
6 files changed, 37 insertions, 2 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 6bb4a57..2ee951c 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,5 +1,9 @@
2009-07-24 Jason Merrill <jason@redhat.com>
+ Core issue 901
+ * call.c (build_op_delete_call): If this is for a new-expression
+ and the op delete is deleted, do nothing.
+
Core issue 702
* call.c (compare_ics): Give list-initialization of std::init_list
priority over conversion to scalar, too.
diff --git a/gcc/cp/call.c b/gcc/cp/call.c
index d396aff..0254ecb 100644
--- a/gcc/cp/call.c
+++ b/gcc/cp/call.c
@@ -4595,6 +4595,10 @@ build_op_delete_call (enum tree_code code, tree addr, tree size,
if (DECL_CLASS_SCOPE_P (fn))
perform_or_defer_access_check (TYPE_BINFO (type), fn, fn);
+ /* Core issue 901: It's ok to new a type with deleted delete. */
+ if (DECL_DELETED_FN (fn) && alloc_fn)
+ return NULL_TREE;
+
if (placement)
{
/* The placement args might not be suitable for overload
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index ea7a034..00dbba7 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,7 @@
2009-07-24 Jason Merrill <jason@redhat.com>
+ * g++.dg/cpp0x/defaulted11.C: New.
+
* g++.dg/cpp0x/initlist23.C: New.
2009-07-24 Janus Weil <janus@gcc.gnu.org>
diff --git a/gcc/testsuite/g++.dg/cpp0x/defaulted11.C b/gcc/testsuite/g++.dg/cpp0x/defaulted11.C
new file mode 100644
index 0000000..b9bed7e
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/defaulted11.C
@@ -0,0 +1,15 @@
+// Core issue 901
+// { dg-options "-std=c++0x" }
+
+struct A
+{
+ A(); ~A();
+ void operator delete (void *) = delete;
+ void operator delete[] (void *) = delete;
+};
+
+int main()
+{
+ A* ap = new A;
+ ap = new A[2];
+}
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index a89a4a6..21f67c5 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,9 @@
+2009-07-24 Jason Merrill <jason@redhat.com>
+
+ Core issue 901
+ * libsupc++/vec.cc (__cxa_vec_new2, __cxa_vec_new3): Handle NULL
+ dealloc.
+
2009-07-24 Joseph Myers <joseph@codesourcery.com>
* include/c_global/cwchar (swprintf, vswprintf): Do not use if
diff --git a/libstdc++-v3/libsupc++/vec.cc b/libstdc++-v3/libsupc++/vec.cc
index f132289..e44a023 100644
--- a/libstdc++-v3/libsupc++/vec.cc
+++ b/libstdc++-v3/libsupc++/vec.cc
@@ -104,7 +104,10 @@ namespace __cxxabiv1
{
{
uncatch_exception ue;
- dealloc(base - padding_size);
+ // Core issue 901 will probably be resolved such that a
+ // deleted operator delete means not freeing memory here.
+ if (dealloc)
+ dealloc(base - padding_size);
}
__throw_exception_again;
}
@@ -142,7 +145,8 @@ namespace __cxxabiv1
{
{
uncatch_exception ue;
- dealloc(base - padding_size, size);
+ if (dealloc)
+ dealloc(base - padding_size, size);
}
__throw_exception_again;
}