filemanager/GFLM/inc/CGflmFileSystemItem.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 12 Mar 2010 15:41:37 +0200
branchRCL_3
changeset 7 8812206c49a0
parent 0 6a9f87576119
permissions -rw-r--r--
Revision: 201006 Kit: 201008

/*
* 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:  File system item definitions
*
*/



#ifndef CGFLMFILESYSTEMITEM_H
#define CGFLMFILESYSTEMITEM_H


//  INCLUDES
#include <e32base.h>
#include "CGflmGroupItem.h"


//  FORWARD DECLARATIONS
class TEntry;


// CLASS DECLARATION

/**
*  A class representing a file system item.
*  A file system item is either a file or a directory.
*
*  @lib GFLM.lib
*  @since 2.0
*/
class CGflmFileSystemItem : public CGflmGroupItem
    {
    public:  // Constructors and destructor

        /**
        * Two-phased constructor.
        */
        static CGflmFileSystemItem* NewLC(
            const TEntry& aFSEntry,
            const TDesC& aBasePath );

        /**
        * Destructor.
        */
        virtual ~CGflmFileSystemItem( );

    public: // New functions

        /**
        * Get the full path of the item.
        * @since 2.0
        * @param aPath Modifiable descriptor with atleast the size of
        *        KMaxFileName. The full path of the item will be
        *        placed in this descriptor.
        */
        IMPORT_C void GetFullPath( TDes& aPath ) const;

        /**
        * Sets the localized name of the item.
        * @since 2.0
        * @param aName A descriptor containing the localized name for the
                 entry. A copy of the name is created.
        */
        IMPORT_C void SetLocalizedNameL( const TDesC& aName );

        /**
        * Get reference to TEntry object of the item.
        * @since 3.1
        * @return  A reference to TEntry object.
        */
        IMPORT_C const TEntry& Entry() const;

        /**
        * Get the full path of the item.
        * @since 3.2
        * @return Item full path. The pointer must be freed.
        */
        IMPORT_C HBufC* FullPathLC() const;

        /**
        * Get the full path of the item.
        * @since 3.2
        * @return Item full path. The pointer must be freed.
        */
        IMPORT_C HBufC* FullPathL() const;

    public: // From CGflmGroupItem

        TGflmItemType Type() const;

        TPtrC Name() const;

        TTime Date() const;

        TInt64 Size() const;

        TPtrC Ext() const;

    private:

        void SetExt();

    protected:

        /**
        * C++ default constructor.
        */
        CGflmFileSystemItem(
            const TEntry& aFSEntry,
            const TDesC& aBasePath );

        inline CGflmFileSystemItem()
            {
            }

        inline void SetBasePath( const TDesC& aBasePath )
            {
            iBasePath.Set( aBasePath );
            }
    
        void SetEntry( const TEntry& aFSEntry );

    private:    // Data
        // A reference to a TEntry object that is the actual filesystem entry
        const TEntry* iFSEntry;

        // A pointer descriptor that contains the base path of the
        // filesystem entry.
        TPtrC iBasePath;

        // The localized name of the entry. NULL if it doesn't have one.
        HBufC* iLocalizedName;

        // A pointer descriptor that contains the file extension
        TPtrC iExt;

    };

#endif      // CGFLMFILESYSTEMITEM_H

// End of File