homescreensrv_plat/hswidgetmodel_api/ihswidgetpreferenceservice.h
author hgs
Fri, 26 Mar 2010 13:00:55 +0200
changeset 91 a6d55a2e75be
parent 85 7feec50967db
child 98 d2f833ab7940
permissions -rw-r--r--
201011_03
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
85
7feec50967db 201003_02
hgs
parents:
diff changeset
     1
/*
7feec50967db 201003_02
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
7feec50967db 201003_02
hgs
parents:
diff changeset
     3
* All rights reserved.
7feec50967db 201003_02
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
7feec50967db 201003_02
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
7feec50967db 201003_02
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
7feec50967db 201003_02
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
7feec50967db 201003_02
hgs
parents:
diff changeset
     8
*
7feec50967db 201003_02
hgs
parents:
diff changeset
     9
* Initial Contributors:
7feec50967db 201003_02
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
7feec50967db 201003_02
hgs
parents:
diff changeset
    11
*
7feec50967db 201003_02
hgs
parents:
diff changeset
    12
* Contributors:
7feec50967db 201003_02
hgs
parents:
diff changeset
    13
*
7feec50967db 201003_02
hgs
parents:
diff changeset
    14
* Description:  Homescreen widget preference service.
7feec50967db 201003_02
hgs
parents:
diff changeset
    15
*
7feec50967db 201003_02
hgs
parents:
diff changeset
    16
*/
7feec50967db 201003_02
hgs
parents:
diff changeset
    17
7feec50967db 201003_02
hgs
parents:
diff changeset
    18
7feec50967db 201003_02
hgs
parents:
diff changeset
    19
#ifndef HSIWIDGETPREFERENCESERVICE_H
7feec50967db 201003_02
hgs
parents:
diff changeset
    20
#define HSIWIDGETPREFERENCESERVICE_H
7feec50967db 201003_02
hgs
parents:
diff changeset
    21
7feec50967db 201003_02
hgs
parents:
diff changeset
    22
class QString;
7feec50967db 201003_02
hgs
parents:
diff changeset
    23
class HsWidget;
7feec50967db 201003_02
hgs
parents:
diff changeset
    24
7feec50967db 201003_02
hgs
parents:
diff changeset
    25
/**
7feec50967db 201003_02
hgs
parents:
diff changeset
    26
 * @ingroup group_hswidgetmodel group_widget_api_candidates
7feec50967db 201003_02
hgs
parents:
diff changeset
    27
 * @brief Preference store for widget.
7feec50967db 201003_02
hgs
parents:
diff changeset
    28
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    29
 * The preference service is a key/value store with both the key and
7feec50967db 201003_02
hgs
parents:
diff changeset
    30
 * the value being strings. The widget may store data to be reused
7feec50967db 201003_02
hgs
parents:
diff changeset
    31
 * at a later date, such as a username, settings for the widget, persistent data,
7feec50967db 201003_02
hgs
parents:
diff changeset
    32
 * and so on. The data is stored on the device, for example on its hard drive,
7feec50967db 201003_02
hgs
parents:
diff changeset
    33
 * and can be read back at any time.
7feec50967db 201003_02
hgs
parents:
diff changeset
    34
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    35
 * @lib ?library
7feec50967db 201003_02
hgs
parents:
diff changeset
    36
 * @since S60 ?S60_version
7feec50967db 201003_02
hgs
parents:
diff changeset
    37
 */
7feec50967db 201003_02
hgs
parents:
diff changeset
    38
class IHsWidgetPreferenceService
7feec50967db 201003_02
hgs
parents:
diff changeset
    39
{
7feec50967db 201003_02
hgs
parents:
diff changeset
    40
public:
7feec50967db 201003_02
hgs
parents:
diff changeset
    41
7feec50967db 201003_02
hgs
parents:
diff changeset
    42
	/**
7feec50967db 201003_02
hgs
parents:
diff changeset
    43
     * Save a widget preference.
7feec50967db 201003_02
hgs
parents:
diff changeset
    44
	 * This method will store the given value in the widget
7feec50967db 201003_02
hgs
parents:
diff changeset
    45
	 * in the widget preference store for the given key.
7feec50967db 201003_02
hgs
parents:
diff changeset
    46
	 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    47
	 * The preference store is unique to this widget and any values
7feec50967db 201003_02
hgs
parents:
diff changeset
    48
	 * stored in it are persisted if the widget is reloaded or closed
7feec50967db 201003_02
hgs
parents:
diff changeset
    49
	 * and started again.
7feec50967db 201003_02
hgs
parents:
diff changeset
    50
	 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    51
	 * If a value for the given key already exists, it is silently
7feec50967db 201003_02
hgs
parents:
diff changeset
    52
	 * overwritten. Storing an empty string for the given key will
7feec50967db 201003_02
hgs
parents:
diff changeset
    53
	 * create an entry for the given key with an empty string as its value.
7feec50967db 201003_02
hgs
parents:
diff changeset
    54
	 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    55
	 * @param widget HsWidget instance.
7feec50967db 201003_02
hgs
parents:
diff changeset
    56
     * @param key The preference to get from the preference store.
7feec50967db 201003_02
hgs
parents:
diff changeset
    57
     * @param value The value of the preference.
7feec50967db 201003_02
hgs
parents:
diff changeset
    58
	 * @return True on success, false otherwise.
7feec50967db 201003_02
hgs
parents:
diff changeset
    59
	 */
7feec50967db 201003_02
hgs
parents:
diff changeset
    60
	virtual bool setPreferenceForKey(HsWidget *widget, const QString &key, const QString &value)=0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    61
7feec50967db 201003_02
hgs
parents:
diff changeset
    62
	/**
7feec50967db 201003_02
hgs
parents:
diff changeset
    63
	 * Get a preference from the widget preference store.
7feec50967db 201003_02
hgs
parents:
diff changeset
    64
	 * Get the value stored for the given key in the widget preference store.
7feec50967db 201003_02
hgs
parents:
diff changeset
    65
	 * If there is no value for the given key, an empty string is returned.
7feec50967db 201003_02
hgs
parents:
diff changeset
    66
	 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    67
	 * @param widget HsWidget instance.
7feec50967db 201003_02
hgs
parents:
diff changeset
    68
     * @param key The preference to get from the preference store.
7feec50967db 201003_02
hgs
parents:
diff changeset
    69
     * @param value The value of the preference.
7feec50967db 201003_02
hgs
parents:
diff changeset
    70
	 * @return True on success, false otherwise.
7feec50967db 201003_02
hgs
parents:
diff changeset
    71
	 */
7feec50967db 201003_02
hgs
parents:
diff changeset
    72
	virtual bool preferenceForKey(HsWidget *widget, const QString &key, QString &value)=0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    73
7feec50967db 201003_02
hgs
parents:
diff changeset
    74
};
7feec50967db 201003_02
hgs
parents:
diff changeset
    75
7feec50967db 201003_02
hgs
parents:
diff changeset
    76
Q_DECLARE_METATYPE(IHsWidgetPreferenceService*)
7feec50967db 201003_02
hgs
parents:
diff changeset
    77
#endif