idlefw/src/framework/main.cpp
author kashif.sayed
Fri, 26 Mar 2010 03:06:02 +0530
branchv5backport
changeset 30 f9f9f96b1873
parent 0 79c6a41cd166
permissions -rw-r--r--
user: kashif.sayed added contentcontrolsrv/.cproject added contentcontrolsrv/.project added contentcontrolsrv/group/ABLD.BAT added contentpublishingsrv/.cproject added contentpublishingsrv/.project added contentpublishingsrv/contentharvester/.cproject added contentpublishingsrv/contentharvester/.project added contentpublishingsrv/contentharvester/contentharvesterclient/group/ABLD.BAT added contentpublishingsrv/contentharvester/contentharvesterserver/group/ABLD.BAT added contentpublishingsrv/contentharvester/contentharvesterswiplugin/group/ABLD.BAT added contentpublishingsrv/contentharvester/factorysettingsplugin/group/ABLD.BAT added contentpublishingsrv/contentharvester/group/ABLD.BAT added contentpublishingsrv/group/ABLD.BAT added dependencies/S3libs/cpswrapper.lib added dependencies/S3libs/hscontentcontrol.lib added dependencies/S3libs/hspswrapper.lib added group/ABLD.BAT added homescreenpluginsrv/group/ABLD.BAT added homescreensrv_plat/group/ABLD.BAT added idlefw/group/ABLD.BAT added inc/ccontentmap.h added inc/cpdebug.h added inc/cpglobals.h added inc/cpliwmap.h added inc/cpluginvalidator.h added inc/cpserverdef.h added inc/cpublisherregistrymap.h added inc/mcssathandler.h added menucontentsrv/group/ABLD.BAT added xcfw/group/ABLD.BAT changed dependencies/S3libs/bld.inf

/*
* Copyright (c) 2005-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:  Entry point of Active Idle process.
*
*/


#include "ecom/ecom.h"
#include "aifw.h"
#include "debug.h"

GLDEF_C TInt E32Main()
    {
    __TICK("FW: Entry point");
    __UHEAP_MARK;
#ifdef _DEBUG
    // Check heap and handle count balance in debug builds
    TInt initPhc, initThc;
    RThread().HandleCount(initPhc, initThc);
#endif

    // Create cleaup stack
    CTrapCleanup* cleanupStack = CTrapCleanup::New();
    if (!cleanupStack)
        {
        return KErrNoMemory;
        }
        
    // Create and run the Active Idle Framework
    TInt aiFwResult = KErrNone;
    TRAP( aiFwResult, 
        CAiFw* fw = CAiFw::NewLC();
        fw->RunL();
        CleanupStack::PopAndDestroy( fw );
        );

    // Clean up before exit
    delete cleanupStack;
    REComSession::FinalClose();

#ifdef _DEBUG
    // Check heap and handle count balance in debug builds
    TInt exitPhc, exitThc;
    RThread().HandleCount(exitPhc, exitThc);
    if ( exitThc != initThc )
        {
        __PRINT(__DBG_FORMAT("FW: Handle count mismatch %d at exit"), exitThc - initThc);
        }
#endif

    __UHEAP_MARKEND;
    __PRINT_IF_ERROR(aiFwResult, "FW: Framework exit with error %d");
    return aiFwResult;
    }