|
|
|
/*
|
|
|
|
knarticlecollection.h
|
|
|
|
|
|
|
|
KNode, the KDE newsreader
|
|
|
|
Copyright (c) 1999-2001 the KNode authors.
|
|
|
|
See file AUTHORS for details
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software Foundation,
|
|
|
|
Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, US
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef KNARTICLECOLLECTION_H
|
|
|
|
#define KNARTICLECOLLECTION_H
|
|
|
|
|
|
|
|
#include "kncollection.h"
|
|
|
|
|
|
|
|
class KNArticle;
|
|
|
|
|
|
|
|
|
|
|
|
class KNArticleVector {
|
|
|
|
|
|
|
|
public:
|
|
|
|
enum SortingType { STid, STmsgId, STunsorted };
|
|
|
|
|
|
|
|
KNArticleVector(KNArticleVector *master=0, SortingType sorting=STunsorted);
|
|
|
|
virtual ~KNArticleVector();
|
|
|
|
|
|
|
|
// list-info
|
|
|
|
KNArticleVector* master() { return m_aster; }
|
|
|
|
void setMaster(KNArticleVector *m) { m_aster=m; }
|
|
|
|
bool isMaster() { return (m_aster==0); }
|
|
|
|
|
|
|
|
bool isEmpty() { return ( (l_ist==0) || (l_en==0) ); }
|
|
|
|
int length() { return l_en; }
|
|
|
|
int size() { return s_ize; }
|
|
|
|
|
|
|
|
// list-handling
|
|
|
|
bool resize(int s=0);
|
|
|
|
bool append(KNArticle *a, bool autoSort=false);
|
|
|
|
void remove(int pos, bool autoDel=false, bool autoCompact=false);
|
|
|
|
void clear();
|
|
|
|
void compact();
|
|
|
|
void syncWithMaster();
|
|
|
|
|
|
|
|
// sorting
|
|
|
|
SortingType sortMode() { return s_ortType; }
|
|
|
|
void setSortMode(SortingType s) { s_ortType=s; }
|
|
|
|
void sort();
|
|
|
|
static int compareById(const void *a1, const void *a2);
|
|
|
|
static int compareByMsgId(const void *a1, const void *a2);
|
|
|
|
|
|
|
|
// article access
|
|
|
|
KNArticle* at(int i) { return ( (i>=0 && i<l_en) ? l_ist[i] : 0 ); }
|
|
|
|
KNArticle* bsearch(int id);
|
|
|
|
KNArticle* bsearch(const TQCString &id);
|
|
|
|
|
|
|
|
int indexForId(int id);
|
|
|
|
int indexForMsgId(const TQCString &id);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
KNArticleVector *m_aster;
|
|
|
|
int l_en,
|
|
|
|
s_ize;
|
|
|
|
KNArticle **l_ist;
|
|
|
|
SortingType s_ortType;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class KNArticleCollection : public KNCollection {
|
|
|
|
|
|
|
|
public:
|
|
|
|
KNArticleCollection(KNCollection *p=0);
|
|
|
|
~KNArticleCollection();
|
|
|
|
|
|
|
|
// info
|
|
|
|
bool isEmpty() { return a_rticles.isEmpty(); }
|
|
|
|
bool isLoaded() { return (c_ount==0 || a_rticles.length()>0); }
|
|
|
|
int size() { return a_rticles.size(); }
|
|
|
|
int length() { return a_rticles.length(); }
|
|
|
|
|
|
|
|
// cache behavior
|
|
|
|
bool isNotUnloadable() { return n_otUnloadable; }
|
|
|
|
void setNotUnloadable(bool b=true) { n_otUnloadable = b; }
|
|
|
|
|
|
|
|
// locking
|
|
|
|
unsigned int lockedArticles() { return l_ockedArticles; }
|
|
|
|
void articleLocked() { l_ockedArticles++; }
|
|
|
|
void articleUnlocked() { l_ockedArticles--; }
|
|
|
|
|
|
|
|
// list-handling
|
|
|
|
bool resize(int s=0);
|
|
|
|
bool append(KNArticle *a, bool autoSync=false);
|
|
|
|
void clear();
|
|
|
|
void compact();
|
|
|
|
void setLastID();
|
|
|
|
|
|
|
|
// article access
|
|
|
|
KNArticle* at(int i) { return a_rticles.at(i); }
|
|
|
|
KNArticle* byId(int id);
|
|
|
|
KNArticle* byMessageId(const TQCString &mid);
|
|
|
|
|
|
|
|
// search index
|
|
|
|
void syncSearchIndex();
|
|
|
|
void clearSearchIndex();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
int l_astID;
|
|
|
|
unsigned int l_ockedArticles;
|
|
|
|
bool n_otUnloadable;
|
|
|
|
KNArticleVector a_rticles;
|
|
|
|
KNArticleVector m_idIndex;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|