charconvfw/fatfilenameconversionplugins/test/T_FatCharsetConvServer.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
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    19
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    20
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    21
#include "T_FatCharsetConvServer.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    22
#include "T_CP874.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    23
#include "T_CP932.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    24
#include "T_CP936.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    25
#include "T_CP949.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    26
#include "T_CP950.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    27
#include "T_CP1250.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    28
#include "T_CP1251.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    29
#include "T_CP1252.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    30
#include "T_CP1253.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    31
#include "T_CP1254.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    32
#include "T_CP1255.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    33
#include "T_CP1256.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    34
#include "T_CP1257.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    35
#include "T_CP1258.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    36
#include "T_CP54936.h"
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    37
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    38
/* Path to the script
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    39
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    40
c:\z:\t_TEF\t_TEF_All.script
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    41
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    42
*/
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    43
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    44
_LIT(KServerName,"T_FatCharsetConvServer");
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    45
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    46
CT_FatCharsetConvServer *CT_FatCharsetConvServer::NewL()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    47
/**
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    48
   @return - Instance of the test server
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    49
   Same code for Secure and non-secure variants
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    50
   Called inside the MainL() function to create and start the
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    51
   CTestServer derived server.
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    52
 */
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    53
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    54
	CT_FatCharsetConvServer * server = new (ELeave) CT_FatCharsetConvServer();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    55
    CleanupStack::PushL(server);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    56
    // CServer base class call
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    57
    server->StartL(KServerName);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    58
    CleanupStack::Pop(server);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    59
    return server;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    60
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    61
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    62
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    63
LOCAL_C void MainL()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    64
//
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    65
// Secure variant
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    66
// Much simpler, uses the new Rendezvous() call to sync with the client
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    67
//
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    68
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    69
#if (defined __DATA_CAGING__)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    70
    RProcess().DataCaging(RProcess::EDataCagingOn);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    71
    RProcess().SecureApi(RProcess::ESecureApiOn);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    72
#endif
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    73
    CActiveScheduler* sched=NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    74
    sched=new(ELeave) CActiveScheduler;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    75
    CActiveScheduler::Install(sched);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    76
    CT_FatCharsetConvServer *server = NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    77
    // Create the CTestServer derived server
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    78
    TRAPD(err,server = CT_FatCharsetConvServer::NewL());
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    79
    if(!err)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    80
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    81
        // Sync with the client and enter the active scheduler
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    82
        RProcess::Rendezvous(KErrNone);
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    83
        sched->Start();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    84
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    85
    delete server;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    86
    delete sched;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    87
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    88
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    89
/** @return - Standard Epoc error code on process exit
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    90
    Secure variant only
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    91
    Process entry point. Called by client using RProcess API
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    92
*/
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    93
GLDEF_C TInt E32Main()
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    94
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    95
    __UHEAP_MARK;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    96
    CTrapCleanup* cleanup = CTrapCleanup::New();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    97
    if(cleanup == NULL)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    98
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
    99
        return KErrNoMemory;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   100
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   101
    TRAPD(err,MainL());
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   102
    // This if statement is here just to shut up RVCT, which would otherwise warn
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   103
    // that err was set but never used
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   104
    if (err)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   105
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   106
        err = KErrNone;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   107
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   108
    delete cleanup;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   109
    __UHEAP_MARKEND;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   110
    return KErrNone;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   111
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   112
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   113
CTestStep *CT_FatCharsetConvServer::CreateTestStep(const TDesC& aStepName)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   114
/**
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   115
   @return - A CTestStep derived instance
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   116
   Secure and non-secure variants
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   117
   Implementation of CTestServer pure virtual
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   118
 */
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   119
    {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   120
    if(aStepName == KTestStep_T_CP874)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   121
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   122
        return new CT_CP874();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   123
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   124
    else if(aStepName == KTestStep_T_CP932)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   125
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   126
        return new CT_CP932();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   127
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   128
    else if(aStepName == KTestStep_T_CP936)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   129
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   130
        return new CT_CP936();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   131
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   132
    else if(aStepName == KTestStep_T_CP949)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   133
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   134
        return new CT_CP949();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   135
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   136
    else if(aStepName == KTestStep_T_CP950)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   137
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   138
        return new CT_CP950();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   139
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   140
    else if(aStepName == KTestStep_T_CP1250)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   141
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   142
        return new CT_CP1250();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   143
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   144
    else if(aStepName == KTestStep_T_CP1251)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   145
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   146
        return new CT_CP1251();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   147
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   148
    else if(aStepName == KTestStep_T_CP1252)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   149
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   150
        return new CT_CP1252();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   151
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   152
    else if(aStepName == KTestStep_T_CP1253)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   153
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   154
        return new CT_CP1253();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   155
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   156
    else if(aStepName == KTestStep_T_CP1254)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   157
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   158
        return new CT_CP1254();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   159
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   160
    else if(aStepName == KTestStep_T_CP1255)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   161
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   162
        return new CT_CP1255();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   163
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   164
    else if(aStepName == KTestStep_T_CP1256)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   165
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   166
        return new CT_CP1256();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   167
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   168
    else if(aStepName == KTestStep_T_CP1257)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   169
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   170
        return new CT_CP1257();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   171
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   172
    else if(aStepName == KTestStep_T_CP1258)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   173
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   174
        return new CT_CP1258();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   175
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   176
    else if(aStepName == KTestStep_T_CP54936)
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   177
        {
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   178
        return new CT_CP54936();
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   179
        }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   180
    return NULL;
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   181
    }
11e2bb0d14ba 201028_05
hgs
parents:
diff changeset
   182