serviceapifw_plat/liw_criteria_api/inc/liwcommon.rh
author Pat Downey <patd@symbian.org>
Mon, 26 Oct 2009 17:47:04 +0000
changeset 25 93c869ba5d1f
parent 0 99ef825efeca
permissions -rw-r--r--
Merge tags.

/*
* Copyright (c) 2003-2005 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:       Contains common resource declarations for the LIWFW.
*
*/







//  INCLUDES
#include <liwcommon.hrh>

//  MACROS  

//  STRUCTURE DEFINITIONS

// -----------------------------------------------------------------------------
// Option item for a criteria.
// -----------------------------------------------------------------------------
STRUCT LIW_CRITERIA_OPTION
    {
    }

// -----------------------------------------------------------------------------
// Criteria item.
// Resource structure to define criteria item consumer.
// -----------------------------------------------------------------------------
//
// Criteria item
//
STRUCT LIW_CRITERIA_ITEM
    {
    // Criteria ID to be used in UI elements referring to this criteria
    // By default the ID should be same as the serviceCmd, but it can be
    // different as well e.g. for mapping old menu items to use LIW
    // This can be consumer defined or predefined, if common interest
    // is allocated.
    LONG id;

    // --------------------------------------------------------------
    // Actual criteria data used when resolving providers from which
    // a consumer is interested in.
    // --------------------------------------------------------------

    // Command ID for service command, mandatory.
    LONG serviceCmd = KLiwCmdNone;

    // Content MIME type, event type or any agreed one.
    LTEXT8 contentType = "";

    // Services class tells what kind of service is expected from
    // provider. See TLiwServiceClass enum for allowed values.
    // Optional, if not defined the default (KLiwClassMenu) is used.
    LONG serviceClass = KLiwClassMenu;

    // --------------------------------------------------------------
    // Additional options, if any.
    // --------------------------------------------------------------

    // Defines UID for default provider. If provider for this
    // UID exists, all the setup calls will be forwarded to it
    // first (eg. if default provider implements 'menu' service class, it will
    // be the first provider to insert its menu items to the consumer menu).
    LONG defaultProvider = 0;

    // The maximum number of providers allowed for the criteria item.
    // There might be cases to limit the number of providers, e.g. for
    // limiting the number of menu items. Maximum is 255 providers per interest.
    BYTE maxProviders = 0xff;

    // Other options bits (8 bits reserved).
    BYTE loadOptions=0;

    // Reserved for extensions.
    LLINK reserved = 0; 
    }

//
// Criteria item with command name as string
//
STRUCT LIW_CRITERIA_ITEM_2
    {
    LONG id;
    LONG serviceCmd = KLiwCmdAsStr;
    // Service name.
    LTEXT8 serviceName = "";
    LTEXT8 contentType = "";
    LONG serviceClass = KLiwClassMenu;

    LONG defaultProvider = 0;
    BYTE maxProviders = 0xff;
    BYTE loadOptions=0;
    
    LLINK reserved = 0;    
    }

//
// Interest is an array of criteria items.
//
STRUCT LIW_INTEREST
    {
    STRUCT items[]; // LIW_CRITERIA_ITEM's
    }

// End of File