organizer_plat/searchfw_launcher_api/inc/searchdocumentid.h
author Simon Howkins <simonh@symbian.org>
Mon, 22 Nov 2010 16:01:09 +0000
branchRCL_3
changeset 93 d216ae5a8733
parent 0 f979ecb2b13e
permissions -rw-r--r--
Adjusted to avoid exports, etc, from a top-level bld.inf

/*
* Copyright (c) 2006-2007 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "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:  Class for document id which uinquely represents a file
*
*/


#ifndef C_SEARCHDOCUMENTID_H
#define C_SEARCHDOCUMENTID_H

#include <e32base.h>
#include <e32def.h>
#include <e32cmn.h>
#include <s32strm.h>

/**
 * This class references to a unique document matching the search criteria
 *
 * @lib searchutilities.lib
 */
NONSHARABLE_CLASS ( CSearchDocumentId ) : public CBase 
    {
    
public :
	/**
	 * Two phased constructor
	 *
	 * @param aPluginId - Plugin id of the Document
	 * @param aDocumentType - Document type of the Document
	 * @param aRepositoryId - Repository id of the Document
	 * @param aDocumentId - Document id of the Document
	 * @return The instantiated cSearchDocumentId
	 */
     IMPORT_C static CSearchDocumentId* NewL( const TInt aDocumentId, TUid aPluginId  );
											
	/**
	 * Two phased constructor
	 * 
	 * @param aDocumentId - CSearchDocument from which the CSearchDocument is 
	 *						 to be instantiated
	 * @return The instantiated cSearchDocumentId
	 */
     IMPORT_C static CSearchDocumentId* NewL( const CSearchDocumentId& aDocumentId );
	

	/**
	 * Two phased constructor
	 * 
	 * @param aStream - Stream from which to construct the CSearchDocumentId object
	 * @return The instantiated cSearchDocumentId
	 */
     IMPORT_C static CSearchDocumentId* NewL( RReadStream& aStream );
	 
		
	/**
	 * Destructor
	 */
	 virtual ~CSearchDocumentId();
		
	/**
	 * Externalizes the CSearchDocumentId class to the stream
	 * @param aStream - Stream to which to write the class data to
	 */
     IMPORT_C void ExternalizeL( RWriteStream& aStream ) const;
	
	
	/**
	 * Getter function for the pluginId of the CSearchDocumentId
	 * @return - Returns the Plugin Id
	 */
     IMPORT_C TUid PluginId() const;
	
	
	/**
	 * Getter function for the RepositoryId of the CSearchDocumentId
	 * @return - Returns RepositoryId of the CSearchDocumentId
	 */
     IMPORT_C const TInt32 RepositoryId() const;
	
	
	/**
	 * Getter function for the DocumentId of the CSearchDocumentId
	 * @return - Returns DocumentId of the CSearchDocumentId
	 */
     IMPORT_C const TInt DocumentId() const;
	
	
	/**
	 * Sets the repository id
	 * @param - aRepositoryId
	 */
     IMPORT_C void SetRepositoryIdL( const TInt32 aRepositoryId );
	
	
	
private:
	
	/**
	 * Default Constructor
	 * @param - aPluginId Plugin Id 
	 */
     CSearchDocumentId( TUid aPluginId );  
	
	/**
	 * ConstructL function that sets document id and repository ids that are taken as 
	 * args.
	 * @param aDocumentId - Document id 
	 */
     void ConstructL( const TInt aDocumentId );
	
	/**
	 * ConstructL function that sets document id and repository ids that are taken as 
	 * args.
	 * 
	 * @param aRepositoryId - Repository id
	 * @param aDocumentId - Document id 
	 */
     void ConstructL( const TInt32 aRepositoryId, const TInt aDocumentId );
	
	/**
	 * ConstructL function that initializes the RepositoryId and DocumentId of
	 * the class read from aStream which is passed as an argument
	 *
	 * @param aStream - Stream from where to read
	 */
     void ConstructL( RReadStream& aStream );
	
private: //data
	
	/**
	 * Plugin Id
	 */
	 TUid iPluginId; 
	
	/**
	 * Repository Id
	 */
	 TInt32 iRepositoryId; 
	
	/**
	 * Document Id	
	 * Own
	 */
 	 TInt iDocumentId; 
    };

#endif //C_SEARCHDOCUMENTID_H