browserutilities/schemehandler/SchemeDispatcher/inc/FileHandler.h
author Kiiskinen Klaus (Nokia-D-MSW/Tampere) <klaus.kiiskinen@nokia.com>
Mon, 30 Mar 2009 12:54:55 +0300
changeset 0 dd21522fd290
child 36 0ed94ceaa377
permissions -rw-r--r--
Revision: 200911 Kit: 200912

/*
* Copyright (c) 2002 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: 
*      Declaration of Scheme handler interface implementation for file:// scheme
*      
*
*/


#ifndef FILE_HANDLER_H
#define FILE_HANDLER_H

// INCLUDES

#include "BaseHandler.h"
#include <e32base.h>
#include <documentHandler.h>
#include <eikdoc.h>
#include <apparc.h>
#include <BrowserLauncher.h>

// FORWARD DECLARATION

// CLASS DECLARATION

/**
* Scheme Handler IF implementation class for file scheme
*/
class CFileHandler : public CBaseHandler,
                     public MAknServerAppExitObserver
    {
    public:     // Constructors and destructor

        /**
        * Two phased constructor. Leaves on failure.
        * @param - aUrl
        * @return The created object.
        */      
		static CFileHandler* NewL( const TDesC& aUrl );

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

	private: // Constructors

        /**
        * Constructor.
        */      
		CFileHandler();

        /**
        * Second phase constructor. Leaves on failure.
		* @param - aUrl
        */      
		void ConstructL( const TDesC& aUrl );

    private: // Functions from base classes

		/**
		* Url Handler with embedding
		* @param -
		*/
		void HandleUrlEmbeddedL();

		/**
		* Url Handler without embedding
		* @param -
		*/
		void HandleUrlStandaloneL();

		/**
		 *
		 * Implements the required behaviour when the editing of an embedded
		 * document completes.
		 *
		 * @param     
		 *            Indicates the state of the document.
		 */
        void HandleServerAppExit(TInt aReason);

		/**
        * Convert Url to file path. Leaves on failure.
        * @param 
        * @return 
        */    
		void ConvertUrlToPathL( TDes& aLiteral );

		/**
        * Convert Url to file path. Leaves on failure.
        * @param 
        * @return 
        */  
        void ConvertPathToUrlL( TDes& aLiteral );

		/**
        * Convert .
        * @param 
        * @return 
        */  
        HBufC* ParseFileSchemeLC( TBool& aDocHandler );

	private: // Data

		CDocumentHandler* iDocHandler; ///< Owned.
        CEikDocument* iDoc;            ///< Owned.
        CBrowserLauncher* iLauncher;   ///< Owned.       
	};

#endif /* def FILE_HANDLER_H */