/* * jabbercontactpool.h * * Copyright (c) 2004 by Till Gerken <till@tantalo.net> * * Kopete (c) by the Kopete developers <kopete-devel@kde.org> * * ************************************************************************* * * * * * 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. * * * * * ************************************************************************* */ #ifndef JABBERCONTACTPOOL_H #define JABBERCONTACTPOOL_H #include <tqobject.h> #include <im.h> namespace Kopete { class MetaContact; } namespace Kopete { class Contact; } class JabberContactPoolItem; class JabberBaseContact; class JabberContact; class JabberGroupContact; class JabberAccount; class JabberTransport; /** * @author Till Gerken <till@tantalo.net> */ class JabberContactPool : public TQObject { Q_OBJECT public: /** * Default constructor */ JabberContactPool ( JabberAccount *account ); /** * Default destructor */ ~JabberContactPool(); /** * Add a contact to the pool */ JabberContact *addContact ( const XMPP::RosterItem &contact, Kopete::MetaContact *metaContact, bool dirty = true ); JabberBaseContact *addGroupContact ( const XMPP::RosterItem &contact, bool roomContact, Kopete::MetaContact *metaContact, bool dirty = true ); /** * Remove a contact from the pool */ void removeContact ( const XMPP::Jid &jid ); /** * Remove all contacts from the pool */ void clear (); /** * Sets the "dirty" flag for a certain contact */ void setDirty ( const XMPP::Jid &jid, bool dirty ); /** * Remove all dirty elements from the pool * (used after connecting to delete removed items from the roster) */ void cleanUp (); /** * Find an exact match in the pool by full JID. */ JabberBaseContact *findExactMatch ( const XMPP::Jid &jid ); /** * Find a relevant recipient for a given JID. * This will match user@domain for a given user@domain/resource, * but NOT user@domain/resource for a given user@domain. */ JabberBaseContact *findRelevantRecipient ( const XMPP::Jid &jid ); /** * Find relevant sources for a given JID. * This will match user@domain/resource for a given user@domain. */ TQPtrList<JabberBaseContact> findRelevantSources ( const XMPP::Jid &jid ); private slots: void slotContactDestroyed ( Kopete::Contact *contact ); private: JabberContactPoolItem *findPoolItem ( const XMPP::RosterItem &contact ); TQPtrList<JabberContactPoolItem> mPool; JabberAccount *mAccount; }; class JabberContactPoolItem : TQObject { Q_OBJECT public: JabberContactPoolItem ( JabberBaseContact *contact ); ~JabberContactPoolItem (); void setDirty ( bool dirty ); bool dirty (); JabberBaseContact *contact (); private: bool mDirty; JabberBaseContact *mContact; }; #endif