phonebookengines/VirtualPhonebook/VPbkCntModel/inc/CContactLink.h
author andy simpson <andrews@symbian.org>
Thu, 02 Sep 2010 15:35:50 +0100
branchRCL_3
changeset 64 c1e8ba0c2b16
parent 0 e686773b3f54
permissions -rw-r--r--
Merge after bad RCL_3 drop reverted

/*
* Copyright (c) 2002-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:  The virtual phonebook contact link
*
*/



#ifndef CCONTACTLINK_H
#define CCONTACTLINK_H

// INCLUDES
#include <MVPbkContactLink.h>
#include <MVPbkStreamable.h>
#include <MVPbkContactLinkPacking.h>
#include <MVPbkContactBookmark.h>
#include <e32base.h>
#include <cntdef.h>
#include <e32des8.h>
#include "TVPbkContactStoreUriPtr.h"

class RReadStream;
class CVPbkContactLinkArray;

namespace VPbkCntModel {

// FORWARD DECLARATIONS
class CContactStore;

// CLASS DECLARATIONS

/**
 * A externalizable Contact link that can be referenced from external systems. 
 */
NONSHARABLE_CLASS( CContactLink ): 
        public CBase, 
        public MVPbkContactLink,
        public MVPbkStreamable,
        public MVPbkContactLinkPacking,
        public MVPbkContactBookmark
    {
    public: // constructor
        /**
         * Construct a new link from aLinkBuf. 
         * @param aStoreUri  The complete URI of this store
         */
        static CContactLink* NewLC( CContactStore& aContactStore, 
                                   RReadStream& aStream );

        /**
         * Construct a new link from aId. 
         * @param aStoreUri  The complete URI of this store
         */
        static CContactLink* NewLC(
                CContactStore& aContactStore, 
                TContactItemId aId,
                TInt aFieldId = KErrNotFound );

        ~CContactLink();

    public: // interface
        /**
         * Returns ETrue if this aLink's aComponent is from this store. 
         * @param aStoreUri The complete URI of this store
         * @param aLink The link
         * @aComponent  The component that is compared
         */
        static TBool Matches( const TDesC& aStoreUri, 
                const MVPbkContactLink& aLink,
                TVPbkContactStoreUriPtr::TVPbkContactStoreUriComponent 
                                                        aComponent );

        /**
         * Returns ETrue if this aLink is from this store. 
         * The URI of the link matches this stores URI.
         * @param aStoreUri The complete URI of this store
         * @param aLink The link
         */
        static TBool Matches( const TVPbkContactStoreUriPtr& aStoreUri, 
                             const MVPbkContactLink& aLink );

        /**
         * Returns the contact model contact id of this link.
         */
        TContactItemId ContactId() const;
        
        /**
         * Returns the contact field id of this link.
         */
        TInt ContactFieldId() const;
        
        /**
         * Sets the contact model contact id of this link.
         */
        void SetContactId( TContactItemId aContactId );

        /**
         * Sets the contact field id of this link.
         */
        void SetContactFieldId( TInt aContactFieldId );

        /**
         * Contact database filename with file type extension.
         */
        const TPtrC ContactDbFileName() const;

    public: // from MVPbkContactLink
        MVPbkContactStore& ContactStore() const;
        TBool IsSame( const MVPbkContactLink& aOther ) const;
        TBool RefersTo( const MVPbkBaseContact& aContact ) const;
        const MVPbkStreamable* Streamable() const;
        const MVPbkContactLinkPacking& Packing() const;
        MVPbkContactLink* CloneLC() const;

    public: // From MVPbkStreamable
        void ExternalizeL( RWriteStream& aStream ) const;
        TInt ExternalizedSize() const;

    public: // from MVPbkContactLinkPacking
        TInt InternalPackedSize() const;
        void PackInternalsL( RWriteStream& aStream ) const;

    private: // implementation
        CContactLink( CContactStore& aContactStore );
        void CommonConstructL();
        void ConstructL( RReadStream& aStream );
        void ConstructL( TContactItemId aId, TInt aFieldId );

    private: // data members
        /// Ref: Contact store this link belongs to.
        CContactStore& iContactStore;
        /// Own: Contact item id
        TContactItemId iId;
        /// Own: Contact field id
        TInt iFieldId;
        /// Own: a link array for externalizing
        CVPbkContactLinkArray* iLinkArray;
    };

// INLINE FUNCTIONS

} // namespace VPbkCntModel

#endif // CCONTACTLINK_H
//End of file