os/ossrv/stdcpp/tsrc/BC/apps/tutility/src/tutilityblocks.cpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
/*
sl@0
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     3
* All rights reserved.
sl@0
     4
* This component and the accompanying materials are made available
sl@0
     5
* under the terms of "Eclipse Public License v1.0"
sl@0
     6
* which accompanies this distribution, and is available
sl@0
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     8
*
sl@0
     9
* Initial Contributors:
sl@0
    10
* Nokia Corporation - initial contribution.
sl@0
    11
*
sl@0
    12
* Contributors:
sl@0
    13
*
sl@0
    14
* Description:       
sl@0
    15
*
sl@0
    16
*/
sl@0
    17
sl@0
    18
sl@0
    19
sl@0
    20
// INCLUDE FILES
sl@0
    21
#include <e32svr.h>
sl@0
    22
#include <StifParser.h>
sl@0
    23
#include <Stiftestinterface.h>
sl@0
    24
#include <memory>
sl@0
    25
sl@0
    26
#include "tutility.h"
sl@0
    27
sl@0
    28
sl@0
    29
using namespace std;
sl@0
    30
sl@0
    31
// ============================= LOCAL FUNCTIONS ===============================
sl@0
    32
sl@0
    33
// -----------------------------------------------------------------------------
sl@0
    34
// ?function_name ?description.
sl@0
    35
// ?description
sl@0
    36
// Returns: ?value_1: ?description
sl@0
    37
//          ?value_n: ?description_line1
sl@0
    38
//                    ?description_line2
sl@0
    39
// -----------------------------------------------------------------------------
sl@0
    40
//
sl@0
    41
/*
sl@0
    42
?type ?function_name(
sl@0
    43
    ?arg_type arg,  // ?description
sl@0
    44
    ?arg_type arg)  // ?description
sl@0
    45
    {
sl@0
    46
sl@0
    47
    ?code  // ?comment
sl@0
    48
sl@0
    49
    // ?comment
sl@0
    50
    ?code
sl@0
    51
    }
sl@0
    52
*/
sl@0
    53
sl@0
    54
// ============================ MEMBER FUNCTIONS ===============================
sl@0
    55
sl@0
    56
// -----------------------------------------------------------------------------
sl@0
    57
// Ctutility::Delete
sl@0
    58
// Delete here all resources allocated and opened from test methods. 
sl@0
    59
// Called from destructor. 
sl@0
    60
// -----------------------------------------------------------------------------
sl@0
    61
//
sl@0
    62
void Ctutility::Delete() 
sl@0
    63
    {
sl@0
    64
sl@0
    65
    }
sl@0
    66
sl@0
    67
// -----------------------------------------------------------------------------
sl@0
    68
// Ctutility::RunMethodL
sl@0
    69
// Run specified method. Contains also table of test mothods and their names.
sl@0
    70
// -----------------------------------------------------------------------------
sl@0
    71
//
sl@0
    72
TInt Ctutility::RunMethodL( 
sl@0
    73
    CStifItemParser& aItem ) 
sl@0
    74
    {
sl@0
    75
sl@0
    76
    static TStifFunctionInfo const KFunctions[] =
sl@0
    77
        {  
sl@0
    78
        // Copy this line for every implemented function.
sl@0
    79
        // First string is the function name used in TestScripter script file.
sl@0
    80
        // Second is the actual implementation member function. 
sl@0
    81
        ENTRY( "Uninitialized_Copy", Ctutility::Uninitialized_Copy ),
sl@0
    82
        ENTRY( "Uninitialized_Copy_n", Ctutility::Uninitialized_Copy_n ),
sl@0
    83
        ENTRY( "Uninitialized_Fill", Ctutility::Uninitialized_Fill ),
sl@0
    84
        ENTRY( "Uninitialized_Fill_n", Ctutility::Uninitialized_Fill_n ),
sl@0
    85
        
sl@0
    86
        //ADD NEW ENTRY HERE
sl@0
    87
sl@0
    88
        };
sl@0
    89
sl@0
    90
    const TInt count = sizeof( KFunctions ) / 
sl@0
    91
                        sizeof( TStifFunctionInfo );
sl@0
    92
sl@0
    93
    return RunInternalL( KFunctions, count, aItem );
sl@0
    94
sl@0
    95
    }
sl@0
    96
sl@0
    97
// -----------------------------------------------------------------------------
sl@0
    98
// Ctutility::Uninitialized_Copy
sl@0
    99
// Uninitialized_Copy test method function.
sl@0
   100
// (other items were commented in a header).
sl@0
   101
// -----------------------------------------------------------------------------
sl@0
   102
//
sl@0
   103
sl@0
   104
TInt Ctutility::Uninitialized_Copy( CStifItemParser& aItem )
sl@0
   105
    {
sl@0
   106
sl@0
   107
	__UHEAP_MARK;
sl@0
   108
	 int Array1[] = { 10, 20, 30, 40 };
sl@0
   109
     const int N = sizeof( Array1 ) / sizeof( int );
sl@0
   110
sl@0
   111
     int i, testfail = 0;
sl@0
   112
sl@0
   113
     Integer* ArrayPtr = ( Integer* )::operator new( N * sizeof( int ) );
sl@0
   114
     Integer* LArrayPtr = uninitialized_copy(Array1, Array1 + N, ArrayPtr);  
sl@0
   115
	 
sl@0
   116
     if ( ( &Array1[0] + N ) == ( void* )LArrayPtr )
sl@0
   117
     {
sl@0
   118
      testfail++;
sl@0
   119
     }
sl@0
   120
     
sl@0
   121
     if ( ( void* )LArrayPtr != ( void* )( ArrayPtr + N ) )
sl@0
   122
     {
sl@0
   123
      testfail++;
sl@0
   124
     }
sl@0
   125
sl@0
   126
     delete ArrayPtr ;
sl@0
   127
     
sl@0
   128
     __UHEAP_MARKEND;
sl@0
   129
sl@0
   130
     if( testfail == 0)
sl@0
   131
       return KErrNone;
sl@0
   132
     else
sl@0
   133
       return KErrGeneral;  
sl@0
   134
sl@0
   135
    }
sl@0
   136
sl@0
   137
// -----------------------------------------------------------------------------
sl@0
   138
// Ctutility::Uninitialized_Copy_n
sl@0
   139
// Uninitialized_Copy_n test method function.
sl@0
   140
// (other items were commented in a header).
sl@0
   141
// -----------------------------------------------------------------------------
sl@0
   142
//
sl@0
   143
sl@0
   144
TInt Ctutility::Uninitialized_Copy_n( CStifItemParser& aItem )
sl@0
   145
    {
sl@0
   146
sl@0
   147
	__UHEAP_MARK;
sl@0
   148
	 int Array1[] = { 10, 20, 30, 40 };
sl@0
   149
     const int N = sizeof( Array1 ) / sizeof( int );
sl@0
   150
sl@0
   151
     int i;
sl@0
   152
sl@0
   153
     Integer* ArrayPtr = ( Integer* )::operator new( N * sizeof( int ) );
sl@0
   154
     std::pair<int*,Integer*> LArrayPtr = uninitialized_copy_n(Array1, N, ArrayPtr);  
sl@0
   155
	 
sl@0
   156
     delete ArrayPtr ;
sl@0
   157
     __UHEAP_MARKEND;
sl@0
   158
sl@0
   159
     return KErrNone;  
sl@0
   160
sl@0
   161
    }
sl@0
   162
sl@0
   163
sl@0
   164
// -----------------------------------------------------------------------------
sl@0
   165
// Ctutility::Uninitialized_Fill
sl@0
   166
// Uninitialized_Fill test method function.
sl@0
   167
// (other items were commented in a header).
sl@0
   168
// -----------------------------------------------------------------------------
sl@0
   169
//
sl@0
   170
sl@0
   171
TInt Ctutility::Uninitialized_Fill( CStifItemParser& aItem )
sl@0
   172
    {
sl@0
   173
sl@0
   174
	__UHEAP_MARK;
sl@0
   175
     int testfail = 0 , p = 0;
sl@0
   176
     const int N = 10;
sl@0
   177
     Integer val ( 25 );
sl@0
   178
     Integer* Array1 = ( Integer* )::operator new( N * sizeof( int ) );
sl@0
   179
     uninitialized_fill( Array1, Array1 + N, val );
sl@0
   180
sl@0
   181
     for ( int i = 0 ; i < N; i++ )
sl@0
   182
      {
sl@0
   183
         p = Array1[ i ].get( );    
sl@0
   184
         if(  p != 25 )
sl@0
   185
           testfail++; 
sl@0
   186
      }
sl@0
   187
 
sl@0
   188
     delete Array1 ;
sl@0
   189
     __UHEAP_MARKEND;
sl@0
   190
sl@0
   191
     if( testfail == 0)
sl@0
   192
       return KErrNone;
sl@0
   193
     else
sl@0
   194
       return KErrGeneral;  
sl@0
   195
    }
sl@0
   196
sl@0
   197
sl@0
   198
// -----------------------------------------------------------------------------
sl@0
   199
// Ctutility::Uninitialized_Fill_n
sl@0
   200
// Uninitialized_Fill_n test method function.
sl@0
   201
// (other items were commented in a header).
sl@0
   202
// -----------------------------------------------------------------------------
sl@0
   203
//
sl@0
   204
sl@0
   205
TInt Ctutility::Uninitialized_Fill_n( CStifItemParser& aItem )
sl@0
   206
    {
sl@0
   207
sl@0
   208
	__UHEAP_MARK;
sl@0
   209
     int testfail = 0 , p = 0;
sl@0
   210
     const int N = 10;
sl@0
   211
     Integer val ( 60 );
sl@0
   212
     Integer* Array1 = ( Integer* )::operator new( N * sizeof( int ) );
sl@0
   213
     uninitialized_fill_n( Array1, N, val );
sl@0
   214
sl@0
   215
     for ( int i = 0 ; i < N; i++ )
sl@0
   216
      {
sl@0
   217
         p = Array1[ i ].get( );    
sl@0
   218
         if(  p != 60 )
sl@0
   219
           testfail++; 
sl@0
   220
      }
sl@0
   221
 
sl@0
   222
     delete Array1 ;
sl@0
   223
     __UHEAP_MARKEND;
sl@0
   224
sl@0
   225
     if( testfail == 0)
sl@0
   226
       return KErrNone;
sl@0
   227
     else
sl@0
   228
       return KErrGeneral;  
sl@0
   229
    }
sl@0
   230
sl@0
   231
sl@0
   232
// ========================== OTHER EXPORTED FUNCTIONS =========================
sl@0
   233
// None
sl@0
   234
sl@0
   235
//  End of File