/* This file is part of libkabc. Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef KABC_RESOURCE_H #define KABC_RESOURCE_H #include <kresources/resource.h> #include "addressbook.h" #include "plugin.h" namespace KABC { /** * @short Helper class for handling coordinated save of address books. * * This class is used as helper class for saving address book. * @see requestSaveTicket(), save(). */ class KABC_EXPORT Ticket { friend class Resource; public: ~Ticket(); Resource *resource(); private: Ticket( Resource *resource ); Resource *mResource; }; /** * @internal */ class KABC_EXPORT Resource : public KRES::Resource { Q_OBJECT public: /** @short Resource Iterator This class provides an iterator for resource entries. By default it points to a TQValueList<Addressee>::Iterator, but you can reimplement this class to fit your own needs. */ class KABC_EXPORT Iterator { public: Iterator(); Iterator( const Iterator & ); virtual ~Iterator(); virtual Iterator &operator=( const Iterator & ); virtual const Addressee &operator*() const; virtual Addressee &operator*(); virtual Iterator &operator++(); virtual Iterator &operator++( int ); virtual Iterator &operator--(); virtual Iterator &operator--( int ); virtual bool operator==( const Iterator &it ); virtual bool operator!=( const Iterator &it ); struct IteratorData; IteratorData *d; }; /** @short Resource Const Iterator This class provides a const iterator for resource entries. */ class KABC_EXPORT ConstIterator { public: ConstIterator(); ConstIterator( const ConstIterator & ); ConstIterator( const Iterator & ); virtual ~ConstIterator(); virtual ConstIterator &operator=( const ConstIterator & ); virtual const Addressee &operator*() const ; virtual ConstIterator &operator++(); virtual ConstIterator &operator++( int ); virtual ConstIterator &operator--(); virtual ConstIterator &operator--( int ); virtual bool operator==( const ConstIterator &it ); virtual bool operator!=( const ConstIterator &it ); struct ConstIteratorData; ConstIteratorData *d; }; /** Constructor. @param config The config object where the derived classes can read out their settings. */ Resource( const TDEConfig *config ); /** Destructor. */ virtual ~Resource(); /** Returns an iterator pointing to the first addressee in the resource. This iterator equals end() if the resource is empty. */ virtual ConstIterator begin() const; /** This is an overloaded member function, provided for convenience. It behaves essentially like the above function. */ virtual Iterator begin(); /** Returns an iterator pointing to the last addressee in the resource. This iterator equals begin() if the resource is empty. */ virtual ConstIterator end() const; /** This is an overloaded member function, provided for convenience. It behaves essentially like the above function. */ virtual Iterator end(); /** Returns a pointer to the addressbook. */ AddressBook *addressBook(); /** Writes the resource specific config to file. */ virtual void writeConfig( TDEConfig *config ); /** Request a ticket, you have to pass through save() to allow locking. The resource has to create its locks in this function. */ virtual Ticket *requestSaveTicket() = 0; /** Releases the ticket previousely requested with requestSaveTicket(). The resource has to remove its locks in this function. This function is also responsible for deleting the ticket. */ virtual void releaseSaveTicket( Ticket* ) = 0; /** Loads all addressees synchronously. @returns Whether the loading was successfully. */ virtual bool load() = 0; /** Loads all addressees asyncronously. You have to make sure that either the loadingFinished() or loadingError() signal is emitted from within this function. The default implementation simply calls the synchronous load. @return Whether the synchronous part of loading was successfully. */ virtual bool asyncLoad(); /** Insert an addressee into the resource. */ virtual void insertAddressee( const Addressee& ); /** Removes an addressee from resource. */ virtual void removeAddressee( const Addressee& addr ); /** Saves all addressees synchronously. @param ticket You have to release the ticket later with releaseSaveTicket() explicitely. @return Whether the saving was successfully. */ virtual bool save( Ticket *ticket ) = 0; /** Saves all addressees asynchronously. You have to make sure that either the savingFinished() or savingError() signal is emitted from within this function. The default implementation simply calls the synchronous save. @param ticket You have to release the ticket later with releaseSaveTicket() explicitely. @return Whether the saving was successfully. */ virtual bool asyncSave( Ticket *ticket ); /** Searches an addressee with the specified unique identifier. @param uid The unique identifier you are looking for. @return The addressee with the specified unique identifier or an empty addressee. */ virtual Addressee findByUid( const TQString &uid ); /** Searches all addressees which match the specified name. @param name The name you are looking for. @return A list of all matching addressees. */ virtual Addressee::List findByName( const TQString &name ); /** Searches all addressees which match the specified email address. @param email The email address you are looking for. @return A list of all matching addressees. */ virtual Addressee::List findByEmail( const TQString &email ); /** Searches all addressees which belongs to the specified category. @param category The category you are looking for. @return A list of all matching addressees. */ virtual Addressee::List findByCategory( const TQString &category ); /** Removes all addressees from the resource. */ virtual void clear(); /** @internal Sets the address book of the resource. */ void setAddressBook( AddressBook* ); signals: /** This signal is emitted when the resource has finished the loading of all addressees from the backend to the internal cache. @param resource The pointer to the resource which emitted this signal. */ void loadingFinished( Resource *resource ); /** This signal is emitted when an error occured during loading the addressees from the backend to the internal cache. @param resource The pointer to the resource which emitted this signal. @param msg A translated error message. */ void loadingError( Resource *resource, const TQString &msg ); /** This signal is emitted when the resource has finished the saving of all addressees from the internal cache to the backend. @param resource The pointer to the resource which emitted this signal. */ void savingFinished( Resource *resource ); /** This signal is emitted when an error occured during saving the addressees from the internal cache to the backend. @param resource The pointer to the resource which emitted this signal. @param msg A translated error message. */ void savingError( Resource *resource, const TQString &msg ); protected: Ticket *createTicket( Resource * ); Addressee::Map mAddrMap; private: AddressBook *mAddressBook; class ResourcePrivate; ResourcePrivate *d; }; } #endif