A few miscellaneous helpers.

PyObject_Dump(): New function that is useful when debugging Python's C
runtime.  In something like gdb it can be a pain to get some useful
information out of PyObject*'s.  This function prints the str() of the
object to stderr, along with the object's refcount and hex address.

PyGC_Dump(): Similar to PyObject_Dump() but knows how to cast from the
garbage collector prefix back to the PyObject* structure.

[See Misc/gdbinit for some useful gdb hooks]

none_dealloc(): Rather than SEGV if we accidentally decref None out of
existance, we assign None's and NotImplemented's destructor slot to
this function, which just calls abort().
diff --git a/Objects/object.c b/Objects/object.c
index c1a1303..8a49353 100644
--- a/Objects/object.c
+++ b/Objects/object.c
@@ -220,6 +220,19 @@
 	return ret;
 }
 
+/* For debugging convenience.  See Misc/gdbinit for some useful gdb hooks */
+void PyObject_Dump(PyObject* op) 
+{
+	(void)PyObject_Print(op, stderr, 0);
+	fprintf(stderr, "\nrefcounts: %d\n", op->ob_refcnt);
+	fprintf(stderr, "address    : %x\n", op);
+}
+void PyGC_Dump(PyGC_Head* op)
+{
+	PyObject_Dump(PyObject_FROM_GC(op));
+}
+
+
 PyObject *
 PyObject_Repr(PyObject *v)
 {
@@ -1213,13 +1226,24 @@
 	return PyString_FromString("None");
 }
 
+/* ARGUSED */
+static void
+none_dealloc(PyObject* ignore) 
+{
+	/* This should never get called, but we also don't want to SEGV if
+	 * we accidently decref None out of existance.
+	 */
+	abort();
+}
+
+
 static PyTypeObject PyNothing_Type = {
 	PyObject_HEAD_INIT(&PyType_Type)
 	0,
 	"None",
 	0,
 	0,
-	0,		/*tp_dealloc*/ /*never called*/
+	(destructor)none_dealloc,	     /*tp_dealloc*/ /*never called*/
 	0,		/*tp_print*/
 	0,		/*tp_getattr*/
 	0,		/*tp_setattr*/
@@ -1250,7 +1274,7 @@
 	"NotImplemented",
 	0,
 	0,
-	0,		/*tp_dealloc*/ /*never called*/
+	(destructor)none_dealloc,	     /*tp_dealloc*/ /*never called*/
 	0,		/*tp_print*/
 	0,		/*tp_getattr*/
 	0,		/*tp_setattr*/