[Zope-Checkins] CVS: ZODB3/Persistence - cPersistence.c:1.72.8.8

Jeremy Hylton jeremy@zope.com
Thu, 3 Jul 2003 13:25:46 -0400


Update of /cvs-repository/ZODB3/Persistence
In directory cvs.zope.org:/tmp/cvs-serv19607/Persistence

Modified Files:
      Tag: zodb33-devel-branch
	cPersistence.c 
Log Message:
Start a test module for Persistent, and convert attribute access to
_p_oid and _p_jar to use getsets.



=== ZODB3/Persistence/cPersistence.c 1.72.8.7 => 1.72.8.8 ===
--- ZODB3/Persistence/cPersistence.c:1.72.8.7	Tue Jul  1 19:14:58 2003
+++ ZODB3/Persistence/cPersistence.c	Thu Jul  3 13:25:11 2003
@@ -17,6 +17,7 @@
 "$Id$\n";
 
 #include "cPersistence.h"
+#include "structmember.h"
 
 struct ccobject_head_struct {
     CACHE_HEAD
@@ -453,12 +454,6 @@
       if (*n++=='p' && *n++=='_') {
 	switch(*n++)
 	  {
-	  case 'o':
-	    if (*n++=='i' && *n++=='d' && ! *n) return orNothing(self->oid);
-	    break;
-	  case 'j':
-	    if (*n++=='a' && *n++=='r' && ! *n) return orNothing(self->jar);
-	    break;
 	  case 'c':
 	    if (strcmp(n,"hanged")==0)
 	      {
@@ -554,47 +549,7 @@
 	return -1;
 
     if (*name == '_' && name[1] == 'p' && name[2] == '_') {
-	if (strcmp(name + 3, "oid") == 0) {
-	    if (self->cache) {
-		int result;
-		if (v == NULL) {
-		    PyErr_SetString(PyExc_ValueError,
-				    "can not delete oid of cached object");
-		    return -1;
-		}
-		if (PyObject_Cmp(self->oid, v, &result) < 0)
-		    return -1;
-		if (result) {
-		    PyErr_SetString(PyExc_ValueError,
-				    "can not change oid of cached object");
-		    return -1;
-		}
-	    }
-	    Py_XINCREF(v);
-	    ASSIGN(self->oid, v);
-	    return 0;
-	}
-	else if (strcmp(name + 3, "jar") == 0) {
-	    if (self->cache && self->jar) {
-		int result;
-		if (v == NULL) {
-		    PyErr_SetString(PyExc_ValueError,
-				    "can not delete jar of cached object");
-		    return -1;
-		}
-		if (PyObject_Cmp(self->jar, v, &result) < 0)
-		    return -1;
-		if (result) {
-		    PyErr_SetString(PyExc_ValueError,
-				    "can not change jar of cached object");
-		    return -1;
-		}
-	    }
-	    Py_XINCREF(v);
-	    ASSIGN(self->jar, v);
-	    return 0;
-	}
-	else if (strcmp(name + 3, "serial") == 0) {
+	if (strcmp(name + 3, "serial") == 0) {
 	    if (v) {
 		if (PyString_Check(v) && PyString_GET_SIZE(v) == 8)
 		    memcpy(self->serial, PyString_AS_STRING(v), 8);
@@ -714,6 +669,95 @@
   return -1;
 }
 
+/*
+
+static PyMethodDef Per_methods[] = {
+    {"__reduce__", (PyCFunction)persist_reduce, METH_NOARGS, },
+    {"__getstate__", (PyCFunction)persist_getstate, METH_NOARGS, },
+    {"__setstate__", persist_setstate, METH_O, },
+    {"_p_activate", (PyCFunction)persist_activate, METH_NOARGS, },
+    {"_p_deactivate", (PyCFunction)persist_deactivate, METH_KEYWORDS, },
+    {"_p_setattr", (PyCFunction)persist_p_setattr, METH_VARARGS, },
+    {"_p_delattr", (PyCFunction)persist_p_delattr, METH_O, },
+    {NULL}
+};
+
+*/
+
+static PyObject *
+Per_get_oid(cPersistentObject *self)
+{
+    PyObject *oid = self->oid ? self->oid : Py_None;
+    Py_INCREF(oid);
+    return oid;
+}
+
+static int
+Per_set_oid(cPersistentObject *self, PyObject *v)
+{
+    if (self->cache) {
+	int result;
+
+	if (v == NULL) {
+	    PyErr_SetString(PyExc_ValueError,
+			    "can't delete _p_oid of cached object");
+	    return -1;
+	}
+	if (PyObject_Cmp(self->oid, v, &result) < 0)
+	    return -1;
+	if (result) {
+	    PyErr_SetString(PyExc_ValueError,
+			    "can not change _p_oid of cached object");
+	    return -1;
+	}
+    }
+    Py_XDECREF(self->oid);
+    Py_XINCREF(v);
+    self->oid = v;
+    return 0;
+}
+
+static PyObject *
+Per_get_jar(cPersistentObject *self)
+{
+    PyObject *jar = self->jar ? self->jar : Py_None;
+    Py_INCREF(jar);
+    return jar;
+}
+
+static int
+Per_set_jar(cPersistentObject *self, PyObject *v)
+{
+    if (self->cache) {
+	int result;
+
+	if (v == NULL) {
+	    PyErr_SetString(PyExc_ValueError,
+			    "can't delete _p_jar of cached object");
+	    return -1;
+	}
+	if (PyObject_Cmp(self->jar, v, &result) < 0)
+	    return -1;
+	if (result) {
+	    PyErr_SetString(PyExc_ValueError,
+			    "can not change _p_jar of cached object");
+	    return -1;
+	}
+    }
+    Py_XDECREF(self->jar);
+    Py_XINCREF(v);
+    self->jar = v;
+    return 0;
+}
+
+
+static PyGetSetDef Per_getsets[] = {
+/*    {"_p_changed", (getter)Per_get_state, (setter)Per_set_state},  */
+    {"_p_oid", (getter)Per_get_oid, (setter)Per_set_oid},
+    {"_p_jar", (getter)Per_get_jar, (setter)Per_set_jar},
+    {NULL}
+};
+
 /* This module is compiled as a shared library.  Some compilers don't
    allow addresses of Python objects defined in other libraries to be
    used in static initializers here.  The DEFERRED_ADDRESS macro is
@@ -758,6 +802,8 @@
     0,					/* tp_iter */
     0,					/* tp_iternext */
     Per_methods,			/* tp_methods */
+    0,			/* tp_members */
+    Per_getsets,			/* tp_getset */
 };
 
 /* End of code for Persistent objects */