[Zope-Checkins] CVS: Zope3/lib/python/Persistence - cPersistenceAPI.h:1.1.2.3
Jeremy Hylton
jeremy@zope.com
Sat, 2 Mar 2002 01:32:46 -0500
Update of /cvs-repository/Zope3/lib/python/Persistence
In directory cvs.zope.org:/tmp/cvs-serv15429
Modified Files:
Tag: Zope-3x-branch
cPersistenceAPI.h
Log Message:
Fix PER_USE_OR_RETURN() macro.
Add some PyPersist_XXX macros that correspond roughtly to PER_XXX macros.
The PyPersist_Load() function does *not* set the object's state to
STICKY, which the Zope2 sestate() function did do. So the macro needs
to assign state to STICKY.
Add PyPersist_INCREF() / PyPersist_DECREF() macros, which control the
sticky state. INCREF() will load a ghost. Expect future modification
to have actual refcount instead of single STICKY state.
Add PyPersist_IS_STICKY() to test sticky state.
Programs should use PyPersist_INCREF() + PyPersist_IS_STICKY() in
place of PER_USE_OR_RETURN().
=== Zope3/lib/python/Persistence/cPersistenceAPI.h 1.1.2.2 => 1.1.2.3 ===
#define PyPersist_TYPE PyPersist_C_API->type
+#define PyPersist_INCREF(O) \
+ if (((O)->po_state == UPTODATE) \
+ || ((O)->po_state == GHOST \
+ && PyPersist_C_API->load((PyPersistObject *)(O)))) \
+ (O)->po_state = STICKY;
+
+#define PyPersist_DECREF(O) \
+ { \
+ if ((O)->po_state == STICKY) \
+ (O)->po_state = UPTODATE; \
+ }
+
+/* XXX perhaps this is a bad name */
+#define PyPersist_IS_STICKY(O) ((O)->po_state == STICKY)
+
+#define PyPersist_CHANGED(O) \
+ PyPersist_C_API->reg_trans((PyPersistObject *)(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((PyPersistObject *)(O)) < 0)) { \
+ (O)->po_state = STICKY; \
return (R); \
- else if ((O)->po_state == UPTODATE) \
+ } else if ((O)->po_state == UPTODATE) \
(O)->po_state = STICKY; \
}