diff options
author | Evan Prodromou <evan@status.net> | 2010-01-04 15:14:54 -1000 |
---|---|---|
committer | Evan Prodromou <evan@status.net> | 2010-01-04 15:14:54 -1000 |
commit | 7aeb11bb077079d5008e9c07e3945b466eb2d3b8 (patch) | |
tree | 60b4ce077b688e048c11d04923421d0ce494fed7 /classes/Memcached_DataObject.php | |
parent | 3f3d6905deb1f292d9f0c5aacb67b98bdfa100c5 (diff) | |
parent | 31585453fc7c7ed2d4b9c72ef0478e541b5622e4 (diff) |
Merge branch 'master' into 0.9.x
Conflicts:
actions/publictagcloud.php
classes/Memcached_DataObject.php
Diffstat (limited to 'classes/Memcached_DataObject.php')
-rw-r--r-- | classes/Memcached_DataObject.php | 38 |
1 files changed, 37 insertions, 1 deletions
diff --git a/classes/Memcached_DataObject.php b/classes/Memcached_DataObject.php index a77e43d38..a3a69e667 100644 --- a/classes/Memcached_DataObject.php +++ b/classes/Memcached_DataObject.php @@ -21,7 +21,7 @@ if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } class Memcached_DataObject extends DB_DataObject { - /** + /** * Destructor to free global memory resources associated with * this data object when it's unset or goes out of scope. * DB_DataObject doesn't do this yet by itself. @@ -36,6 +36,42 @@ class Memcached_DataObject extends DB_DataObject } /** + * Magic function called at serialize() time. + * + * We use this to drop a couple process-specific references + * from DB_DataObject which can cause trouble in future + * processes. + * + * @return array of variable names to include in serialization. + */ + function __sleep() + { + $vars = array_keys(get_object_vars($this)); + $skip = array('_DB_resultid', '_link_loaded'); + return array_diff($vars, $skip); + } + + /** + * Magic function called at unserialize() time. + * + * Clean out some process-specific variables which might + * be floating around from a previous process's cached + * objects. + * + * Old cached objects may still have them. + */ + function __wakeup() + { + // Refers to global state info from a previous process. + // Clear this out so we don't accidentally break global + // state in *this* process. + $this->_DB_resultid = null; + + // We don't have any local DBO refs, so clear these out. + $this->_link_loaded = false; + } + + /** * Wrapper for DB_DataObject's static lookup using memcached * as backing instead of an in-process cache array. * |