[Zope-Checkins] CVS: Zope3/lib/python/Persistence - cPersistence.c:1.1.2.13 cPersistence.h:1.1.2.5 cPersistenceAPI.h:1.1.2.5
Jeremy Hylton
jeremy@zope.com
Tue, 4 Jun 2002 11:45:39 -0400
Update of /cvs-repository/Zope3/lib/python/Persistence
In directory cvs.zope.org:/tmp/cvs-serv19248
Modified Files:
Tag: Zope-3x-branch
cPersistence.c cPersistence.h cPersistenceAPI.h
Log Message:
Define a PyPersistBaseObject that has the layout of PyPersist_HEAD.
The distinction between PyPersistBaseObject and PyPersistObject is
that the latter has po_dict, which can hold an __dict__ attribute.
Change the basic persistence API to deal in PyPersistBaseObject.
=== Zope3/lib/python/Persistence/cPersistence.c 1.1.2.12 => 1.1.2.13 ===
PyObject *
-PyPersist_RegisterDataManager(PyPersistObject *self)
+PyPersist_RegisterDataManager(PyPersistBaseObject *self)
{
PyObject *meth, *arg, *result;
@@ -71,7 +71,7 @@
*/
PyObject *
-PyPersist_Load(PyPersistObject *self)
+PyPersist_Load(PyPersistBaseObject *self)
{
static PyObject *s_setstate = NULL;
PyObject *meth, *arg, *result;
@@ -105,7 +105,7 @@
*/
int
-PyPersist_RegisterTransaction(PyPersistObject *self)
+PyPersist_RegisterTransaction(PyPersistBaseObject *self)
{
static PyObject *get_transaction = NULL;
PyObject *mainmod = NULL, *builtins = NULL;
@@ -182,7 +182,7 @@
*/
void
-PyPersist_SetATime(PyPersistObject *self)
+PyPersist_SetATime(PyPersistBaseObject *self)
{
time_t t = time(NULL);
self->po_atime = t % 86400;
@@ -378,7 +378,7 @@
if (newstate == CHANGED_TRUE || newstate == CHANGED_FALSE) {
/* Turn a ghost into a real object. */
self->po_state = CHANGED;
- if (PyPersist_Load(self) == NULL)
+ if (PyPersist_Load((PyPersistBaseObject *)self) == NULL)
return -1;
if (newstate == CHANGED_TRUE)
self->po_state = CHANGED;
@@ -389,7 +389,7 @@
/* Mark an up-to-date object as changed. */
if (self->po_state == UPTODATE) {
self->po_state = CHANGED;
- if (PyPersist_RegisterDataManager(self) == NULL)
+ if (!PyPersist_RegisterDataManager((PyPersistBaseObject *)self))
return -1;
}
} else if (newstate == CHANGED_FALSE) {
@@ -491,14 +491,14 @@
&& (strcmp(s_name, "__dict__") != 0))) {
if (self->po_state == GHOST) {
self->po_state = CHANGED;
- if (PyPersist_Load(self) == NULL) {
+ if (PyPersist_Load((PyPersistBaseObject *)self) == NULL) {
persist_deactivate(self);
self->po_state = GHOST;
return NULL;
} else
self->po_state = UPTODATE;
}
- PyPersist_SetATime(self);
+ PyPersist_SetATime((PyPersistBaseObject *)self);
}
attr = PyObject_GenericGetAttr((PyObject *)self, name);
@@ -547,15 +547,15 @@
"attempt to modify unrevivable ghost");
return -1;
}
- if (PyPersist_Load(self) == NULL)
+ if (PyPersist_Load((PyPersistBaseObject *)self) == NULL)
return -1;
} else if (self->po_state == UPTODATE && self->po_dm)
- if (PyPersist_RegisterDataManager(self) == NULL)
+ if (!PyPersist_RegisterDataManager((PyPersistBaseObject *)self))
return -1;
if (self->po_dm && self->po_oid) {
self->po_state = CHANGED;
- PyPersist_SetATime(self);
+ PyPersist_SetATime((PyPersistBaseObject *)self);
}
}
=== Zope3/lib/python/Persistence/cPersistence.h 1.1.2.4 => 1.1.2.5 ===
typedef struct {
+ PyPersist_HEAD
+} PyPersistBaseObject;
+
+typedef struct {
PyPersist_INSTANCE_HEAD
} PyPersistObject;
/* XXX need to make these macros in cPersistenceAPI.h */
-extern PyObject *PyPersist_Load(PyPersistObject *);
-extern PyObject *PyPersist_RegisterDataManager(PyPersistObject *);
-extern int PyPersist_RegisterTransaction(PyPersistObject *);
-extern void PyPersist_SetATime(PyPersistObject *);
+extern PyObject *PyPersist_Load(PyPersistBaseObject *);
+extern PyObject *PyPersist_RegisterDataManager(PyPersistBaseObject *);
+extern int PyPersist_RegisterTransaction(PyPersistBaseObject *);
+extern void PyPersist_SetATime(PyPersistBaseObject *);
/* A struct to encapsulation the PyPersist C API for use by other
dynamically load extensions.
@@ -48,8 +52,8 @@
typedef struct {
PyTypeObject *type;
- PyObject *(*load)(PyPersistObject *);
- int (*reg_trans)(PyPersistObject *);
- void (*set_atime)(PyPersistObject *);
+ PyObject *(*load)(PyPersistBaseObject *);
+ int (*reg_trans)(PyPersistBaseObject *);
+ void (*set_atime)(PyPersistBaseObject *);
} PyPersist_C_API_struct;
=== Zope3/lib/python/Persistence/cPersistenceAPI.h 1.1.2.4 => 1.1.2.5 ===
if (((O)->po_state == UPTODATE) \
|| ((O)->po_state == GHOST \
- && PyPersist_C_API->load((PyPersistObject *)(O)))) \
+ && PyPersist_C_API->load((PyPersistBaseObject *)(O)))) \
(O)->po_state = STICKY;
#define PyPersist_DECREF(O) \
@@ -24,25 +24,25 @@
}
/* XXX need to check *either* sticky or changed for now */
-#define PyPersist_IS_STICKY(O) ((O)->po_state == STICKY || \
- (O)->po_state == CHANGED)
+#define PyPersist_IS_STICKY(O) \
+ ((O)->po_state == STICKY || (O)->po_state == CHANGED)
#define PyPersist_CHANGED(O) \
- PyPersist_C_API->reg_trans((PyPersistObject *)(O))
+ PyPersist_C_API->reg_trans((PyPersistBaseObject *)(O))
/* Macros for compatibility with ZODB 3 C extensions. */
#define PER_USE_OR_RETURN(O, R) \
{ \
if (((O)->po_state == GHOST) \
- && (PyPersist_C_API->load((PyPersistObject *)(O)) < 0)) { \
+ && (PyPersist_C_API->load((PyPersistBaseObject *)(O)) < 0)) { \
(O)->po_state = STICKY; \
return (R); \
} else if ((O)->po_state == UPTODATE) \
(O)->po_state = STICKY; \
}
-#define PER_CHANGED(O) PyPersist_C_API->reg_trans((PyPersistObject *)(O))
+#define PER_CHANGED(O) PyPersist_C_API->reg_trans((PyPersistBaseObject *)(O))
#define PER_ALLOW_DEACTIVATION(O) \
{ \
@@ -57,9 +57,9 @@
}
#define PER_USE(O) \
- ((((PyPersistObject *)(O))->po_state != GHOST) \
- || (PyPersist_C_API->load((PyPersistObject *)(O)) >= 0) \
- ? ((((PyPersistObject *)(O))->po_state == UPTODATE) \
- ? (((PyPersistObject *)(O))->po_state = STICKY) : 1) : 0)
+ ((((PyPersistBaseObject *)(O))->po_state != GHOST) \
+ || (PyPersist_C_API->load((PyPersistBaseObject *)(O)) >= 0) \
+ ? ((((PyPersistBaseObject *)(O))->po_state == UPTODATE) \
+ ? (((PyPersistBaseObject *)(O))->po_state = STICKY) : 1) : 0)
-#define PER_ACCESSED(O) PyPersist_C_API->set_atime((PyPersistObject *)O)
+#define PER_ACCESSED(O) PyPersist_C_API->set_atime((PyPersistBaseObject *)O)