examples/SFExamples/Example_RArray/SharedCode.cpp

00001 /*
00002 Copyright (c) 2002-2011 Nokia Corporation and/or its subsidiary(-ies). All rights reserved.
00003 
00004 Redistribution and use in source and binary forms, with or without
00005 modification, are permitted provided that the following conditions are met:
00006 
00007 * Redistributions of source code must retain the above copyright notice, this
00008   list of conditions and the following disclaimer.
00009 * Redistributions in binary form must reproduce the above copyright notice,
00010   this list of conditions and the following disclaimer in the documentation
00011   and/or other materials provided with the distribution.
00012 * Neither the name of Nokia Corporation nor the names of its contributors
00013   may be used to endorse or promote products derived from this software
00014   without specific prior written permission.
00015 
00016 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00017 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00018 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00019 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
00020 FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00021 DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
00022 SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00023 CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00024 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00025 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00026 
00027 Description:  
00028 */ 
00029 #include "SharedCode.h"
00030 #include <Random.h>
00031 
00032 // ---------------------------------------------------------
00033 // TExampleStruct* GenerateValuesLC()
00034 // Generates a blob of randomized data
00035 // ---------------------------------------------------------
00036 //
00037 TExampleStruct* GenerateValuesLC()
00038         {
00039         const TInt maxLength = sizeof(TExampleStruct) * KMaxElements;
00040         TExampleStruct* structs = REINTERPRET_CAST(TExampleStruct*, User::AllocLC(maxLength));
00041         TPtr8 tmp(REINTERPRET_CAST(TUint8*, structs), maxLength, maxLength);
00042         TRandom::Random(tmp);
00043         return structs;
00044         }
00045 
00046 // ---------------------------------------------------------
00047 // void AddElementsL(const TExampleStruct* aValues, RExampleArray& aArray)
00048 // Adds the elements to the array without a leak
00049 // ---------------------------------------------------------
00050 //
00051 void AddElementsL(const TExampleStruct* aValues, RExampleArray& aArray)
00052         {       
00053         for (TInt i=0; i < KMaxElements; i++)
00054                 {
00055                 User::LeaveIfError(aArray.Append(aValues[i]));
00056                 }
00057         }
00058 
00059 // ---------------------------------------------------------
00060 // TBool TExampleStruct::IsEqual(const TExampleStruct& aLeft, const TExampleStruct& aRight)
00061 // Checks to see if the two arras are equal
00062 // ---------------------------------------------------------
00063 //
00064 TBool TExampleStruct::IsEqual(const TExampleStruct& aLeft, const TExampleStruct& aRight)
00065         {
00066         return aLeft.iA == aRight.iA && aLeft.iB == aRight.iB;
00067         }
00068 
00069 // ---------------------------------------------------------
00070 // TInt TExampleStruct::RelativeAOrdering(const TExampleStruct& aLeft, const TExampleStruct& aRight)
00071 // Compares the two elements
00072 // ---------------------------------------------------------
00073 //
00074 TInt TExampleStruct::RelativeAOrdering(const TExampleStruct& aLeft, const TExampleStruct& aRight)
00075         {
00076         if (aLeft.iA < aRight.iA)
00077                 return -1;
00078         
00079         if (aLeft.iA > aRight.iA)
00080                 return 1;
00081 
00082         return 0;
00083         }
00084 
00085 // ---------------------------------------------------------
00086 // TInt TExampleStruct::KeyCompare(const TInt* aKey, const TExampleStruct& aElement)
00087 // Compares the iA element of the structure against the supplied key
00088 // ---------------------------------------------------------
00089 //
00090 TInt TExampleStruct::KeyCompare(const TInt* aKey, const TExampleStruct& aElement)
00091         {
00092         if (*aKey < aElement.iA)
00093                 return -1;
00094         
00095         if (*aKey > aElement.iA)
00096                 return 1;
00097         
00098         return 0;
00099         }

Generated by  doxygen 1.6.2