X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;ds=sidebyside;f=banana%2Fspool.inc.php;h=c938a24b1c25e69f5edcde228759d5077cdc9b7f;hb=d634c13c4ec3b1761622cf3ad558ffe89ba81a0b;hp=9e078f24dd12d64b10c9806d3ceeaa8498e9d8a3;hpb=9090c67309e46afcb82a2f260ce9d3ecd306e38f;p=banana.git
diff --git a/banana/spool.inc.php b/banana/spool.inc.php
index 9e078f2..c938a24 100644
--- a/banana/spool.inc.php
+++ b/banana/spool.inc.php
@@ -7,7 +7,7 @@
* Copyright: See COPYING files that comes with this distribution
********************************************************************************/
-if(!function_exists('_file_put_contents')) {
+if(!function_exists('file_put_contents')) {
function file_put_contents($filename, $data)
{
$fp = fopen($filename, 'w');
@@ -83,6 +83,8 @@ class BananaSpool
var $ids;
/** thread starts */
var $roots;
+ /** test validity */
+ var $valid = true;
/** constructor
* @param $_group STRING group name
@@ -94,19 +96,30 @@ class BananaSpool
global $banana;
$this->group = $_group;
$groupinfo = $banana->nntp->group($_group);
- if (!$groupinfo) { return ($this = null); }
+ if (!$groupinfo) {
+ $this->valid = false;
+ return null;
+ }
$this->_readFromFile();
$do_save = false;
- $first = $banana->maxspool ? max($groupinfo[2]-$banana->maxspool, $groupinfo[1]) : $groupinfo[1];
- $last = $groupinfo[2];
- if ($this->version == BANANA_SPOOL_VERSION) {
- for ($id = min(array_keys($this->overview)); $id<$first; $id++) {
- $this->delid($id, false);
- $do_save = true;
+ $first = $banana->maxspool ? max($groupinfo[2] - $banana->maxspool, $groupinfo[1]) : $groupinfo[1];
+ $last = $groupinfo[2];
+
+ if ($this->version == BANANA_SPOOL_VERSION && is_array($this->overview)) {
+ $mids = array_keys($this->overview);
+ foreach ($mids as $id) {
+ if (($first <= $last && ($id < $first || $id > $last))
+ || ($first > $last && $id < $first && $id > $last))
+ {
+ $this->delid($id, false);
+ $do_save = true;
+ }
+ }
+ if (!empty($this->overview)) {
+ $first = max(array_keys($this->overview))+1;
}
- $first = max(array_keys($this->overview))+1;
} else {
unset($this->overview, $this->ids);
$this->version = BANANA_SPOOL_VERSION;
@@ -126,7 +139,10 @@ class BananaSpool
{
$file = $this->_spoolfile();
if (file_exists($file)) {
- $this = unserialize(file_get_contents($file));
+ $temp = unserialize(file_get_contents($file));
+ foreach (get_object_vars($temp) as $key=>$val) {
+ $this->$key = $val;
+ }
}
}
@@ -141,7 +157,7 @@ class BananaSpool
$this->roots[] = $id;
}
}
-
+
file_put_contents($file, serialize($this));
}
@@ -156,13 +172,13 @@ class BananaSpool
function _updateSpool($arg)
{
global $banana;
- $dates = array_map(strtotime, $banana->nntp->xhdr("Date", $arg));
- $subjects = array_map(headerdecode, $banana->nntp->xhdr("Subject", $arg));
- $froms = array_map(headerdecode, $banana->nntp->xhdr("From", $arg));
- $msgids = $banana->nntp->xhdr("Message-ID", $arg);
- $refs = $banana->nntp->xhdr("References", $arg);
+ $dates = array_map('strtotime', $banana->nntp->xhdr('Date', $arg));
+ $subjects = array_map('headerdecode', $banana->nntp->xhdr('Subject', $arg));
+ $froms = array_map('headerdecode', $banana->nntp->xhdr('From', $arg));
+ $msgids = $banana->nntp->xhdr('Message-ID', $arg);
+ $refs = $banana->nntp->xhdr('References', $arg);
- if (is_array($this->ids)) {
+ if (is_array(@$this->ids)) {
$this->ids = array_merge($this->ids, array_flip($msgids));
} else {
$this->ids = array_flip($msgids);
@@ -170,7 +186,7 @@ class BananaSpool
foreach ($msgids as $id=>$msgid) {
$msg = new BananaSpoolHead($dates[$id], $subjects[$id], $froms[$id]);
- $refs[$id] = str_replace('><', '> <', $refs[$id]);
+ $refs[$id] = str_replace('><', '> <', @$refs[$id]);
$msgrefs = preg_split("/[ \t]/", strtr($refs[$id], $this->ids));
$parents = preg_grep('/^\d+$/', $msgrefs);
$msg->parent = array_pop($parents);
@@ -202,6 +218,7 @@ class BananaSpool
if (empty($since)) { return; }
if (is_array($newpostsids = $banana->nntp->newnews($since, $this->group))) {
+ if (!is_array($this->ids)) { $this->ids = array(); }
$newpostsids = array_intersect($newpostsids, array_keys($this->ids));
foreach ($newpostsids as $mid) {
$this->overview[$this->ids[$mid]]->isread = false;
@@ -292,20 +309,24 @@ class BananaSpool
* @param $_pfx_node STRING prefix used for current node
* @param $_pfx_end STRING prefix used for children of current node
* @param $_head BOOLEAN true if first post in thread
+ *
+ * If you want to analyse subject, you can define the function hook_getSubject(&$subject) which
+ * take the subject as a reference parameter, transform this subject to be displaid in the spool
+ * view and return a string. This string will be put after the subject.
*/
function _to_html($_id, $_index, $_first=0, $_last=0, $_ref="", $_pfx_node="", $_pfx_end="", $_head=true)
{
- $spfx_f = '';
- $spfx_n = '
';
- $spfx_Tnd = '
';
- $spfx_Lnd = '
';
- $spfx_snd = '
';
- $spfx_T = '
';
- $spfx_L = '
';
- $spfx_s = '
';
- $spfx_e = '
';
- $spfx_I = '
';
+ $spfx_f = makeImg('k1.gif', 'o', 21, 9);
+ $spfx_n = makeImg('k2.gif', '*', 21, 9);
+ $spfx_Tnd = makeImg('T-direct.gif', '+', 21, 12);
+ $spfx_Lnd = makeImg('L-direct.gif', '`', 21, 12);
+ $spfx_snd = makeImg('s-direct.gif', '-', 21, 5);
+ $spfx_T = makeImg('T.gif', '+', 21, 12);
+ $spfx_L = makeImg('L.gif', '`', 21, 12);
+ $spfx_s = makeImg('s.gif', '-', 21, 5);
+ $spfx_e = makeImg('e.gif', ' ', 21, 12);
+ $spfx_I = makeImg('I.gif', '|', 21, 12);
if ($_index + $this->overview[$_id]->desc < $_first || $_index > $_last) {
return;
@@ -321,10 +342,23 @@ class BananaSpool
$res .= "
'._b_('Date').' | '; - $res .= ''._b_('Sujet').' | '; - $res .= ''._b_('Auteur').' |
---|---|---|
' . _b_('Date') . ' | '; + $res .= '' . $new . _b_('Sujet') . ' | '; + $res .= '' . _b_('Auteur') . ' |
' . _b_('Aperçu de ') + . makeHREF(Array('group' => $this->group), + $this->group) + . ' | ||
'._b_('Aucun message dans ce forum').' | ||
' + . $banana->groups->to_html() + . ' |