At the PythonLabs meeting someone mentioned it would make Jim really
happy if one could delete the __dict__ attribute of an instance.  I
love to make Jim happy, so here goes...

- New-style objects now support deleting their __dict__.  This is for
  all intents and purposes equivalent to assigning a brand new empty
  dictionary, but saves space if the object is not used further.
diff --git a/Lib/test/test_descr.py b/Lib/test/test_descr.py
index 48d1138..b73025b 100644
--- a/Lib/test/test_descr.py
+++ b/Lib/test/test_descr.py
@@ -2261,12 +2261,7 @@
     cant(a, None)
     cant(a, [])
     cant(a, 1)
-    try:
-        del a.__dict__
-    except TypeError:
-        pass
-    else:
-        raise TestFailed, "shouldn't allow del %r.__dict__" % (a)
+    del a.__dict__ # Deleting __dict__ is allowed
     # Classes don't allow __dict__ assignment
     cant(C, {})
 
diff --git a/Misc/NEWS b/Misc/NEWS
index 565c675..58119ea 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -30,6 +30,10 @@
   dict.__hash__ and list.__hash__ now raises the same TypeError
   (previously, these were the same as object.__hash__).
 
+- New-style objects now support deleting their __dict__.  This is for
+  all intents and purposes equivalent to assigning a brand new empty
+  dictionary, but saves space if the object is not used further.
+
 Core and builtins
 
 Extension modules
diff --git a/Objects/typeobject.c b/Objects/typeobject.c
index 16591cf..14a7e86 100644
--- a/Objects/typeobject.c
+++ b/Objects/typeobject.c
@@ -812,13 +812,13 @@
 				"This object has no __dict__");
 		return -1;
 	}
-	if (value == NULL || !PyDict_Check(value)) {
+	if (value != NULL && !PyDict_Check(value)) {
 		PyErr_SetString(PyExc_TypeError,
 				"__dict__ must be set to a dictionary");
 		return -1;
 	}
 	dict = *dictptr;
-	Py_INCREF(value);
+	Py_XINCREF(value);
 	*dictptr = value;
 	Py_XDECREF(dict);
 	return 0;