author | alwin <alwin> | 2003-12-17 22:14:05 (UTC) |
---|---|---|
committer | alwin <alwin> | 2003-12-17 22:14:05 (UTC) |
commit | eccc6a6362ab655b14c91a65a1cd4c89f39bd1e6 (patch) (side-by-side diff) | |
tree | 30bef45970fea14e13d46a7fd026ef80c4a9b7d0 | |
parent | 0b9db8cd39412de3bdc26e8f451b0475a149c903 (diff) | |
download | opie-eccc6a6362ab655b14c91a65a1cd4c89f39bd1e6.zip opie-eccc6a6362ab655b14c91a65a1cd4c89f39bd1e6.tar.gz opie-eccc6a6362ab655b14c91a65a1cd4c89f39bd1e6.tar.bz2 |
folder tree will generate better and real.
-rw-r--r-- | noncore/net/mail/accountview.cpp | 40 | ||||
-rw-r--r-- | noncore/net/mail/accountview.h | 6 |
2 files changed, 32 insertions, 14 deletions
diff --git a/noncore/net/mail/accountview.cpp b/noncore/net/mail/accountview.cpp index bc13336..71a0d74 100644 --- a/noncore/net/mail/accountview.cpp +++ b/noncore/net/mail/accountview.cpp @@ -107,2 +107,23 @@ AbstractMail *IMAPviewItem::getWrapper() +IMAPfolderItem*IMAPviewItem::findSubItem(const QString&path,IMAPfolderItem*start) +{ + IMAPfolderItem*pitem,*sitem; + if (!start) pitem = (IMAPfolderItem*)firstChild(); + else pitem = (IMAPfolderItem*)start->firstChild(); + while (pitem) { + if (pitem->matchName(path)) { + break; + } + if (pitem->childCount()>0) { + sitem = findSubItem(path,pitem); + if (sitem) { + pitem = sitem; + break; + } + } + pitem=(IMAPfolderItem*)pitem->nextSibling(); + } + return pitem; +} + void IMAPviewItem::refresh(QList<RecMail>&) @@ -122,3 +143,2 @@ void IMAPviewItem::refresh(QList<RecMail>&) QListViewItem*titem = 0; - QListViewItem*inboxitem = 0; QString fname,del,search; @@ -130,3 +150,3 @@ void IMAPviewItem::refresh(QList<RecMail>&) if (it->getDisplayName().lower()=="inbox") { - inboxitem = new IMAPfolderItem( it, this , item ); + item = new IMAPfolderItem( it, this , item ); folders->remove(it); @@ -136,3 +156,2 @@ void IMAPviewItem::refresh(QList<RecMail>&) } - for ( it = folders->first(); it; it = folders->next() ) { @@ -142,14 +161,7 @@ void IMAPviewItem::refresh(QList<RecMail>&) fname = fname.left(pos); - qDebug(fname); - } - IMAPfolderItem*pitem = (IMAPfolderItem*)firstChild(); - while (pitem) { - if (pitem->matchName(fname)) { - break; - } - pitem=(IMAPfolderItem*)pitem->nextSibling(); } + IMAPfolderItem*pitem = findSubItem(fname); if (pitem) { titem = item; - item = new IMAPfolderItem(it,pitem,item,this); + item = new IMAPfolderItem(it,pitem,pitem->firstChild(),this); item->setSelectable(it->may_select()); @@ -159,3 +171,3 @@ void IMAPviewItem::refresh(QList<RecMail>&) } else { - item = new IMAPfolderItem( it, this , (inboxitem?inboxitem:item) ); + item = new IMAPfolderItem( it, this , item ); item->setSelectable(it->may_select()); @@ -177,3 +189,3 @@ IMAPfolderItem::~IMAPfolderItem() IMAPfolderItem::IMAPfolderItem( Folder *folderInit, IMAPviewItem *parent , QListViewItem*after ) - : AccountViewItem( parent ) + : AccountViewItem( parent , after ) { diff --git a/noncore/net/mail/accountview.h b/noncore/net/mail/accountview.h index a57935f..64abed9 100644 --- a/noncore/net/mail/accountview.h +++ b/noncore/net/mail/accountview.h @@ -53,2 +53,4 @@ private: +class IMAPfolderItem; + class IMAPviewItem : public AccountViewItem @@ -62,2 +64,6 @@ public: AbstractMail *getWrapper(); + +protected: + IMAPfolderItem*findSubItem(const QString&path,IMAPfolderItem*start=0); + private: |