summaryrefslogtreecommitdiff
path: root/classes
diff options
context:
space:
mode:
Diffstat (limited to 'classes')
-rw-r--r--classes/File.php5
-rw-r--r--classes/Session.php13
2 files changed, 14 insertions, 4 deletions
diff --git a/classes/File.php b/classes/File.php
index 0c4fbf7e6..959301eda 100644
--- a/classes/File.php
+++ b/classes/File.php
@@ -93,7 +93,6 @@ class File extends Memcached_DataObject
if (empty($file)) {
$file_redir = File_redirection::staticGet('url', $given_url);
if (empty($file_redir)) {
- common_debug("processNew() '$given_url' not a known redirect.\n");
$redir_data = File_redirection::where($given_url);
$redir_url = $redir_data['url'];
if ($redir_url === $given_url) {
@@ -114,7 +113,9 @@ class File extends Memcached_DataObject
if (empty($x)) {
$x = File::staticGet($file_id);
- if (empty($x)) die('Impossible!');
+ if (empty($x)) {
+ throw new ServerException("Robin thinks something is impossible.");
+ }
}
File_to_post::processNew($file_id, $notice_id);
diff --git a/classes/Session.php b/classes/Session.php
index ac80279c5..a92ce405b 100644
--- a/classes/Session.php
+++ b/classes/Session.php
@@ -110,9 +110,18 @@ class Session extends Memcached_DataObject
$session = new Session();
$session->whereAdd('modified < "'.$epoch.'"');
- $result = $session->delete(DB_DATAOBJECT_WHEREADD_ONLY);
- self::logdeb("garbage collection result = $result");
+ $session->find();
+
+ while ($session->fetch()) {
+ $other = new Session();
+ $other->id = $session->id;
+ self::logdeb("Collecting session $other->id");
+ $result = $other->delete();
+ self::logdeb("garbage collection result = $result");
+ }
+
+ $session->free();
}
static function setSaveHandler()