textrendering/textformatting/test/src/tformserver.cpp
author hgs
Thu, 23 Sep 2010 12:50:02 +0800
changeset 64 f66674566702
parent 53 11e2bb0d14ba
permissions -rw-r--r--
201033_08
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
53
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     1
/*
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     3
* All rights reserved.
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     8
*
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
     9
* Initial Contributors:
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    11
*
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    12
* Contributors:
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    13
*
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    14
* Description: 
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    15
* @file
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    16
* @internalComponent 
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    17
*
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    18
*/
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    19
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    20
#include "tformserver.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    21
#include "tcustomcharmapping.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    22
#include "ttagmaimp.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    23
#include "ttmsource.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    24
#include "tbidicursorpos.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    25
#include "ttmcode.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    26
#include "tunique.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    27
#include "tundo.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    28
#include "tinterpreter.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    29
#include "tformat.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    30
#include "tinlinetext.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    31
#include "tgraphemeiterator.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    32
#include "tformbenchmark.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    33
#include "tlinepag.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    34
#include "tformhindi.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    35
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    36
_LIT(KServerName,"TFormServer");
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    37
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    38
CTFormServer* CTFormServer::NewL()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    39
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    40
    CTFormServer * server = new (ELeave) CTFormServer();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    41
    CleanupStack::PushL(server);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    42
    // CServer base class call
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    43
    server->StartL(KServerName);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    44
    CleanupStack::Pop(server);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    45
    return server;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    46
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    47
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    48
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    49
LOCAL_C void MainL()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    50
//
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    51
// Secure variant
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    52
// Much simpler, uses the new Rendezvous() call to sync with the client
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    53
//
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    54
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    55
#if (defined __DATA_CAGING__)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    56
    RProcess().DataCaging(RProcess::EDataCagingOn);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    57
    RProcess().SecureApi(RProcess::ESecureApiOn);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    58
#endif
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    59
    CActiveScheduler* sched=NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    60
    sched=new(ELeave) CActiveScheduler;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    61
    CActiveScheduler::Install(sched);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    62
    CTFormServer *server = NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    63
    // Create the CTestServer derived server
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    64
    TRAPD(err,server = CTFormServer::NewL());
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    65
    if(!err)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    66
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    67
        // Sync with the client and enter the active scheduler
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    68
        RProcess::Rendezvous(KErrNone);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    69
        sched->Start();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    70
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    71
    delete server;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    72
    delete sched;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    73
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    74
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    75
/** @return - Standard Epoc error code on process exit
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    76
    Secure variant only
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    77
    Process entry point. Called by client using RProcess API
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    78
*/
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    79
GLDEF_C TInt E32Main()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    80
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    81
    __UHEAP_MARK;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    82
    CTrapCleanup* cleanup = CTrapCleanup::New();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    83
    if(cleanup == NULL)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    84
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    85
        return KErrNoMemory;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    86
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    87
    TRAPD(err,MainL());
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    88
    // This if statement is here just to shut up RVCT, which would otherwise warn
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    89
    // that err was set but never used
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    90
    if (err)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    91
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    92
        err = KErrNone;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    93
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    94
    delete cleanup;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    95
    __UHEAP_MARKEND;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    96
    return KErrNone;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    97
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    98
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    99
CTestStep *CTFormServer::CreateTestStep(const TDesC& aStepName)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   100
/**
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   101
   @return - A CTestStep derived instance
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   102
   Secure and non-secure variants
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   103
   Implementation of CTestServer pure virtual
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   104
 */
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   105
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   106
    if(aStepName == KTestStep_T_CustomCharMapping)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   107
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   108
        return new CTCustomCharMappingStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   109
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   110
    else if(aStepName == KTestStep_T_TagmaImp)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   111
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   112
        return new CTTagmaImpStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   113
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   114
    else if(aStepName == KTestStep_T_TmSource)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   115
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   116
        return new CTTmSourceStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   117
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   118
    else if(aStepName == KTestStep_T_BidiCursorPos)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   119
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   120
        return new CTBidiCursorPosStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   121
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   122
    else if(aStepName == KTestStep_T_TmCode)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   123
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   124
        return new CTTmCodeStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   125
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   126
    else if(aStepName == KTestStep_T_Unique)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   127
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   128
        return new CTUniqueStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   129
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   130
    else if(aStepName == KTestStep_T_Undo)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   131
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   132
        return new CTUndoStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   133
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   134
    else if(aStepName == KTestStep_T_Interpreter)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   135
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   136
        return new CTInterpreterStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   137
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   138
    else if(aStepName == KTestStep_T_Format)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   139
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   140
        return new CTFormatStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   141
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   142
    else if(aStepName == KTestStep_T_InLineText)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   143
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   144
        return new CTInLineTextStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   145
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   146
    else if(aStepName == KTestStep_T_GraphemeIterator)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   147
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   148
        return new CTGraphemeIteratorStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   149
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   150
    else if(aStepName == KTestStep_T_FormBenchmark)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   151
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   152
        return new CTFormBenchmarkStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   153
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   154
    else if(aStepName == KTestStep_T_LinePag)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   155
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   156
        return new CTLinePagStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   157
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   158
    else if(aStepName == KTestStep_T_FormHindi)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   159
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   160
        return new CTFormHindiStep();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   161
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   162
        
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   163
    
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   164
    return NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   165
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   166
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   167
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   168