ncdengine/inc/catalogsarray.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 26 Jan 2010 12:06:03 +0200
changeset 4 32704c33136d
permissions -rw-r--r--
Revision: 201001 Kit: 201004

/*
* Copyright (c) 2006 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:   Contains definition of Catalogs interface pointer array 
*
*/


#ifndef R_CATALOGS_ARRAY_H
#define R_CATALOGS_ARRAY_H

#include <e32cmn.h>

/**
 *  Array class for MCatalogsBase-derived interface pointers. Can be operated
 *  like ordinary RPointerArray array.
 *
 *  
 */
template< class T >
class RCatalogsArray : public RPointerArray< T >
    {
public:
    
    RCatalogsArray();
    
    RCatalogsArray( TInt aGranularity );
        
    /**
     * Empties the array and releases the referenced objects.
     *
     * It frees all memory allocated to the array and resets the internal state so
     * that it is ready to be reused. The function also calls Release() on all of
     * the objects whose pointers are contained by the array.
     * This array object can be allowed to go out of scope after a call to this
     * function.
     *
     * 
     * @see ResetAndRelease()
     */
    void ResetAndDestroy();


    /**
     * Empties the array and releases the referenced objects.
     *
     * It frees all memory allocated to the array and resets the internal state so
     * that it is ready to be reused. The function also calls Release() on all of
     * the objects whose pointers are contained by the array.
     * This array object can be allowed to go out of scope after a call to this
     * function.
     *
     * @note Same as ResetAndDestroy(), can be used instead if a more descriptive
     *       terminology for the operation is desired (contained objects will not
     *       necessarily be destroyed, but their Release() method is called).
     *
     * 
     * @see ResetAndDestroy()
     */
    inline void ResetAndRelease()
        {
        ResetAndDestroy();
        }

    };

#include "catalogsarray.inl"

#endif // R_CATALOGS_ARRAY_H