mirror of
https://bitbucket.org/smil3y/kde-playground.git
synced 2025-02-23 10:22:50 +00:00
206 lines
5.9 KiB
C++
206 lines
5.9 KiB
C++
/*
|
|
Copyright (c) 2007 Volker Krause <vkrause@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 AKONADI_SEARCHCREATEJOB_H
|
|
#define AKONADI_SEARCHCREATEJOB_H
|
|
|
|
#include <akonadi/job.h>
|
|
#include "collection.h"
|
|
|
|
namespace Akonadi {
|
|
|
|
class Collection;
|
|
class SearchQuery;
|
|
class SearchCreateJobPrivate;
|
|
|
|
/**
|
|
* @short Job that creates a virtual/search collection in the Akonadi storage.
|
|
*
|
|
* This job creates so called virtual or search collections, which don't contain
|
|
* real data, but references to items that match a given search query.
|
|
*
|
|
* @code
|
|
*
|
|
* const QString name = "My search folder";
|
|
* const QString query = "...";
|
|
*
|
|
* Akonadi::SearchCreateJob *job = new Akonadi::SearchCreateJob( name, query );
|
|
* connect( job, SIGNAL(result(KJob*)), SLOT(jobFinished(KJob*)) );
|
|
*
|
|
* MyClass::jobFinished( KJob *job )
|
|
* {
|
|
* if ( job->error() ) {
|
|
* qDebug() << "Error occurred";
|
|
* return;
|
|
* }
|
|
*
|
|
* qDebug() << "Created search folder successfully";
|
|
* const Collection searchCollection = job->createdCollection();
|
|
* ...
|
|
* }
|
|
*
|
|
* @endcode
|
|
*
|
|
* @author Volker Krause <vkrause@kde.org>
|
|
*/
|
|
class AKONADI_EXPORT SearchCreateJob : public Job
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/**
|
|
* Creates a search create job.
|
|
*
|
|
* @param name The name of the search collection.
|
|
* @param query The search query (format not defined yet).
|
|
* @param parent The parent object.
|
|
* @deprecated Deprecated as of 4.13, use Akonadi::SearchQuery instead
|
|
*/
|
|
AKONADI_DEPRECATED SearchCreateJob(const QString &name, const QString &query, QObject *parent = 0);
|
|
|
|
/**
|
|
* Creates a search create job
|
|
*
|
|
* @param name The name of the search collection.
|
|
* @param query The search query.
|
|
* @param parent The parent object.
|
|
* @since 4.13
|
|
*/
|
|
SearchCreateJob(const QString &name, const SearchQuery &searchQuery, QObject *parent = 0);
|
|
|
|
/**
|
|
* Sets the query language.
|
|
* @param queryLanguage The query language used.
|
|
* @since 4.6
|
|
* @deprecated This method is deprecated as of 4.13 and has no effect.
|
|
*
|
|
*/
|
|
AKONADI_DEPRECATED void setQueryLanguage(const QString &queryLanguage);
|
|
|
|
/**
|
|
* Sets list of mime types of items that search results can contain
|
|
*
|
|
* @param mimeTypes Mime types of items to include in search
|
|
* @since 4.13
|
|
*/
|
|
void setSearchMimeTypes(const QStringList &mimeTypes);
|
|
|
|
/**
|
|
* Returns list of mime types that search results can contain
|
|
*
|
|
* @since 4.13
|
|
*/
|
|
QStringList searchMimeTypes() const;
|
|
|
|
/**
|
|
* Sets list of collections to search in.
|
|
*
|
|
* When an empty list is set (default value), the search will contain
|
|
* results from all collections that contain given mime types.
|
|
*
|
|
* @param collections Collections to search in, or an empty list to search all
|
|
* @since 4.13
|
|
*/
|
|
void setSearchCollections(const Collection::List &collections);
|
|
|
|
/**
|
|
* Returns list of collections to search in
|
|
*
|
|
* @since 4.13
|
|
*/
|
|
Collection::List searchCollections() const;
|
|
|
|
/**
|
|
* Sets whether resources should be queried too.
|
|
*
|
|
* When set to true, Akonadi will search local indexed items and will also
|
|
* query resources that support server-side search, to forward the query
|
|
* to remote storage (for example using SEARCH feature on IMAP servers) and
|
|
* merge their results with results from local index.
|
|
*
|
|
* This is useful especially when searching resources, that don't fetch full
|
|
* payload by default, for example the IMAP resource, which only fetches headers
|
|
* by default and the body is fetched on demand, which means that emails that
|
|
* were not yet fully fetched cannot be indexed in local index, and thus cannot
|
|
* be searched. With remote search, even those emails can be included in search
|
|
* results.
|
|
*
|
|
* This feature is disabled by default.
|
|
*
|
|
* @param enabled Whether remote search is enabled
|
|
* @since 4.13
|
|
*/
|
|
void setRemoteSearchEnabled(bool enabled);
|
|
|
|
/**
|
|
* Returns whether remote search is enabled.
|
|
*
|
|
* @since 4.13
|
|
*/
|
|
bool isRemoteSearchEnabled() const;
|
|
|
|
/**
|
|
* Sets whether the search should recurse into collections
|
|
*
|
|
* When set to true, all child collections of the specific collections will
|
|
* be search recursively.
|
|
*
|
|
* @param recursive Whether to search recursively
|
|
* @since 4.13
|
|
*/
|
|
void setRecursive(bool recursive);
|
|
|
|
/**
|
|
* Returns whether the search is recursive
|
|
*
|
|
* @since 4.13
|
|
*/
|
|
bool isRecursive() const;
|
|
|
|
/**
|
|
* Destroys the search create job.
|
|
*/
|
|
~SearchCreateJob();
|
|
|
|
/**
|
|
* Returns the newly created search collection once the job finished successfully. Returns an invalid
|
|
* collection if the job has not yet finished or failed.
|
|
*
|
|
* @since 4.4
|
|
*/
|
|
Collection createdCollection() const;
|
|
|
|
protected:
|
|
/**
|
|
* Reimplemented from Akonadi::Job
|
|
*/
|
|
void doStart();
|
|
|
|
/**
|
|
* Reimplemented from Akonadi::Job
|
|
*/
|
|
void doHandleResponse(const QByteArray &tag, const QByteArray &data);
|
|
|
|
private:
|
|
Q_DECLARE_PRIVATE(SearchCreateJob)
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|