Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
ZEO
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
ZEO
Commits
95528d0f
Commit
95528d0f
authored
Mar 28, 1997
by
Jim Fulton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Simplified reinit logic.
parent
4410e38c
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
222 additions
and
45 deletions
+222
-45
src/Persistence/cPickleCache.c
src/Persistence/cPickleCache.c
+74
-15
src/ZODB/cPickleCache.c
src/ZODB/cPickleCache.c
+74
-15
src/persistent/cPickleCache.c
src/persistent/cPickleCache.c
+74
-15
No files found.
src/Persistence/cPickleCache.c
View file @
95528d0f
/*
/*
$Id: cPickleCache.c,v 1.
2 1997/03/11 20:48:38
jim Exp $
$Id: cPickleCache.c,v 1.
3 1997/03/28 20:18:34
jim Exp $
C implementation of a pickle jar cache.
C implementation of a pickle jar cache.
...
@@ -56,7 +56,7 @@
...
@@ -56,7 +56,7 @@
(540) 371-6909
(540) 371-6909
***************************************************************************/
***************************************************************************/
static
char
*
what_string
=
"$Id: cPickleCache.c,v 1.
2 1997/03/11 20:48:38
jim Exp $"
;
static
char
*
what_string
=
"$Id: cPickleCache.c,v 1.
3 1997/03/28 20:18:34
jim Exp $"
;
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define UNLESS(E) if(!(E))
#define UNLESS(E) if(!(E))
...
@@ -64,8 +64,9 @@ static char *what_string = "$Id: cPickleCache.c,v 1.2 1997/03/11 20:48:38 jim Ex
...
@@ -64,8 +64,9 @@ static char *what_string = "$Id: cPickleCache.c,v 1.2 1997/03/11 20:48:38 jim Ex
#define Py_ASSIGN(P,E) if(!PyObject_AssignExpression(&(P),(E))) return NULL
#define Py_ASSIGN(P,E) if(!PyObject_AssignExpression(&(P),(E))) return NULL
#include "Python.h"
#include "Python.h"
#include <time.h>
static
PyObject
*
py_reload
,
*
py__p_jar
,
*
py__p_atime
;
static
PyObject
*
py_reload
,
*
py__p_jar
,
*
py__p_atime
,
*
py__p___reinit__
;
/* Declarations for objects of type cCache */
/* Declarations for objects of type cCache */
...
@@ -101,21 +102,21 @@ gc_item(ccobject *self, PyObject *key, PyObject *v, time_t now, time_t dt)
...
@@ -101,21 +102,21 @@ gc_item(ccobject *self, PyObject *key, PyObject *v, time_t now, time_t dt)
{
{
UNLESS
(
-
1
!=
PyDict_DelItem
(
self
->
data
,
key
))
return
-
1
;
UNLESS
(
-
1
!=
PyDict_DelItem
(
self
->
data
,
key
))
return
-
1
;
}
}
else
if
((
atime
=
PyTuple_GET_ITEM
(
v
,
1
))
&&
else
if
(
!
dt
||
now
-
((
PATimeobject
*
)
atime
)
->
value
>
dt
)
((
atime
=
PyTuple_GET_ITEM
(
v
,
1
))
&&
now
-
((
PATimeobject
*
)
atime
)
->
value
>
dt
))
{
{
/* We have a cPersistent object that hasn't been used in
/* We have a cPersistent object that hasn't been used in
a while. Reinitialize it, hopefully freeing it's state.
a while. Reinitialize it, hopefully freeing it's state.
*/
*/
v
=
PyTuple_GET_ITEM
(
v
,
0
);
v
=
PyTuple_GET_ITEM
(
v
,
0
);
UNLESS
(
key
=
PyObject_GetAttr
(
v
,
py__p_jar
))
return
-
1
;
if
(
key
=
PyObject_GetAttr
(
v
,
py__p___reinit__
))
if
(
key
!=
Py_None
)
{
{
UNLESS_ASSIGN
(
key
,
PyObject_GetAttr
(
key
,
py_reload
))
return
-
1
;
ASSIGN
(
key
,
PyObject_CallObject
(
key
,
NULL
))
;
UNLESS
_ASSIGN
(
key
,
PyObject_CallFunction
(
key
,
"(O)"
,
v
))
UNLESS
(
key
)
return
-
1
;
return
-
1
;
Py_DECREF
(
key
)
;
}
}
Py
_DECREF
(
key
);
Py
Err_Clear
(
);
}
}
}
}
return
0
;
return
0
;
...
@@ -131,7 +132,7 @@ fullgc(ccobject *self)
...
@@ -131,7 +132,7 @@ fullgc(ccobject *self)
i
=
PyDict_Size
(
self
->
data
)
-
3
/
self
->
cache_size
;
i
=
PyDict_Size
(
self
->
data
)
-
3
/
self
->
cache_size
;
if
(
i
<
3
)
i
=
3
;
if
(
i
<
3
)
i
=
3
;
dt
=
self
->
cache_age
*
3
/
i
;
dt
=
self
->
cache_age
*
3
/
i
;
if
(
dt
<
60
)
dt
=
6
0
;
if
(
dt
<
10
)
dt
=
1
0
;
now
=
time
(
NULL
);
now
=
time
(
NULL
);
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
...
@@ -140,12 +141,29 @@ fullgc(ccobject *self)
...
@@ -140,12 +141,29 @@ fullgc(ccobject *self)
return
0
;
return
0
;
}
}
static
int
reallyfullgc
(
ccobject
*
self
)
{
PyObject
*
key
,
*
v
;
int
i
;
/* First time through should get refcounts to 1 */
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
if
(
gc_item
(
self
,
key
,
v
,
0
,
0
)
<
0
)
return
-
1
;
/* Second time through should free many objects */
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
if
(
gc_item
(
self
,
key
,
v
,
0
,
0
)
<
0
)
return
-
1
;
self
->
position
=
0
;
return
0
;
}
static
int
static
int
maybegc
(
ccobject
*
self
)
maybegc
(
ccobject
*
self
)
{
{
int
n
,
s
;
int
n
,
s
;
time_t
now
,
dt
;
time_t
now
,
dt
;
PyObject
*
key
=
0
,
*
v
=
0
,
*
atime
;
PyObject
*
key
=
0
,
*
v
=
0
;
s
=
PyDict_Size
(
self
->
data
)
-
3
;
s
=
PyDict_Size
(
self
->
data
)
-
3
;
if
(
s
<
self
->
cache_size
)
return
0
;
if
(
s
<
self
->
cache_size
)
return
0
;
...
@@ -176,10 +194,22 @@ cc_full_sweep(ccobject *self, PyObject *args)
...
@@ -176,10 +194,22 @@ cc_full_sweep(ccobject *self, PyObject *args)
return
Py_None
;
return
Py_None
;
}
}
static
PyObject
*
cc_reallyfull_sweep
(
ccobject
*
self
,
PyObject
*
args
)
{
UNLESS
(
PyArg_Parse
(
args
,
""
))
return
NULL
;
UNLESS
(
-
1
!=
reallyfullgc
(
self
))
return
NULL
;
Py_INCREF
(
Py_None
);
return
Py_None
;
}
static
struct
PyMethodDef
cc_methods
[]
=
{
static
struct
PyMethodDef
cc_methods
[]
=
{
{
"full_sweep"
,
(
PyCFunction
)
cc_full_sweep
,
0
,
{
"full_sweep"
,
(
PyCFunction
)
cc_full_sweep
,
0
,
"Perform a full sweep of the cache, looking for objects that can be removed"
"Perform a full sweep of the cache, looking for objects that can be removed"
},
},
{
"minimize"
,
(
PyCFunction
)
cc_reallyfull_sweep
,
0
,
"Try to free as many objects as possible"
},
{
NULL
,
NULL
}
/* sentinel */
{
NULL
,
NULL
}
/* sentinel */
};
};
...
@@ -221,6 +251,31 @@ cc_getattr(ccobject *self, char *name)
...
@@ -221,6 +251,31 @@ cc_getattr(ccobject *self, char *name)
return
PyObject_GetAttrString
(
self
->
data
,
name
);
return
PyObject_GetAttrString
(
self
->
data
,
name
);
}
}
static
int
cc_setattr
(
ccobject
*
self
,
char
*
name
,
PyObject
*
value
)
{
if
(
value
)
{
int
v
;
if
(
strcmp
(
name
,
"cache_age"
)
==
0
)
{
if
(
PyArg_Parse
(
value
,
"i"
,
&
v
))
return
0
;
else
return
-
1
;
if
(
v
>
0
)
self
->
cache_age
=
v
;
}
if
(
strcmp
(
name
,
"cache_size"
)
==
0
)
{
if
(
PyArg_Parse
(
value
,
"i"
,
&
v
))
return
0
;
else
return
-
1
;
if
(
v
>
0
)
self
->
cache_size
=
v
;
}
}
PyErr_SetString
(
PyExc_AttributeError
,
name
);
return
-
1
;
}
static
PyObject
*
static
PyObject
*
cc_repr
(
ccobject
*
self
)
cc_repr
(
ccobject
*
self
)
{
{
...
@@ -319,7 +374,7 @@ static PyTypeObject Cctype = {
...
@@ -319,7 +374,7 @@ static PyTypeObject Cctype = {
(
destructor
)
cc_dealloc
,
/*tp_dealloc*/
(
destructor
)
cc_dealloc
,
/*tp_dealloc*/
(
printfunc
)
0
,
/*tp_print*/
(
printfunc
)
0
,
/*tp_print*/
(
getattrfunc
)
cc_getattr
,
/*tp_getattr*/
(
getattrfunc
)
cc_getattr
,
/*tp_getattr*/
(
setattrfunc
)
0
,
/*tp_setattr*/
(
setattrfunc
)
cc_setattr
,
/*tp_setattr*/
(
cmpfunc
)
0
,
/*tp_compare*/
(
cmpfunc
)
0
,
/*tp_compare*/
(
reprfunc
)
cc_repr
,
/*tp_repr*/
(
reprfunc
)
cc_repr
,
/*tp_repr*/
0
,
/*tp_as_number*/
0
,
/*tp_as_number*/
...
@@ -371,7 +426,7 @@ void
...
@@ -371,7 +426,7 @@ void
initcPickleCache
()
initcPickleCache
()
{
{
PyObject
*
m
,
*
d
;
PyObject
*
m
,
*
d
;
char
*
rev
=
"$Revision: 1.
2
$"
;
char
*
rev
=
"$Revision: 1.
3
$"
;
Cctype
.
ob_type
=&
PyType_Type
;
Cctype
.
ob_type
=&
PyType_Type
;
...
@@ -388,6 +443,7 @@ initcPickleCache()
...
@@ -388,6 +443,7 @@ initcPickleCache()
py_reload
=
PyString_FromString
(
"reload"
);
py_reload
=
PyString_FromString
(
"reload"
);
py__p_jar
=
PyString_FromString
(
"_p_jar"
);
py__p_jar
=
PyString_FromString
(
"_p_jar"
);
py__p_atime
=
PyString_FromString
(
"_p_atime"
);
py__p_atime
=
PyString_FromString
(
"_p_atime"
);
py__p___reinit__
=
PyString_FromString
(
"_p___reinit__"
);
PyDict_SetItemString
(
d
,
"__version__"
,
PyDict_SetItemString
(
d
,
"__version__"
,
PyString_FromStringAndSize
(
rev
+
11
,
strlen
(
rev
+
11
)
-
2
));
PyString_FromStringAndSize
(
rev
+
11
,
strlen
(
rev
+
11
)
-
2
));
...
@@ -398,6 +454,9 @@ initcPickleCache()
...
@@ -398,6 +454,9 @@ initcPickleCache()
/******************************************************************************
/******************************************************************************
$Log: cPickleCache.c,v $
$Log: cPickleCache.c,v $
Revision 1.3 1997/03/28 20:18:34 jim
Simplified reinit logic.
Revision 1.2 1997/03/11 20:48:38 jim
Revision 1.2 1997/03/11 20:48:38 jim
Added object-deactivation support. This only works with cPersistent
Added object-deactivation support. This only works with cPersistent
objects.
objects.
...
...
src/ZODB/cPickleCache.c
View file @
95528d0f
/*
/*
$Id: cPickleCache.c,v 1.
2 1997/03/11 20:48:38
jim Exp $
$Id: cPickleCache.c,v 1.
3 1997/03/28 20:18:34
jim Exp $
C implementation of a pickle jar cache.
C implementation of a pickle jar cache.
...
@@ -56,7 +56,7 @@
...
@@ -56,7 +56,7 @@
(540) 371-6909
(540) 371-6909
***************************************************************************/
***************************************************************************/
static
char
*
what_string
=
"$Id: cPickleCache.c,v 1.
2 1997/03/11 20:48:38
jim Exp $"
;
static
char
*
what_string
=
"$Id: cPickleCache.c,v 1.
3 1997/03/28 20:18:34
jim Exp $"
;
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define UNLESS(E) if(!(E))
#define UNLESS(E) if(!(E))
...
@@ -64,8 +64,9 @@ static char *what_string = "$Id: cPickleCache.c,v 1.2 1997/03/11 20:48:38 jim Ex
...
@@ -64,8 +64,9 @@ static char *what_string = "$Id: cPickleCache.c,v 1.2 1997/03/11 20:48:38 jim Ex
#define Py_ASSIGN(P,E) if(!PyObject_AssignExpression(&(P),(E))) return NULL
#define Py_ASSIGN(P,E) if(!PyObject_AssignExpression(&(P),(E))) return NULL
#include "Python.h"
#include "Python.h"
#include <time.h>
static
PyObject
*
py_reload
,
*
py__p_jar
,
*
py__p_atime
;
static
PyObject
*
py_reload
,
*
py__p_jar
,
*
py__p_atime
,
*
py__p___reinit__
;
/* Declarations for objects of type cCache */
/* Declarations for objects of type cCache */
...
@@ -101,21 +102,21 @@ gc_item(ccobject *self, PyObject *key, PyObject *v, time_t now, time_t dt)
...
@@ -101,21 +102,21 @@ gc_item(ccobject *self, PyObject *key, PyObject *v, time_t now, time_t dt)
{
{
UNLESS
(
-
1
!=
PyDict_DelItem
(
self
->
data
,
key
))
return
-
1
;
UNLESS
(
-
1
!=
PyDict_DelItem
(
self
->
data
,
key
))
return
-
1
;
}
}
else
if
((
atime
=
PyTuple_GET_ITEM
(
v
,
1
))
&&
else
if
(
!
dt
||
now
-
((
PATimeobject
*
)
atime
)
->
value
>
dt
)
((
atime
=
PyTuple_GET_ITEM
(
v
,
1
))
&&
now
-
((
PATimeobject
*
)
atime
)
->
value
>
dt
))
{
{
/* We have a cPersistent object that hasn't been used in
/* We have a cPersistent object that hasn't been used in
a while. Reinitialize it, hopefully freeing it's state.
a while. Reinitialize it, hopefully freeing it's state.
*/
*/
v
=
PyTuple_GET_ITEM
(
v
,
0
);
v
=
PyTuple_GET_ITEM
(
v
,
0
);
UNLESS
(
key
=
PyObject_GetAttr
(
v
,
py__p_jar
))
return
-
1
;
if
(
key
=
PyObject_GetAttr
(
v
,
py__p___reinit__
))
if
(
key
!=
Py_None
)
{
{
UNLESS_ASSIGN
(
key
,
PyObject_GetAttr
(
key
,
py_reload
))
return
-
1
;
ASSIGN
(
key
,
PyObject_CallObject
(
key
,
NULL
))
;
UNLESS
_ASSIGN
(
key
,
PyObject_CallFunction
(
key
,
"(O)"
,
v
))
UNLESS
(
key
)
return
-
1
;
return
-
1
;
Py_DECREF
(
key
)
;
}
}
Py
_DECREF
(
key
);
Py
Err_Clear
(
);
}
}
}
}
return
0
;
return
0
;
...
@@ -131,7 +132,7 @@ fullgc(ccobject *self)
...
@@ -131,7 +132,7 @@ fullgc(ccobject *self)
i
=
PyDict_Size
(
self
->
data
)
-
3
/
self
->
cache_size
;
i
=
PyDict_Size
(
self
->
data
)
-
3
/
self
->
cache_size
;
if
(
i
<
3
)
i
=
3
;
if
(
i
<
3
)
i
=
3
;
dt
=
self
->
cache_age
*
3
/
i
;
dt
=
self
->
cache_age
*
3
/
i
;
if
(
dt
<
60
)
dt
=
6
0
;
if
(
dt
<
10
)
dt
=
1
0
;
now
=
time
(
NULL
);
now
=
time
(
NULL
);
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
...
@@ -140,12 +141,29 @@ fullgc(ccobject *self)
...
@@ -140,12 +141,29 @@ fullgc(ccobject *self)
return
0
;
return
0
;
}
}
static
int
reallyfullgc
(
ccobject
*
self
)
{
PyObject
*
key
,
*
v
;
int
i
;
/* First time through should get refcounts to 1 */
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
if
(
gc_item
(
self
,
key
,
v
,
0
,
0
)
<
0
)
return
-
1
;
/* Second time through should free many objects */
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
if
(
gc_item
(
self
,
key
,
v
,
0
,
0
)
<
0
)
return
-
1
;
self
->
position
=
0
;
return
0
;
}
static
int
static
int
maybegc
(
ccobject
*
self
)
maybegc
(
ccobject
*
self
)
{
{
int
n
,
s
;
int
n
,
s
;
time_t
now
,
dt
;
time_t
now
,
dt
;
PyObject
*
key
=
0
,
*
v
=
0
,
*
atime
;
PyObject
*
key
=
0
,
*
v
=
0
;
s
=
PyDict_Size
(
self
->
data
)
-
3
;
s
=
PyDict_Size
(
self
->
data
)
-
3
;
if
(
s
<
self
->
cache_size
)
return
0
;
if
(
s
<
self
->
cache_size
)
return
0
;
...
@@ -176,10 +194,22 @@ cc_full_sweep(ccobject *self, PyObject *args)
...
@@ -176,10 +194,22 @@ cc_full_sweep(ccobject *self, PyObject *args)
return
Py_None
;
return
Py_None
;
}
}
static
PyObject
*
cc_reallyfull_sweep
(
ccobject
*
self
,
PyObject
*
args
)
{
UNLESS
(
PyArg_Parse
(
args
,
""
))
return
NULL
;
UNLESS
(
-
1
!=
reallyfullgc
(
self
))
return
NULL
;
Py_INCREF
(
Py_None
);
return
Py_None
;
}
static
struct
PyMethodDef
cc_methods
[]
=
{
static
struct
PyMethodDef
cc_methods
[]
=
{
{
"full_sweep"
,
(
PyCFunction
)
cc_full_sweep
,
0
,
{
"full_sweep"
,
(
PyCFunction
)
cc_full_sweep
,
0
,
"Perform a full sweep of the cache, looking for objects that can be removed"
"Perform a full sweep of the cache, looking for objects that can be removed"
},
},
{
"minimize"
,
(
PyCFunction
)
cc_reallyfull_sweep
,
0
,
"Try to free as many objects as possible"
},
{
NULL
,
NULL
}
/* sentinel */
{
NULL
,
NULL
}
/* sentinel */
};
};
...
@@ -221,6 +251,31 @@ cc_getattr(ccobject *self, char *name)
...
@@ -221,6 +251,31 @@ cc_getattr(ccobject *self, char *name)
return
PyObject_GetAttrString
(
self
->
data
,
name
);
return
PyObject_GetAttrString
(
self
->
data
,
name
);
}
}
static
int
cc_setattr
(
ccobject
*
self
,
char
*
name
,
PyObject
*
value
)
{
if
(
value
)
{
int
v
;
if
(
strcmp
(
name
,
"cache_age"
)
==
0
)
{
if
(
PyArg_Parse
(
value
,
"i"
,
&
v
))
return
0
;
else
return
-
1
;
if
(
v
>
0
)
self
->
cache_age
=
v
;
}
if
(
strcmp
(
name
,
"cache_size"
)
==
0
)
{
if
(
PyArg_Parse
(
value
,
"i"
,
&
v
))
return
0
;
else
return
-
1
;
if
(
v
>
0
)
self
->
cache_size
=
v
;
}
}
PyErr_SetString
(
PyExc_AttributeError
,
name
);
return
-
1
;
}
static
PyObject
*
static
PyObject
*
cc_repr
(
ccobject
*
self
)
cc_repr
(
ccobject
*
self
)
{
{
...
@@ -319,7 +374,7 @@ static PyTypeObject Cctype = {
...
@@ -319,7 +374,7 @@ static PyTypeObject Cctype = {
(
destructor
)
cc_dealloc
,
/*tp_dealloc*/
(
destructor
)
cc_dealloc
,
/*tp_dealloc*/
(
printfunc
)
0
,
/*tp_print*/
(
printfunc
)
0
,
/*tp_print*/
(
getattrfunc
)
cc_getattr
,
/*tp_getattr*/
(
getattrfunc
)
cc_getattr
,
/*tp_getattr*/
(
setattrfunc
)
0
,
/*tp_setattr*/
(
setattrfunc
)
cc_setattr
,
/*tp_setattr*/
(
cmpfunc
)
0
,
/*tp_compare*/
(
cmpfunc
)
0
,
/*tp_compare*/
(
reprfunc
)
cc_repr
,
/*tp_repr*/
(
reprfunc
)
cc_repr
,
/*tp_repr*/
0
,
/*tp_as_number*/
0
,
/*tp_as_number*/
...
@@ -371,7 +426,7 @@ void
...
@@ -371,7 +426,7 @@ void
initcPickleCache
()
initcPickleCache
()
{
{
PyObject
*
m
,
*
d
;
PyObject
*
m
,
*
d
;
char
*
rev
=
"$Revision: 1.
2
$"
;
char
*
rev
=
"$Revision: 1.
3
$"
;
Cctype
.
ob_type
=&
PyType_Type
;
Cctype
.
ob_type
=&
PyType_Type
;
...
@@ -388,6 +443,7 @@ initcPickleCache()
...
@@ -388,6 +443,7 @@ initcPickleCache()
py_reload
=
PyString_FromString
(
"reload"
);
py_reload
=
PyString_FromString
(
"reload"
);
py__p_jar
=
PyString_FromString
(
"_p_jar"
);
py__p_jar
=
PyString_FromString
(
"_p_jar"
);
py__p_atime
=
PyString_FromString
(
"_p_atime"
);
py__p_atime
=
PyString_FromString
(
"_p_atime"
);
py__p___reinit__
=
PyString_FromString
(
"_p___reinit__"
);
PyDict_SetItemString
(
d
,
"__version__"
,
PyDict_SetItemString
(
d
,
"__version__"
,
PyString_FromStringAndSize
(
rev
+
11
,
strlen
(
rev
+
11
)
-
2
));
PyString_FromStringAndSize
(
rev
+
11
,
strlen
(
rev
+
11
)
-
2
));
...
@@ -398,6 +454,9 @@ initcPickleCache()
...
@@ -398,6 +454,9 @@ initcPickleCache()
/******************************************************************************
/******************************************************************************
$Log: cPickleCache.c,v $
$Log: cPickleCache.c,v $
Revision 1.3 1997/03/28 20:18:34 jim
Simplified reinit logic.
Revision 1.2 1997/03/11 20:48:38 jim
Revision 1.2 1997/03/11 20:48:38 jim
Added object-deactivation support. This only works with cPersistent
Added object-deactivation support. This only works with cPersistent
objects.
objects.
...
...
src/persistent/cPickleCache.c
View file @
95528d0f
/*
/*
$Id: cPickleCache.c,v 1.
2 1997/03/11 20:48:38
jim Exp $
$Id: cPickleCache.c,v 1.
3 1997/03/28 20:18:34
jim Exp $
C implementation of a pickle jar cache.
C implementation of a pickle jar cache.
...
@@ -56,7 +56,7 @@
...
@@ -56,7 +56,7 @@
(540) 371-6909
(540) 371-6909
***************************************************************************/
***************************************************************************/
static
char
*
what_string
=
"$Id: cPickleCache.c,v 1.
2 1997/03/11 20:48:38
jim Exp $"
;
static
char
*
what_string
=
"$Id: cPickleCache.c,v 1.
3 1997/03/28 20:18:34
jim Exp $"
;
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define ASSIGN(V,E) {PyObject *__e; __e=(E); Py_XDECREF(V); (V)=__e;}
#define UNLESS(E) if(!(E))
#define UNLESS(E) if(!(E))
...
@@ -64,8 +64,9 @@ static char *what_string = "$Id: cPickleCache.c,v 1.2 1997/03/11 20:48:38 jim Ex
...
@@ -64,8 +64,9 @@ static char *what_string = "$Id: cPickleCache.c,v 1.2 1997/03/11 20:48:38 jim Ex
#define Py_ASSIGN(P,E) if(!PyObject_AssignExpression(&(P),(E))) return NULL
#define Py_ASSIGN(P,E) if(!PyObject_AssignExpression(&(P),(E))) return NULL
#include "Python.h"
#include "Python.h"
#include <time.h>
static
PyObject
*
py_reload
,
*
py__p_jar
,
*
py__p_atime
;
static
PyObject
*
py_reload
,
*
py__p_jar
,
*
py__p_atime
,
*
py__p___reinit__
;
/* Declarations for objects of type cCache */
/* Declarations for objects of type cCache */
...
@@ -101,21 +102,21 @@ gc_item(ccobject *self, PyObject *key, PyObject *v, time_t now, time_t dt)
...
@@ -101,21 +102,21 @@ gc_item(ccobject *self, PyObject *key, PyObject *v, time_t now, time_t dt)
{
{
UNLESS
(
-
1
!=
PyDict_DelItem
(
self
->
data
,
key
))
return
-
1
;
UNLESS
(
-
1
!=
PyDict_DelItem
(
self
->
data
,
key
))
return
-
1
;
}
}
else
if
((
atime
=
PyTuple_GET_ITEM
(
v
,
1
))
&&
else
if
(
!
dt
||
now
-
((
PATimeobject
*
)
atime
)
->
value
>
dt
)
((
atime
=
PyTuple_GET_ITEM
(
v
,
1
))
&&
now
-
((
PATimeobject
*
)
atime
)
->
value
>
dt
))
{
{
/* We have a cPersistent object that hasn't been used in
/* We have a cPersistent object that hasn't been used in
a while. Reinitialize it, hopefully freeing it's state.
a while. Reinitialize it, hopefully freeing it's state.
*/
*/
v
=
PyTuple_GET_ITEM
(
v
,
0
);
v
=
PyTuple_GET_ITEM
(
v
,
0
);
UNLESS
(
key
=
PyObject_GetAttr
(
v
,
py__p_jar
))
return
-
1
;
if
(
key
=
PyObject_GetAttr
(
v
,
py__p___reinit__
))
if
(
key
!=
Py_None
)
{
{
UNLESS_ASSIGN
(
key
,
PyObject_GetAttr
(
key
,
py_reload
))
return
-
1
;
ASSIGN
(
key
,
PyObject_CallObject
(
key
,
NULL
))
;
UNLESS
_ASSIGN
(
key
,
PyObject_CallFunction
(
key
,
"(O)"
,
v
))
UNLESS
(
key
)
return
-
1
;
return
-
1
;
Py_DECREF
(
key
)
;
}
}
Py
_DECREF
(
key
);
Py
Err_Clear
(
);
}
}
}
}
return
0
;
return
0
;
...
@@ -131,7 +132,7 @@ fullgc(ccobject *self)
...
@@ -131,7 +132,7 @@ fullgc(ccobject *self)
i
=
PyDict_Size
(
self
->
data
)
-
3
/
self
->
cache_size
;
i
=
PyDict_Size
(
self
->
data
)
-
3
/
self
->
cache_size
;
if
(
i
<
3
)
i
=
3
;
if
(
i
<
3
)
i
=
3
;
dt
=
self
->
cache_age
*
3
/
i
;
dt
=
self
->
cache_age
*
3
/
i
;
if
(
dt
<
60
)
dt
=
6
0
;
if
(
dt
<
10
)
dt
=
1
0
;
now
=
time
(
NULL
);
now
=
time
(
NULL
);
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
...
@@ -140,12 +141,29 @@ fullgc(ccobject *self)
...
@@ -140,12 +141,29 @@ fullgc(ccobject *self)
return
0
;
return
0
;
}
}
static
int
reallyfullgc
(
ccobject
*
self
)
{
PyObject
*
key
,
*
v
;
int
i
;
/* First time through should get refcounts to 1 */
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
if
(
gc_item
(
self
,
key
,
v
,
0
,
0
)
<
0
)
return
-
1
;
/* Second time through should free many objects */
for
(
i
=
0
;
PyDict_Next
(
self
->
data
,
&
i
,
&
key
,
&
v
);
)
if
(
gc_item
(
self
,
key
,
v
,
0
,
0
)
<
0
)
return
-
1
;
self
->
position
=
0
;
return
0
;
}
static
int
static
int
maybegc
(
ccobject
*
self
)
maybegc
(
ccobject
*
self
)
{
{
int
n
,
s
;
int
n
,
s
;
time_t
now
,
dt
;
time_t
now
,
dt
;
PyObject
*
key
=
0
,
*
v
=
0
,
*
atime
;
PyObject
*
key
=
0
,
*
v
=
0
;
s
=
PyDict_Size
(
self
->
data
)
-
3
;
s
=
PyDict_Size
(
self
->
data
)
-
3
;
if
(
s
<
self
->
cache_size
)
return
0
;
if
(
s
<
self
->
cache_size
)
return
0
;
...
@@ -176,10 +194,22 @@ cc_full_sweep(ccobject *self, PyObject *args)
...
@@ -176,10 +194,22 @@ cc_full_sweep(ccobject *self, PyObject *args)
return
Py_None
;
return
Py_None
;
}
}
static
PyObject
*
cc_reallyfull_sweep
(
ccobject
*
self
,
PyObject
*
args
)
{
UNLESS
(
PyArg_Parse
(
args
,
""
))
return
NULL
;
UNLESS
(
-
1
!=
reallyfullgc
(
self
))
return
NULL
;
Py_INCREF
(
Py_None
);
return
Py_None
;
}
static
struct
PyMethodDef
cc_methods
[]
=
{
static
struct
PyMethodDef
cc_methods
[]
=
{
{
"full_sweep"
,
(
PyCFunction
)
cc_full_sweep
,
0
,
{
"full_sweep"
,
(
PyCFunction
)
cc_full_sweep
,
0
,
"Perform a full sweep of the cache, looking for objects that can be removed"
"Perform a full sweep of the cache, looking for objects that can be removed"
},
},
{
"minimize"
,
(
PyCFunction
)
cc_reallyfull_sweep
,
0
,
"Try to free as many objects as possible"
},
{
NULL
,
NULL
}
/* sentinel */
{
NULL
,
NULL
}
/* sentinel */
};
};
...
@@ -221,6 +251,31 @@ cc_getattr(ccobject *self, char *name)
...
@@ -221,6 +251,31 @@ cc_getattr(ccobject *self, char *name)
return
PyObject_GetAttrString
(
self
->
data
,
name
);
return
PyObject_GetAttrString
(
self
->
data
,
name
);
}
}
static
int
cc_setattr
(
ccobject
*
self
,
char
*
name
,
PyObject
*
value
)
{
if
(
value
)
{
int
v
;
if
(
strcmp
(
name
,
"cache_age"
)
==
0
)
{
if
(
PyArg_Parse
(
value
,
"i"
,
&
v
))
return
0
;
else
return
-
1
;
if
(
v
>
0
)
self
->
cache_age
=
v
;
}
if
(
strcmp
(
name
,
"cache_size"
)
==
0
)
{
if
(
PyArg_Parse
(
value
,
"i"
,
&
v
))
return
0
;
else
return
-
1
;
if
(
v
>
0
)
self
->
cache_size
=
v
;
}
}
PyErr_SetString
(
PyExc_AttributeError
,
name
);
return
-
1
;
}
static
PyObject
*
static
PyObject
*
cc_repr
(
ccobject
*
self
)
cc_repr
(
ccobject
*
self
)
{
{
...
@@ -319,7 +374,7 @@ static PyTypeObject Cctype = {
...
@@ -319,7 +374,7 @@ static PyTypeObject Cctype = {
(
destructor
)
cc_dealloc
,
/*tp_dealloc*/
(
destructor
)
cc_dealloc
,
/*tp_dealloc*/
(
printfunc
)
0
,
/*tp_print*/
(
printfunc
)
0
,
/*tp_print*/
(
getattrfunc
)
cc_getattr
,
/*tp_getattr*/
(
getattrfunc
)
cc_getattr
,
/*tp_getattr*/
(
setattrfunc
)
0
,
/*tp_setattr*/
(
setattrfunc
)
cc_setattr
,
/*tp_setattr*/
(
cmpfunc
)
0
,
/*tp_compare*/
(
cmpfunc
)
0
,
/*tp_compare*/
(
reprfunc
)
cc_repr
,
/*tp_repr*/
(
reprfunc
)
cc_repr
,
/*tp_repr*/
0
,
/*tp_as_number*/
0
,
/*tp_as_number*/
...
@@ -371,7 +426,7 @@ void
...
@@ -371,7 +426,7 @@ void
initcPickleCache
()
initcPickleCache
()
{
{
PyObject
*
m
,
*
d
;
PyObject
*
m
,
*
d
;
char
*
rev
=
"$Revision: 1.
2
$"
;
char
*
rev
=
"$Revision: 1.
3
$"
;
Cctype
.
ob_type
=&
PyType_Type
;
Cctype
.
ob_type
=&
PyType_Type
;
...
@@ -388,6 +443,7 @@ initcPickleCache()
...
@@ -388,6 +443,7 @@ initcPickleCache()
py_reload
=
PyString_FromString
(
"reload"
);
py_reload
=
PyString_FromString
(
"reload"
);
py__p_jar
=
PyString_FromString
(
"_p_jar"
);
py__p_jar
=
PyString_FromString
(
"_p_jar"
);
py__p_atime
=
PyString_FromString
(
"_p_atime"
);
py__p_atime
=
PyString_FromString
(
"_p_atime"
);
py__p___reinit__
=
PyString_FromString
(
"_p___reinit__"
);
PyDict_SetItemString
(
d
,
"__version__"
,
PyDict_SetItemString
(
d
,
"__version__"
,
PyString_FromStringAndSize
(
rev
+
11
,
strlen
(
rev
+
11
)
-
2
));
PyString_FromStringAndSize
(
rev
+
11
,
strlen
(
rev
+
11
)
-
2
));
...
@@ -398,6 +454,9 @@ initcPickleCache()
...
@@ -398,6 +454,9 @@ initcPickleCache()
/******************************************************************************
/******************************************************************************
$Log: cPickleCache.c,v $
$Log: cPickleCache.c,v $
Revision 1.3 1997/03/28 20:18:34 jim
Simplified reinit logic.
Revision 1.2 1997/03/11 20:48:38 jim
Revision 1.2 1997/03/11 20:48:38 jim
Added object-deactivation support. This only works with cPersistent
Added object-deactivation support. This only works with cPersistent
objects.
objects.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment