tracesrv/tracecompiler/test/multipleMmpTestCases/mmp_traces_mmpname/src/MultipleMmpApp1.cpp
author hgs
Fri, 08 Oct 2010 14:56:39 +0300
changeset 56 aa2539c91954
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: 
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
//  Include Files  
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include "MultipleMmpApp.h"
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
#include <e32std.h>
hgs
parents:
diff changeset
    24
#include <e32cons.h>			// Console
hgs
parents:
diff changeset
    25
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
    26
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    27
#include "MultipleMmpApp1Traces.h"
hgs
parents:
diff changeset
    28
#endif
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
//  Constants
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
_LIT(KTextConsoleTitle, "Console");
hgs
parents:
diff changeset
    33
_LIT(KTextFailed, " failed, leave code = %d");
hgs
parents:
diff changeset
    34
_LIT(KTextPressAnyKey, " [press any key]\n");
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
//  Global Variables
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
LOCAL_D CConsoleBase* console; // write all messages to this
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
//  Local Functions
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
LOCAL_C void MainL()
hgs
parents:
diff changeset
    44
    {
hgs
parents:
diff changeset
    45
    /****************************TRACE STATEMENTS*********************************/
hgs
parents:
diff changeset
    46
    OstTrace0( TRACE_FLOW, TEST1_MAINL, "MainL()" );
hgs
parents:
diff changeset
    47
    OstTrace0( TRACE_FLOW, TEST2_MAINL, "MainL()" );    
hgs
parents:
diff changeset
    48
    /*****************************************************************************/
hgs
parents:
diff changeset
    49
    
hgs
parents:
diff changeset
    50
    CallSomeMoreTraceStatements();
hgs
parents:
diff changeset
    51
    
hgs
parents:
diff changeset
    52
    console->Write(_L("Hello, world!\n"));
hgs
parents:
diff changeset
    53
    }
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
LOCAL_C void DoStartL()
hgs
parents:
diff changeset
    56
    {
hgs
parents:
diff changeset
    57
    // Create active scheduler (to run active objects)
hgs
parents:
diff changeset
    58
    CActiveScheduler* scheduler = new (ELeave) CActiveScheduler();
hgs
parents:
diff changeset
    59
    CleanupStack::PushL(scheduler);
hgs
parents:
diff changeset
    60
    CActiveScheduler::Install(scheduler);
hgs
parents:
diff changeset
    61
hgs
parents:
diff changeset
    62
    MainL();
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
    // Delete active scheduler
hgs
parents:
diff changeset
    65
    CleanupStack::PopAndDestroy(scheduler);
hgs
parents:
diff changeset
    66
    }
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
//  Global Functions
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
GLDEF_C TInt E32Main()
hgs
parents:
diff changeset
    71
    {
hgs
parents:
diff changeset
    72
    // Create cleanup stack
hgs
parents:
diff changeset
    73
    __UHEAP_MARK;
hgs
parents:
diff changeset
    74
    CTrapCleanup* cleanup = CTrapCleanup::New();
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
    // Create output console
hgs
parents:
diff changeset
    77
    TRAPD(createError, console = Console::NewL(KTextConsoleTitle, TSize(
hgs
parents:
diff changeset
    78
            KConsFullScreen, KConsFullScreen)));
hgs
parents:
diff changeset
    79
    if (createError)
hgs
parents:
diff changeset
    80
        return createError;
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
    // Run application code inside TRAP harness, wait keypress when terminated
hgs
parents:
diff changeset
    83
    TRAPD(mainError, DoStartL());
hgs
parents:
diff changeset
    84
    if (mainError)
hgs
parents:
diff changeset
    85
        console->Printf(KTextFailed, mainError);
hgs
parents:
diff changeset
    86
    console->Printf(KTextPressAnyKey);
hgs
parents:
diff changeset
    87
    console->Getch();
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
    delete console;
hgs
parents:
diff changeset
    90
    delete cleanup;
hgs
parents:
diff changeset
    91
    __UHEAP_MARKEND;
hgs
parents:
diff changeset
    92
    return KErrNone;
hgs
parents:
diff changeset
    93
    }
hgs
parents:
diff changeset
    94