brandingserver/tools/bsimport/inc/cbsimportfilereader.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 15:31:29 +0300
branchRCL_3
changeset 21 cfd5c2994f10
parent 0 e6b17d312c8b
child 22 113b91e0a2ad
permissions -rw-r--r--
Revision: 201033 Kit: 201035

/*
* Copyright (c) 2006-2006 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:   Import reader opens and reads the XML file to CMDXMLDocument 
*                object
*
*/


#ifndef CBSIMPORTFILEREADER_H
#define CBSIMPORTFILEREADER_H

#include <e32base.h>
#include <gmxmlparser.h>

class CMDXMLDocument;
class CActiveScheduler;

/**
 *  Import reader opens and reads the XML file to CMDXMLDocument object
 *
 *  @lib brandimporter.exe
 *  @since S60 v3.2
 */
class CBSImportFileReader : public CBase,
                            public MMDXMLParserObserver
    {
public:

    static CBSImportFileReader* NewL( TBool aUseScheduler );
    
    static CBSImportFileReader* NewLC( TBool aUseScheduler );
    
    ~CBSImportFileReader();

    /**
     * Reads XML file to CMDXMLDocument object
     *
     * @since S60 v3.2
     * @param aFs file system handle
     * @param aFileName XML file to read
     */
    CMDXMLDocument* ReadXMLFileL( RFs& aFs, const TDesC& aFileName );
    
private:

    void ConstructL();

    CBSImportFileReader( TBool aUseScheduler );

// from base class MMDXMLParserObserver

    /**
     * From MMDXMLParserObserver.
     * Writes text to log
     *
     * @since S60 v3.2
     * @param aText text to write
     */
    void ParseFileCompleteL();
            
private: // Data
    
    // Own. XML parser
    CMDXMLParser* iParser;
    
    // Own. XML document from parser
    CMDXMLDocument* iDocument;

    // Own. ActiveScheduler
    CActiveScheduler* iScheduler;

    // Own. Scheduler waiter. Used when we can't use scheduler directly.    
    CActiveSchedulerWait* iWaiter;
    
    // Wheter we use CActiveScheduler or CActiveSchedulerWait
    TBool iUseScheduler;
    };

#endif //CBSIMPORTFILEREADER_H