searchsrv_plat/cpix_search_api/inc/cpixdocument.h
author hgs
Tue, 05 Oct 2010 13:15:12 +0530
changeset 23 d4d56f5e7c55
parent 13 fcb2a58c181b
child 24 65456528cac2
permissions -rw-r--r--
201039
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Qt search document APIs
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef _CPIXDOCUMENT_H
hgs
parents:
diff changeset
    19
#define _CPIXDOCUMENT_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#ifdef BUILD_DLL
hgs
parents:
diff changeset
    22
#define DLL_EXPORT Q_DECL_EXPORT
hgs
parents:
diff changeset
    23
#else
hgs
parents:
diff changeset
    24
#define DLL_EXPORT Q_DECL_IMPORT
hgs
parents:
diff changeset
    25
#endif
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
/**
hgs
parents:
diff changeset
    28
 * @file
hgs
parents:
diff changeset
    29
 * @ingroup Qt Search ClientAPI
hgs
parents:
diff changeset
    30
 * @brief Contains CpixDocument APIs
hgs
parents:
diff changeset
    31
 */
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
#include <QObject>
hgs
parents:
diff changeset
    34
#include <cpixcommon.h>
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
//Forward  Declaration
hgs
parents:
diff changeset
    37
class CpixDocumentPrivate;
hgs
parents:
diff changeset
    38
class CpixDocumentField;
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
/**
hgs
parents:
diff changeset
    41
 * @brief Represents the document returned as a result of a search query.
hgs
parents:
diff changeset
    42
 * @ingroup ClientAPI
hgs
parents:
diff changeset
    43
 * 
hgs
parents:
diff changeset
    44
 * Link against: cpixsearch.lib 
hgs
parents:
diff changeset
    45
 */
hgs
parents:
diff changeset
    46
class DLL_EXPORT CpixDocument: public QObject
hgs
parents:
diff changeset
    47
    {
hgs
parents:
diff changeset
    48
    Q_OBJECT
hgs
parents:
diff changeset
    49
public:
hgs
parents:
diff changeset
    50
    //@TODO: The following enums are copied over from S60. They need to 
hgs
parents:
diff changeset
    51
    // be moved to a common file so that they can be shared by s60, qt and openc.
hgs
parents:
diff changeset
    52
    /**
hgs
parents:
diff changeset
    53
     * TStored defines wheter the value is stored to database.
hgs
parents:
diff changeset
    54
     * If value is stored to database, it can be retrieved from search result. 
hgs
parents:
diff changeset
    55
     */
hgs
parents:
diff changeset
    56
    enum Stored
hgs
parents:
diff changeset
    57
        {
hgs
parents:
diff changeset
    58
        StoreYes = 1,
hgs
parents:
diff changeset
    59
        StoreNo = 2
hgs
parents:
diff changeset
    60
        };
hgs
parents:
diff changeset
    61
hgs
parents:
diff changeset
    62
    /**
hgs
parents:
diff changeset
    63
     * TIndexed defines how the value of the field is indexed. 
hgs
parents:
diff changeset
    64
     * If value is indexed, it can be searched. 
hgs
parents:
diff changeset
    65
     */
hgs
parents:
diff changeset
    66
    enum Indexed
hgs
parents:
diff changeset
    67
        {
hgs
parents:
diff changeset
    68
        IndexNo = 16,
hgs
parents:
diff changeset
    69
        IndexTokenized = 32,
hgs
parents:
diff changeset
    70
        IndexUnTokenized = 64
hgs
parents:
diff changeset
    71
        };
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
    /**
hgs
parents:
diff changeset
    74
     * TAggregated defines how the value of the field are exposed 
hgs
parents:
diff changeset
    75
     * for aggregation. Aggregated field can be found with generic searches. 
hgs
parents:
diff changeset
    76
     * If aggregation is not specified, all indexed field are aggeregated by
hgs
parents:
diff changeset
    77
     * default. Note: that also non-indexed fields can be aggregated.
hgs
parents:
diff changeset
    78
     */
hgs
parents:
diff changeset
    79
    enum Aggregated
hgs
parents:
diff changeset
    80
        {
hgs
parents:
diff changeset
    81
        AggregateNo = 1<<30,
23
hgs
parents: 13
diff changeset
    82
        AggregateYes = (unsigned int)1<<31,
13
hgs
parents:
diff changeset
    83
        AggregateDefault = 0
hgs
parents:
diff changeset
    84
        };
hgs
parents:
diff changeset
    85
    /**
hgs
parents:
diff changeset
    86
     * By default, field value is stored to database and it's indexed as tokenized strings.
hgs
parents:
diff changeset
    87
     */
hgs
parents:
diff changeset
    88
    static const int DefaultConfig = StoreYes | IndexTokenized | AggregateDefault;
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
    static const float KDefaultBoost; 
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
public:
hgs
parents:
diff changeset
    93
    /**
hgs
parents:
diff changeset
    94
       * Constructor.
hgs
parents:
diff changeset
    95
       * Creates a CpixDocument object and return a pointer to the created object.
hgs
parents:
diff changeset
    96
       * @return A pointer to the created instance of CpixDocument.
hgs
parents:
diff changeset
    97
       */
hgs
parents:
diff changeset
    98
    static CpixDocument* newInstance();
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
    /**
hgs
parents:
diff changeset
   101
     * Destructor
hgs
parents:
diff changeset
   102
     */
hgs
parents:
diff changeset
   103
    virtual ~CpixDocument();
hgs
parents:
diff changeset
   104
    
hgs
parents:
diff changeset
   105
    /**
hgs
parents:
diff changeset
   106
     * Getter: Gets the document identifier.
hgs
parents:
diff changeset
   107
     * @return document identifier.
hgs
parents:
diff changeset
   108
     */
hgs
parents:
diff changeset
   109
    QString docId() const;
hgs
parents:
diff changeset
   110
    
hgs
parents:
diff changeset
   111
    /**
hgs
parents:
diff changeset
   112
     * Getter: Gets the document excert.
hgs
parents:
diff changeset
   113
     * @return document excerpt.
hgs
parents:
diff changeset
   114
     */
hgs
parents:
diff changeset
   115
    QString excerpt() const;
hgs
parents:
diff changeset
   116
    
hgs
parents:
diff changeset
   117
    /**
hgs
parents:
diff changeset
   118
     * Getter: Gets the document's base app class.
hgs
parents:
diff changeset
   119
     * @return document's base app class.
hgs
parents:
diff changeset
   120
     */
hgs
parents:
diff changeset
   121
    QString baseAppClass() const;
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
    /**
hgs
parents:
diff changeset
   124
     * Getter: Gets the field at aIndex in the document.
hgs
parents:
diff changeset
   125
     * @param aIndex index of the field that is to be retrieved.
hgs
parents:
diff changeset
   126
     * @return CpixDocumentField that was at aIndex.
hgs
parents:
diff changeset
   127
     */
hgs
parents:
diff changeset
   128
    const CpixDocumentField& field( const int aIndex ) const THROWS_EXCEPTION;
hgs
parents:
diff changeset
   129
    
hgs
parents:
diff changeset
   130
    /**
hgs
parents:
diff changeset
   131
     * Getter: Gets the field count.
hgs
parents:
diff changeset
   132
     * @return The number of the fields in the document.
hgs
parents:
diff changeset
   133
     */
hgs
parents:
diff changeset
   134
    int fieldCount() const;
hgs
parents:
diff changeset
   135
    
hgs
parents:
diff changeset
   136
    /**
hgs
parents:
diff changeset
   137
     * Setter: Sets the document identifier for the document.
hgs
parents:
diff changeset
   138
     * @param aDocId the document identifier to be set.
hgs
parents:
diff changeset
   139
     */
hgs
parents:
diff changeset
   140
    void setDocId(const QString aDocId);
hgs
parents:
diff changeset
   141
    
hgs
parents:
diff changeset
   142
    /**
hgs
parents:
diff changeset
   143
     * Setter: Sets the excerpt for the document.
hgs
parents:
diff changeset
   144
     * @param aExcerpt the excerpt to be set.
hgs
parents:
diff changeset
   145
     */
hgs
parents:
diff changeset
   146
    void setExcerpt(const QString aExcerpt);
hgs
parents:
diff changeset
   147
    
hgs
parents:
diff changeset
   148
    /**
hgs
parents:
diff changeset
   149
     * Setter: Sets the base app class for the document.
hgs
parents:
diff changeset
   150
     * @param aBaseAppClass the base app class to be set.
hgs
parents:
diff changeset
   151
     */
hgs
parents:
diff changeset
   152
    void setBaseAppClass(const QString aBaseAppClass);
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
    /**
hgs
parents:
diff changeset
   155
     * Setter: Adds a field with aName, aValue and aConfig to the document.
hgs
parents:
diff changeset
   156
     * @param aName The name of the field
hgs
parents:
diff changeset
   157
     * @param aValue The value of the field
hgs
parents:
diff changeset
   158
     * @param aConfig The config of the field
hgs
parents:
diff changeset
   159
     * @return the CpixDocumentField that was added to the document.
hgs
parents:
diff changeset
   160
     */
hgs
parents:
diff changeset
   161
    void addField(const QString aName, const QString aValue, const int aConfig = CpixDocument::DefaultConfig);
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
private:
hgs
parents:
diff changeset
   164
    /**
hgs
parents:
diff changeset
   165
     * Default constructor
hgs
parents:
diff changeset
   166
     */
hgs
parents:
diff changeset
   167
    CpixDocument();
hgs
parents:
diff changeset
   168
hgs
parents:
diff changeset
   169
private:
hgs
parents:
diff changeset
   170
    CpixDocumentPrivate* const iPvtImpl;
hgs
parents:
diff changeset
   171
	Q_DECLARE_PRIVATE_D( iPvtImpl, CpixDocument )
hgs
parents:
diff changeset
   172
    };
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
#endif //_CPIXDOCUMENT_H