tracesrv/tracecompiler/test/multipleMmpTestCases/mmp_traces/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
//  Include Files  
hgs
parents:
diff changeset
     3
hgs
parents:
diff changeset
     4
#include "MultipleMmpApp.h"
hgs
parents:
diff changeset
     5
#include <e32base.h>
hgs
parents:
diff changeset
     6
#include <e32std.h>
hgs
parents:
diff changeset
     7
#include <e32cons.h>			// Console
hgs
parents:
diff changeset
     8
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
     9
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    10
#include "MultipleMmpApp1Traces.h"
hgs
parents:
diff changeset
    11
#endif
hgs
parents:
diff changeset
    12
hgs
parents:
diff changeset
    13
//  Constants
hgs
parents:
diff changeset
    14
hgs
parents:
diff changeset
    15
_LIT(KTextConsoleTitle, "Console");
hgs
parents:
diff changeset
    16
_LIT(KTextFailed, " failed, leave code = %d");
hgs
parents:
diff changeset
    17
_LIT(KTextPressAnyKey, " [press any key]\n");
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
//  Global Variables
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
LOCAL_D CConsoleBase* console; // write all messages to this
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
//  Local Functions
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
LOCAL_C void MainL()
hgs
parents:
diff changeset
    27
    {
hgs
parents:
diff changeset
    28
    /****************************TRACE STATEMENTS*********************************/
hgs
parents:
diff changeset
    29
    OstTrace0( TRACE_FLOW, TEST1_MAINL, "MainL()" );
hgs
parents:
diff changeset
    30
    OstTrace0( TRACE_FLOW, TEST2_MAINL, "MainL()" );    
hgs
parents:
diff changeset
    31
    /*****************************************************************************/
hgs
parents:
diff changeset
    32
    
hgs
parents:
diff changeset
    33
    CallSomeMoreTraceStatements();
hgs
parents:
diff changeset
    34
    
hgs
parents:
diff changeset
    35
    console->Write(_L("Hello, world!\n"));
hgs
parents:
diff changeset
    36
    }
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
LOCAL_C void DoStartL()
hgs
parents:
diff changeset
    39
    {
hgs
parents:
diff changeset
    40
    // Create active scheduler (to run active objects)
hgs
parents:
diff changeset
    41
    CActiveScheduler* scheduler = new (ELeave) CActiveScheduler();
hgs
parents:
diff changeset
    42
    CleanupStack::PushL(scheduler);
hgs
parents:
diff changeset
    43
    CActiveScheduler::Install(scheduler);
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
    MainL();
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
    // Delete active scheduler
hgs
parents:
diff changeset
    48
    CleanupStack::PopAndDestroy(scheduler);
hgs
parents:
diff changeset
    49
    }
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
//  Global Functions
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
GLDEF_C TInt E32Main()
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
    // Create cleanup stack
hgs
parents:
diff changeset
    56
    __UHEAP_MARK;
hgs
parents:
diff changeset
    57
    CTrapCleanup* cleanup = CTrapCleanup::New();
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
    // Create output console
hgs
parents:
diff changeset
    60
    TRAPD(createError, console = Console::NewL(KTextConsoleTitle, TSize(
hgs
parents:
diff changeset
    61
            KConsFullScreen, KConsFullScreen)));
hgs
parents:
diff changeset
    62
    if (createError)
hgs
parents:
diff changeset
    63
        return createError;
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
    // Run application code inside TRAP harness, wait keypress when terminated
hgs
parents:
diff changeset
    66
    TRAPD(mainError, DoStartL());
hgs
parents:
diff changeset
    67
    if (mainError)
hgs
parents:
diff changeset
    68
        console->Printf(KTextFailed, mainError);
hgs
parents:
diff changeset
    69
    console->Printf(KTextPressAnyKey);
hgs
parents:
diff changeset
    70
    console->Getch();
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
    delete console;
hgs
parents:
diff changeset
    73
    delete cleanup;
hgs
parents:
diff changeset
    74
    __UHEAP_MARKEND;
hgs
parents:
diff changeset
    75
    return KErrNone;
hgs
parents:
diff changeset
    76
    }
hgs
parents:
diff changeset
    77