textrendering/texthandling/ttext/TETextServer.cpp
author hgs
Tue, 07 Sep 2010 16:39:34 +0800
changeset 59 7d891bb52a7d
parent 53 11e2bb0d14ba
permissions -rw-r--r--
201033_04
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
*
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    16
*/
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    17
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    18
#include "TETextServer.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    19
#include "T_FIELD1.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    20
#include "T_ROMAN.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    21
#include "T_STREAM.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    22
#include "T_RICHOOM.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    23
#include "TRTCOPY.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    24
#include "TRTCUSTM.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    25
#include "TTIMES1.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    26
#include "T_CONVRT.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    27
#include "T_CONVS.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    28
#include "T_CONVS1.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    29
#include "T_CPLAIN.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    30
#include "T_CUTPST.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    31
#include "T_FMT.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    32
#include "T_FMT1.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    33
#include "T_IMPORT.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    34
#include "T_INDTER.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    35
#include "T_LAYDOC.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    36
#include "T_PARSE_for_TEF.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    37
#include "T_PICRES.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    38
#include "T_RICH1A.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    39
#include "T_RTCLIP.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    40
#include "T_SCANDC.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    41
#include "T_STYLE.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    42
#include "T_TIMES.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    43
#include "T_TRAN.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    44
#include "TEtextDefect.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    45
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    46
_LIT(KServerName, "TETextServer");
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    47
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    48
CTETextServer *CTETextServer::NewL()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    49
/**
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    50
   @return - Instance of the test server
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    51
   Same code for Secure and non-secure variants
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    52
   Called inside the MainL() function to create and start the
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    53
   CTestServer derived server.
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    54
 */
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    55
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    56
	CTETextServer * server = new (ELeave) CTETextServer();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    57
    CleanupStack::PushL(server);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    58
    // CServer base class call
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    59
    server->StartL(KServerName);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    60
    CleanupStack::Pop(server);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    61
    return server;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    62
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    63
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    64
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    65
LOCAL_C void MainL()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    66
//
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    67
// Secure variant
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    68
// Much simpler, uses the new Rendezvous() call to sync with the client
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    69
//
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    70
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    71
#if (defined __DATA_CAGING__)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    72
    RProcess().DataCaging(RProcess::EDataCagingOn);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    73
    RProcess().SecureApi(RProcess::ESecureApiOn);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    74
#endif
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    75
    CActiveScheduler* sched=NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    76
    sched=new(ELeave) CActiveScheduler;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    77
    CActiveScheduler::Install(sched);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    78
    CTETextServer *server = NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    79
    // Create the CTestServer derived server
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    80
    TRAPD(err,server = CTETextServer::NewL());
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    81
    if(!err)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    82
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    83
        // Sync with the client and enter the active scheduler
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    84
        RProcess::Rendezvous(KErrNone);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    85
        sched->Start();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    86
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    87
    delete server;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    88
    delete sched;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    89
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    90
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    91
/** @return - Standard Epoc error code on process exit
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    92
    Secure variant only
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    93
    Process entry point. Called by client using RProcess API
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    94
*/
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    95
GLDEF_C TInt E32Main()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    96
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    97
    __UHEAP_MARK;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    98
    CTrapCleanup* cleanup = CTrapCleanup::New();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    99
    if(cleanup == NULL)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   100
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   101
        return KErrNoMemory;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   102
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   103
    TRAPD(err,MainL());
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   104
    // This if statement is here just to shut up RVCT, which would otherwise warn
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   105
    // that err was set but never used
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   106
    if (err)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   107
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   108
        err = KErrNone;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   109
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   110
    delete cleanup;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   111
    __UHEAP_MARKEND;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   112
    return KErrNone;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   113
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   114
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   115
CTestStep *CTETextServer::CreateTestStep(const TDesC& aStepName)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   116
/**
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   117
   @return - A CTestStep derived instance
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   118
   Secure and non-secure variants
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   119
   Implementation of CTestServer pure virtual
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   120
 */
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   121
	{
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   122
	if (aStepName == KTestStep_T_FIELD1)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   123
		return new CT_FIELD1();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   124
	else if (aStepName == KTestStep_T_ROMAN)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   125
		return new CT_ROMAN();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   126
	else if (aStepName == KTestStep_T_STREAM)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   127
		return new CT_STREAM();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   128
	else if (aStepName == KTestStep_T_RICHOOM)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   129
		return new CT_RICHOOM();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   130
    else if (aStepName == KTestStep_T_TRTCOPY)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   131
        return new CT_TRTCOPY();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   132
    else if (aStepName == KTestStep_T_TRTCUSTM)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   133
        return new CT_TRTCUSTM();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   134
    else if (aStepName == KTestStep_T_TTIMES1)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   135
        return new CT_TTIMES1();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   136
    else if (aStepName == KTestStep_T_CONVRT)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   137
        return new CT_CONVRT();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   138
    else if (aStepName == KTestStep_T_CONVS)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   139
        return new CT_CONVS();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   140
    else if (aStepName == KTestStep_T_CONVS1)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   141
        return new CT_CONVS1();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   142
    else if (aStepName == KTestStep_T_CPLAIN)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   143
        return new CT_CPLAIN();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   144
    else if (aStepName == KTestStep_T_CUTPST)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   145
        return new CT_CUTPST();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   146
    else if (aStepName == KTestStep_T_FMT)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   147
        return new CT_FMT();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   148
    else if (aStepName == KTestStep_T_FMT1)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   149
        return new CT_FMT1();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   150
    else if (aStepName == KTestStep_T_IMPORT)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   151
        return new CT_IMPORT();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   152
    else if (aStepName == KTestStep_T_INDTER)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   153
        return new CT_INDTER();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   154
    else if (aStepName == KTestStep_T_LAYDOC)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   155
        return new CT_LAYDOC();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   156
    else if (aStepName == KTestStep_T_PARSE)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   157
        return new CT_PARSE();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   158
    else if (aStepName == KTestStep_T_PICRES)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   159
        return new CT_PICRES();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   160
    else if (aStepName == KTestStep_T_RICH1A)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   161
        return new CT_RICH1A();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   162
    else if (aStepName == KTestStep_T_RTCLIP)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   163
        return new CT_RTCLIP();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   164
    else if (aStepName == KTestStep_T_SCANDC)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   165
        return new CT_SCANDC();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   166
    else if (aStepName == KTestStep_T_STYLE)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   167
        return new CT_STYLE();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   168
    else if (aStepName == KTestStep_T_TIMES)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   169
        return new CT_TIMES();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   170
    else if (aStepName == KTestStep_T_TRAN)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   171
        return new CT_TRAN();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   172
    else if (aStepName == KTestStep_TEtextDefect)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   173
        return new CTEtextDefect();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   174
	return NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   175
	}