--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/kerneltest/e32test/buffer/t_buf.cpp Mon Oct 19 15:55:17 2009 +0100
@@ -0,0 +1,1928 @@
+// Copyright (c) 1994-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of the License "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// e32test\buffer\t_buf.cpp
+// Overview:
+// Test methods of the TBuf16, TBuf8, TBuf template class.
+// API Information:
+// TBuf16, TBuf8, TBuf.
+// Details :
+// - Create some 16 bit modifiable descriptors, 8 bit modifiable descriptors
+// of fixed length, Build-independent modifiable descriptors, initialize
+// with different strings and check for
+// - Comparison operators,
+// - Property access methods,
+// - Fill & swap methods,
+// - Conversion methods,
+// - Comparison methods,
+// - Pattern Matching methods,
+// - Pattern Locating methods,
+// - Copying methods,
+// - Find, FindC, FindF methods,
+// - Repeat, Trim, TrimLeft, TrimRight, Insert, Delete, Left,
+// Right, Mid methods,
+// - Formatting methods,
+// - Replace methods are as expected.
+// - Construct some descriptors with buffer length, string and buffer reference and
+// verify that they are created successfully.
+// - Test assignment operators and comparison operators for different descriptors.
+// - Initialize some descriptors and check descriptors' maximum length, length and
+// size are as expected.
+// - Check Fill and Swap methods are as expected.
+// - Test Fold, Collate, LowerCase, UpperCase methods are as expected.
+// - Test Comparison methods are as expected.
+// - Test pattern matching for simple string, wild cards with collated comparison. Verify that the
+// return value is KErrNotFound when pattern doesn't match.
+// - Check Locating methods by searching character in forward and backward direction and
+// verify the return value is KErrNotFound when unavailable character is searched.
+// - Check copying strings and converting those into lower and upper case strings are
+// as expected.
+// - Check Find methods by searching string and verify the return value is KErrNotFound when
+// unavailable string is searched.
+// - Check Repeat, Trim, Insert and Delete methods are as expected.
+// - Check the formatting operations are as expected.
+// - Check integer to decimal character representation is as expected.
+// - Check integer to character representation with different number system is as expected.
+// - Check string formatting with variable parameter list is as expected
+// - Check Replace method by replacing string at different places in a string is as expected.
+// - Check the conversion of real numbers, extended precision real numbers into string
+// format is as expected.
+// - Check Format and FormatList methods are as expected.
+// - Check Format of TReal is as expected.
+// - Check the non-leaving and leaving descriptors overflow handlers are as expected.
+// Platforms/Drives/Compatibility:
+// All
+// Assumptions/Requirement/Pre-requisites:
+// Failures and causes:
+// Base Port information:
+//
+//
+
+#include <e32test.h>
+#include <e32math.h>
+#include <hal.h>
+#include <hal_data.h>
+#include <hal_data.h>
+#include <e32svr.h>
+
+#ifdef __VC32__
+ // Solve compilation problem caused by non-English locale
+ #pragma setlocale("english")
+#endif
+
+LOCAL_D RTest test(_L("T_BUF"));
+
+#pragma warning(disable: 4127) // disabling warning "conditional expression is constant"
+#pragma warning(disable: 4310) // disabling warning "cast truncates constant value"
+
+#undef _TL
+#define _TL(a) DESTEMPLATE((S*)RTest::String(sizeof(S),(TText8*)a,(TText16*)L ## a))
+#undef _TS
+#define _TS(a) ((const S*)RTest::String(sizeof(S),(TText8*)a,(TText16*)L ## a))
+
+template<class T,class S,class DESTEMPLATE>
+class TestTBuf
+ {
+public:
+ TestTBuf(TInt aLength); // Test class constructor.
+ void Test1(); // Tests all functions of the class.
+ void Test2(); // Tests all constructors.
+ void Test3(); // Tests all assignment operators
+ void Test4(); // Tests all comparison operators
+ void Test5(); // Tests all property access
+ void Test6(); // Tests all fill and swap
+ void Test7(); // Tests all conversion
+ void Test8(); // Tests all comparison
+ void Test9(); // Tests all matching
+ void Test10(); // Tests all locating
+ void Test11(); // Tests all Copying
+ void Test12(); // Tests all finding
+ void Test13(); // Tests all basic like ops
+ void Test14(); // Tests all formating
+ void Test15(); // Tests all replacing
+ void test_TBuf(); // Test all classes
+protected:
+ void Test1List(T* a,T* b,...);
+ void Test14_ReorderedParameterFormatting(TInt aDummyParameter, ...);
+private:
+ TInt iMaxBufLength;
+ };
+
+void TestEq(const TDesC8& a, const TDesC8& b, TInt aLine)
+ {
+ if (a!=b)
+ {
+ TBuf<256> buf;
+ test.Printf(_L("LINE %d:\n"),aLine);
+ buf.Copy(a);
+ test.Printf(_L("a=%S\n"),&buf);
+ buf.Copy(b);
+ test.Printf(_L("b=%S\n"),&buf);
+ test(0);
+ }
+ }
+
+void TestEq(const TDesC16& a, const TDesC16& b, TInt aLine)
+ {
+ if (a!=b)
+ {
+ test.Printf(_L("LINE %d:\n"),aLine);
+ test.Printf(_L("a=%S\n"),&a);
+ test.Printf(_L("b=%S\n"),&b);
+ test(0);
+ }
+ }
+
+#define TESTEQ(a,b) TestEq((a),(b),__LINE__)
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C TestTBuf<T,S,DESTEMPLATE>::TestTBuf(TInt aLength)
+// Constructor.
+ : iMaxBufLength(aLength)
+ {}
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test1List(T* a,T* b,...)
+// Test the format with list functions.
+ {
+ VA_LIST list;
+ VA_START(list,b);
+ a->Format(*b,list);
+ VA_START(list,b);
+ a->AppendFormat(*b,list);
+ VA_START(list,b);
+ a->Format(_TL("%d"),list);
+ VA_START(list,b);
+ a->AppendFormat(_TL("%d"),list);
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test1()
+// Tests all functions of the class.
+ {
+ test.Start(_L("Constructors"));
+ T a;
+ T b;
+ T c(_TL("AB"));
+ T d(c);
+
+// To avoid unused warning
+ a.Length();
+ b.Length();
+ c.Length();
+ d.Length();
+
+ test.Next(_L("Copy operators"));
+ a=_TL("DE");
+ b=c;
+ a+=_TL("DE");
+ b+=c;
+
+ test.Next(_L("Comparison operators"));
+ TInt t=(a<b);
+ t=(a<_TL("AB"));
+ t=(_TL("AB")<a);
+ t=(a<=b);
+ t=(a<=_TL("AB"));
+ t=(_TL("AB")<=a);
+ t=(a>b);
+ t=(a>_TL("AB"));
+ t=(_TL("AB")>a);
+ t=(a>=b);
+ t=(a>=_TL("AB"));
+ t=(_TL("AB")>=a);
+ t=(a==b);
+ t=(a==_TL("AB"));
+ t=(_TL("AB")==a);
+ t=(a!=_TL("AB"));
+ t=(_TL("AB")!=a);
+
+ test.Next(_L("Property access"));
+ a[0]='A';
+ a.Ptr();
+ TInt i=a.MaxLength()-a.Length();
+ i=a.Size();
+ a.Zero();
+ a.SetLength(2);
+
+ test.Next(_L("Fill & swap"));
+ a.Fill(' ');
+ a.Fill(' ',iMaxBufLength);
+ a.FillZ();
+ a.FillZ(iMaxBufLength);
+ a.Swap(b);
+
+ test.Next(_L("Conversion"));
+ a.Fold();
+ a.Collate();
+ a.LowerCase();
+ a.UpperCase();
+ a.Capitalize();
+
+ test.Next(_L("Comparison"));
+ a.Compare(b);
+ a.Compare(_TL("AB"));
+ a.CompareF(b);
+ a.CompareF(_TL("AB"));
+ a.CompareC(b);
+ a.CompareC(_TL("AB"));
+
+ test.Next(_L("Matching"));
+ a.Match(b);
+ a.Match(_TL("AB"));
+ a.MatchF(b);
+ a.MatchF(_TL("AB"));
+
+ T buf(_TL("abcdef"));
+ TInt res = buf.MatchF(_TL("abc*def"));
+ test(res == 0);
+
+ a.MatchC(b);
+ a.MatchC(_TL("AB"));
+
+ test.Next(_L("Locating"));
+ a.Locate('A');
+ a.LocateF('A');
+ a.LocateReverse('A');
+ a.LocateReverseF('A');
+
+ test.Next(_L("Copying"));
+ a.Copy(b);
+ a.Copy(_TL("AB"));
+// a.Copy(_TL("AB"),1);
+ a.CopyF(b);
+ a.CopyF(_TL("AB"));
+ a.CopyC(b);
+ a.CopyC(_TL("AB"));
+ a.CopyLC(b);
+ a.CopyLC(_TL("AB"));
+ a.CopyUC(b);
+ a.CopyUC(_TL("AB"));
+ a.CopyCP(b);
+ a.CopyCP(_TL("AB"));
+
+ test.Next(_L("Finding"));
+ a.Find(b);
+ a.Find(_TL("AB"));
+ a.FindF(b);
+ a.FindF(_TL("AB"));
+ a.FindC(b);
+ a.FindC(_TL("AB"));
+
+ test.Next(_L("Basic like ops"));
+ a.Repeat(b);
+ a.Repeat(_TL("AB"));
+ a.TrimLeft();
+ a.TrimRight();
+ a.Trim();
+ b=_TL("AA");
+ a.Insert(0,b);
+ a.Delete(0,2);
+ b = a.Left(1);
+ b = a.Right(1);
+ b = a.Mid(0,1);
+
+ test.Next(_L("Formating"));
+ a.Justify(_TL("AB"),10,ELeft,' ');
+ a.Justify(b,10,ELeft,' ');
+ b.Fill('A',2);
+ a.Zero();
+ a.AppendJustify(_TL("AB"),10,ELeft,' ');
+ a.AppendJustify(b,10,ELeft,' ');
+ TInt v1=10;
+ a.Num(v1);
+ a.AppendNum(v1);
+ TInt v2=10;
+ a.Num((TUint)v2,EHex);
+ a.AppendNum((TUint)v2,EHex);
+ a.NumUC((TUint)v2,EHex);
+ a.AppendNumUC((TUint)v2,EHex);
+ TReal v3=10.0;
+ TRealFormat ff;
+ ff.iType=KRealFormatFixed;
+ ff.iWidth=10;
+ ff.iPlaces=2;
+ ff.iPoint='.';
+ ff.iTriad=',';
+ ff.iTriLen=3;
+ a.Num(v3,ff);
+ a.AppendNum(v3,ff);
+ a.Format(_TL("%d"),12);
+ a.AppendFormat(_TL("%d"),12);
+ b=_TL("%d");
+ a.Format(b,12);
+ a.AppendFormat(b,12);
+ Test1List(&a,&b,12);
+
+ test.Next(_L("Replacing"));
+ a=_TL("AAC");
+ b=_TL("B");
+ a.Replace(1,1,b);
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test2()
+// Tests all constructors.
+ {
+ test.Start(_L("Default"));
+ T a;
+ test(a.MaxLength()==iMaxBufLength);
+ test(a.Length()==0);
+
+ test.Next(_L("By length"));
+ T b(iMaxBufLength>>1);
+ test(b.MaxLength()==iMaxBufLength);
+ test(b.Length()==(iMaxBufLength>>1));
+
+ test.Next(_L("By string"));
+ T c(_TL("AB"));
+ test(c.MaxLength()==iMaxBufLength);
+ test(c.Length()==2);
+ test(c[0]=='A');
+ test(c[1]=='B');
+
+ test.Next(_L("By buffer reference"));
+ T d(c);
+ test(d.MaxLength()==iMaxBufLength);
+ test(d.Length()==2);
+ test(d[0]=='A');
+ test(d[1]=='B');
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test3()
+// Tests all assignment operators
+ {
+ test.Start(_L("By String"));
+ T a;
+ a=_TL("AB");
+ a+=_TL("CD");
+ test(a.Length()==4);
+ test(a==_TL("ABCD"));
+
+ test.Next(_L("By buffer"));
+ T b;
+ b=a;
+ b+=a;
+ test(b.Length()==8);
+ test(b==_TL("ABCDABCD"));
+//
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test4()
+// Test all comparison operators
+ {
+ test.Start(_L("By NULL string"));
+ T a;
+ test(a==_TL("")); // NULL strings
+ test(!(a!=_TL("")));
+ test(a<=_TL(""));
+ test(a>=_TL(""));
+ test(!(a<_TL("")));
+ test(!(a>_TL("")));
+ test(_TL("")==a);
+ test(!(_TL("")!=a));
+ test(_TL("")<=a);
+ test(_TL("")>=a);
+ test(!(_TL("")<a));
+ test(!(_TL("")>a));
+
+ test.Next(_L("By string or buffer"));
+ a=_TL("abc");
+ test(a==_TL("abc")); // ==
+ test(!(a==_TL("xyz")));
+ test(!(a==_TL("aa")));
+ test(_TL("abc")==a);
+ test(!(_TL("xyz")==a));
+ test(!(_TL("aa")==a));
+ test(a!=_TL("xyz")); // !=
+ test(!(a!=_TL("abc")));
+ test(a!=_TL("aa"));
+ test(_TL("xyz")!=a);
+ test(!(_TL("abc")!=a));
+ test(_TL("aa")!=a);
+ test(a<_TL("x")); // <
+ test(!(a<_TL("abc")));
+ test(!(a<_TL("aa")));
+ test(_TL("aa")<a);
+ test(!(_TL("abc")<a));
+ test(!(_TL("xyz")<a));
+ test(a>_TL("aa")); // >
+ test(!(a>_TL("abc")));
+ test(!(a>_TL("xyz")));
+ test(_TL("xyz")>a);
+ test(!(_TL("abc")>a));
+ test(!(_TL("aa")>a));
+ test(a>=_TL("abc")); // >=
+ test(!(a>=_TL("xyz")));
+ test(a>=_TL("aa"));
+ test(_TL("abc")>=a);
+ test(!(_TL("aaa")>=a));
+ test(_TL("xyz")>=a);
+ test(a<=_TL("abc")); // <=
+ test(!(a<=_TL("aa")));
+ test(a<=_TL("xyz"));
+ test(_TL("abc")<=a);
+ test(!(_TL("xyz")<=a));
+ test(_TL("aa")<=a);
+
+ test.Next(_L("By special characters"));
+ a=_TL("!@#$%^&*()");
+ test(a==_TL("!@#$%^&*()"));
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test5()
+// Test all property access
+ {
+ test.Start(_L("Length and Size"));
+ T a;
+ TInt maxLength=a.MaxLength();
+ TInt i;
+ for (i=0;i<maxLength;i++)
+ {
+ test(a.Length()==i); // Length
+ test(a.Size()==(TInt)(sizeof(S)*i)); // Size
+ a.AppendNum(i%10);
+ }
+ const T b=a;
+ for (i=0;i<maxLength;i++)
+ {
+ test(a[i]=='0'+(i%10)); // At
+ test(b[i]=='0'+(i%10)); // AtConst
+ }
+ test(a[0]==*a.Ptr()); //Ptr
+ a.SetLength(0); // SetLength
+ test(a.Length()==0);
+ a.SetLength(maxLength-1);
+ test(a.Length()==maxLength-1);
+ a.Zero(); // Null
+ test(a.Length()==0);
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test6()
+// Fill and Swap
+ {
+ test.Start(_L("Fill and Swap"));
+ T a,b;
+ TChar chr;
+ TInt j;
+ TInt maxLength=a.MaxLength();
+ for (TInt i=0;i<maxLength;i++)
+ {
+ chr=(i%10)+'0';
+ a.SetLength(i);
+ a.Fill(chr); // Fill(TChar)
+ b.Swap(a);
+ test(b.Length()==i); // Swap
+ j=0;
+ while (j<i)
+ test(b[j++]=='0'+(i%10));
+ b.FillZ(); // FillZ()
+ a.Swap(b);
+ j=0;
+ while (j<i)
+ test(a[j++]==0);
+ a.Fill(chr,i); // Fill(TChar,TUint)
+ j=0;
+ while (j<i)
+ test(a[j++]=='0'+(i%10));
+ a.FillZ(i); // FillZ(TUint)
+ j=0;
+ while (j<i)
+ test(a[j++]==0);
+ }
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test7()
+// Conversion operators
+ {
+ test.Start(_L("Fold, collate ..."));
+ T a;
+ T b;
+ a=_TL("abc AbC");
+ b=_TL("ABC ABC");
+ a.Fold();
+ b.Fold();
+ test(a==b);
+ a=_TL("abc AbC");
+ b=_TL("ABC ABC");
+ a.Collate();
+ b.Collate();
+ test(a==b);
+ a.LowerCase();
+ test(a==_TL("abc abc"));
+ a.Capitalize();
+ test(a==_TL("Abc abc"));
+ a.UpperCase();
+ test(a==_TL("ABC ABC"));
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test8()
+// Comparison
+ {
+ test.Start(_L("By string"));
+ T a;
+ a=_TL("abc AbC");
+ test(a.Compare(_TL("abc AbC"))==0);
+ test(a.CompareF(_TL("ABC aBc"))==0);
+ test(a.Compare(_TL("xyz"))!=0);
+ test(a.CompareC(_TL("xyz"))!=0);
+ test(a.CompareF(_TL("xyz"))!=0);
+
+ test.Next(_L("By buffer"));
+ T b;
+ T c;
+ a=_TL("abc AbC");
+ b=_TL("abc AbC");
+ c=_TL("xyz");
+ test(a.Compare(b)==0);
+ test(a.Compare(c)!=0);
+ b=_TL("ABC aBc");
+ test(a.CompareC(c)!=0);
+ test(a.CompareF(b)==0);
+ test(a.CompareF(c)!=0);
+
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test9()
+// Matching (need to test explicit result as error KErrNotFound = KMaxTUint
+// and so registers as TRUE. (test parameter is TUint) )
+ {
+ test.Start(_L("By string"));
+ T a;
+ a=_TL("abc AbC");
+ test(a.Match(_TL("abc AbC"))==0);
+ test(a.MatchC(_TL("ABC aBc"))==0);
+ test(a.MatchF(_TL("ABC aBc"))==0);
+ test(a.Match(_TL("xyz"))==KErrNotFound);
+ test(a.MatchC(_TL("xyz"))==KErrNotFound);
+ test(a.MatchF(_TL("xyz"))==KErrNotFound);
+
+ test.Next(_L("By buffer"));
+ T b;
+ T c;
+ a=_TL("abc AbC");
+ b=_TL("abc AbC");
+ c=_TL("xyz");
+ test(a.Match(b)==0);
+ test(a.Match(c)==KErrNotFound);
+ b=_TL("ABC aBc");
+ test(a.MatchC(b)==0);
+ test(a.MatchC(c)==KErrNotFound);
+ test(a.MatchF(b)==0);
+ test(a.MatchF(c)==KErrNotFound);
+
+ test.Next(_L("Wildcards"));
+ a=_TL("abcxyz");
+ test(a.Match(_TL("abc*"))==0);
+ test(a.Match(_TL("abw*"))==KErrNotFound);
+ a=_TL("abcdefg");
+ test(a.Match(_TL("a*fg"))==0);
+ test(a.Match(_TL("a*f"))==KErrNotFound);
+ test(a.Match(_TL("abc*fgh"))==KErrNotFound);
+ a=_TL("abcdef");
+ test(a.Match(_TL("abc?ef"))==0);
+ test(a.Match(_TL("abc?xf"))==KErrNotFound);
+
+ a=_TL("a(01)");
+ test(a.Match(_TL("*(01)"))==1);
+ test(a.Match(_TL("?(01)"))==0);
+ test(a.Match(_TL("?(*)"))==0);
+ test(a.Match(_TL("?(**)"))==0);
+
+ test(a.Match(_TL("?(\?\?)"))==0);
+ test(a.Match(_TL("*(*)"))>=0);
+ test(a.Match(_TL("*(0?)"))>=0);
+ test(a.Match(_TL("a(\?\?)"))==0);
+ test(a.Match(_TL("*(\?\?)"))>=0);
+
+ test.Next(_L("wild cards with collated comparison"));
+ a = _TL("abcdefghijkl");
+ test(a.MatchC(_TL("abc*")) == 0);
+ test(a.MatchC(_TL("abc")) == KErrNotFound);
+ test(a.MatchC(_TL("xyz")) == KErrNotFound);
+ test(a.MatchC(_TL("*def")) == KErrNotFound);
+ test(a.MatchC(_TL("*def*")) == 3);
+ test(a.MatchC(_TL("*d?f*")) == 3);
+ test(a.MatchC(_TL("a*kl")) == 0);
+ test(a.MatchC(_TL("*e*?l")) == 4);
+ test(a.MatchC(_TL("abc*dEf*")) == 0);
+
+
+ T candidate;
+ T search;
+
+ candidate = _TL("");
+ search = _TL("**");
+ test(candidate.MatchC(search) == 0);
+
+ candidate = _TL("");
+ search = _TL("*");
+ test(candidate.MatchC(search) == 0);
+
+ candidate = _TL("abcd");
+ search = _TL("*abc*cd");
+ test(candidate.MatchC(search) == KErrNotFound);
+
+ if (sizeof(S) == 2)
+ {
+ test.Next(_L("Unicode MatchC and FindC treat base+accent as equal to composed character"));
+ TPtrC p = _L("te\x302te");
+ test(p.MatchC(_L("t\xeate")) == 0);
+ test(p.FindC(_L("t\xeate")) == 0);
+ }
+
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test10()
+// Locating
+ {
+ T a;
+ TChar b;
+
+ test.Start(_L("First Char"));
+ b='a';
+ a=_TL("axaxa");
+ test(a.Locate(b)==0);
+ test(a.LocateF(b)==0);
+ test(a.LocateReverse(b)==4);
+ test(a.LocateReverseF(b)==4);
+
+ test.Next(_L("Middle Char"));
+ a=_TL("xaxa");
+ test(a.Locate(b)==1);
+ test(a.LocateF(b)==1);
+ a=_TL("axax");
+ test(a.LocateReverse(b)==2);
+ test(a.LocateReverseF(b)==2);
+
+ test.Next(_L("Last Char"));
+ a=_TL("xxa");
+ test(a.Locate(b)==2);
+ test(a.LocateF(b)==2);
+ a=_TL("axx");
+ test(a.LocateReverse(b)==0);
+ test(a.LocateReverseF(b)==0);
+
+ test.Next(_L("Test for failure of locate"));
+ a=_TL("xxx");
+ test(a.Locate(b)==KErrNotFound);
+ test(a.LocateF(b)==KErrNotFound);
+ test(a.LocateReverse(b)==KErrNotFound);
+ test(a.LocateReverseF(b)==KErrNotFound);
+
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test11()
+// Copying
+ {
+ T a, b;
+
+ test.Start(_L("By String"));
+ a.Copy(_TL("abc"));
+ test(a.Length()==3);
+ test(a==_TL("abc"));
+ a.CopyF(_TL("abc"));
+ test(a.Length()==3);
+ b.CopyF(_TL("ABC"));
+ test(a==b);
+ a.CopyLC(_TL("AbC"));
+ test(a==_TL("abc"));
+ test(a.Length()==3);
+ a.CopyC(_TL("abc"));
+ b.CopyC(_TL("ABC"));
+ test(a==b);
+ test(a.Length()==3);
+ a.CopyCP(_TL("abc"));
+ test(a==_TL("Abc"));
+ test(a.Length()==3);
+ a.CopyUC(_TL("aBc"));
+ test(a==_TL("ABC"));
+ test(a.Length()==3);
+// a.Copy(_TL("abc"),3);
+// test(a==_TL("abc"));
+// test(a.Length()==3);
+// a.Copy(_TL("abcd"),3);
+// test(a==_TL("abc"));
+// test(a.Length()==3);
+
+ test.Next(_L("By buffer"));
+ b=_TL("abc");
+ a.Copy(b);
+ test(a==_TL("abc"));
+ test(a.Length()==3);
+ a=_TL("");
+ a.CopyF(b);
+ b.CopyF(_TL("ABC"));
+ test(a==b);
+ test(a.Length()==3);
+ a=_TL("");
+ b=_TL("AbC");
+ a.CopyLC(b);
+ test(a==_TL("abc"));
+ test(a.Length()==3);
+ a=_TL("");
+ b=_TL("abC");
+ a.CopyC(b);
+ b.CopyC(_TL("ABC"));
+ test(a==b);
+ test(a.Length()==3);
+ a=_TL("");
+ b=_TL("abC");
+ a.CopyCP(b);
+ test(a==_TL("Abc"));
+ test(a.Length()==3);
+ a=_TL("");
+ b=_TL("aBc");
+ a.CopyUC(b);
+ test(a.Length()==3);
+ test(a==_TL("ABC"));
+
+ test.End();
+ }
+
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test12()
+// Finding
+ {
+ test.Start(_L("By String"));
+ T a,b;
+ a=_TL("abccef");
+ test(a.Find(_TL(""))==0);
+ test(a.Find(_TL("abc"))==0);
+ test(a.Find(_TL("cce"))==2);
+ test(a.Find(_TL("cef"))==3);
+ test(a.Find(_TL("efg"))==KErrNotFound);
+ test(a.Find(_TL("xxx"))==KErrNotFound);
+ test(a.FindF(_TL(""))==0);
+ test(a.FindF(_TL("AbC"))==0);
+ test(a.FindF(_TL("CcE"))==2);
+ test(a.FindF(_TL("CeF"))==3);
+ test(a.FindF(_TL("efg"))==KErrNotFound);
+ test(a.FindF(_TL("xxx"))==KErrNotFound);
+ test(a.FindC(_TL(""))==0);
+ test(a.FindC(_TL("aBc"))==0);
+ test(a.FindC(_TL("cce"))==2);
+ test(a.FindC(_TL("cEf"))==3);
+ test(a.FindC(_TL("efg"))==KErrNotFound);
+ test(a.FindC(_TL("xxx"))==KErrNotFound);
+
+ test.Next(_L("By buffer"));
+ test(a.Find(b)==0);
+ test(a.FindF(b)==0);
+ test(a.FindC(b)==0);
+ b=_TL("xxx");
+ test(a.Find(b)==KErrNotFound);
+ test(a.FindF(b)==KErrNotFound);
+ test(a.FindC(b)==KErrNotFound);
+ b=_TL("efg");
+ test(a.Find(b)==KErrNotFound);
+ test(a.FindF(b)==KErrNotFound);
+ test(a.FindC(b)==KErrNotFound);
+ b=_TL("abc");
+ test(a.Find(b)==0);
+ b=_TL("cce");
+ test(a.Find(b)==2);
+ b=_TL("cef");
+ test(a.Find(b)==3);
+ b=_TL("AbC");
+ test(a.FindF(b)==0);
+ b=_TL("CcE");
+ test(a.FindF(b)==2);
+ b=_TL("CeF");
+ test(a.FindF(b)==3);
+ b=_TL("aBc");
+ test(a.FindC(b)==0);
+ b=_TL("cCe");
+ test(a.FindC(b)==2);
+ b=_TL("cEf");
+ test(a.FindC(b)==3);
+
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test13()
+// Basic like ops
+ {
+ test.Start(_L("Repeat, trim, insert and delete"));
+ T a,b;
+ TInt max=a.MaxLength();
+ b=_TL("abc");
+ a.Repeat(_TL("abc"));
+ test(a==_TL(""));
+ a.Repeat(b);
+ test(a==_TL(""));
+ for (TInt j=1;j<max;j++) // ?? Cannot SetLength = MaxLength
+ {
+ a.SetLength(j);
+ a.Repeat(_TL("abc"));
+ TInt i;
+ for (i=0;i<j;i++)
+ test(a[i]==b[i%3]);
+ a=_TL("");
+ a.SetLength(j);
+ a.Repeat(b);
+ for (i=0;i<j;i++)
+ test(a[i]==b[i%3]);
+ a=_TL("");
+ }
+ a=_TL("\t\n ab \t\n ");
+ a.TrimLeft();
+ test(a==_TL("ab \t\n "));
+ test(a.Length()==6);
+ a=_TL("\t\n ab \t\n ");
+ a.TrimRight();
+ test(a==_TL("\t\n ab"));
+ test(a.Length()==6);
+ a=_TL(" \t\n ab \t \n");
+ a.Trim();
+ test(a==_TL("ab"));
+ a.Trim();
+ test(a==_TL("ab"));
+ a=_TL("abc");
+ b=_TL("123");
+ a.Insert(1,b);
+ test(a==_TL("a123bc"));
+ test(a.Length()==6);
+ b=_TL("");
+ a.Insert(4,b);
+ test(a==_TL("a123bc"));
+ test(a.Length()==6);
+ a.Insert(0,b);
+ test(a==_TL("a123bc"));
+ test(a.Length()==6);
+ a.Delete(1,3);
+ test(a==_TL("abc"));
+ test(a.Length()==3);
+ a.Delete(0,3);
+ test(a==_TL(""));
+ test(a.Length()==0);
+
+ test.Next(_L("TrimAll"));
+ a=_TL("");
+ a.TrimAll();
+ test(a==_TL(""));
+ a=_TL(" ");
+ a.TrimAll();
+ test(a==_TL(""));
+ a=_TL(" ");
+ a.TrimAll();
+ test(a==_TL(""));
+ a=_TL(" ab cd ef g");
+ a.TrimAll();
+ test(a==_TL("ab cd ef g"));
+ a=_TL("abcdef");
+ a.TrimAll();
+ test(a==_TL("abcdef"));
+ a=_TL("a b\t cd\t\tef");
+ a.TrimAll();
+ test(a==_TL("a b\tcd\tef"));
+ a=_TL("abcdef \t ghijk");
+ a.TrimAll();
+ test(a==_TL("abcdef ghijk"));
+ a=_TL("abcdef g");
+ a.TrimAll();
+ test(a==_TL("abcdef g"));
+ a=_TL("ab cd ef gh ij");
+ a.TrimAll();
+ test(a==_TL("ab cd ef gh ij"));
+ a=_TL("a b c defg h i jk l mno pqr stu vw xyz");
+ a.TrimAll();
+ test(a==_TL("a b c defg h i jk l mno pqr stu vw xyz"));
+
+ test.Next(_L("Right, Left and Mid"));
+ a=_TL("abcdef");
+ b = a.Left(3);
+ test(b==_TL("abc"));
+ test(b.Length()==3);
+ b = a.Right(3);
+ test(b==_TL("def"));
+ b = a.Mid(2);
+ test(b==_TL("cdef"));
+ test(b.Length()==4);
+ b = a.Left(2);
+ test(b==_TL("ab"));
+ test(b.Length()==2);
+ b = a.Right(2);
+ test(b==_TL("ef"));
+ b = a.Mid(2,1);
+ test(b==_TL("c"));
+ test(b.Length()==1);
+ b = a.Left(6);
+ test(b==_TL("abcdef"));
+ test(b.Length()==6);
+ b=_TL("");
+ b.SetLength(4);
+ b = a.Right(6);
+ test(b==_TL("abcdef"));
+ test(b.Length()==6);
+ a = a.Left(6);
+ test(a==_TL("abcdef"));
+ b=_TL("");
+ b = a.Mid(0,6);
+ test(b==_TL("abcdef"));
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test14()
+// Formating operations
+ {
+ test.Start(_L("Justify"));
+ T a,b,d;
+ TInt aWidth;
+ TChar c;
+ a=_TL("wxyz");
+ b=_TL("abc");
+ d=_TL("linearisation");
+ const S* pD=_TS("299792458");
+ c='x';
+ aWidth=KDefaultJustifyWidth; // Left justified, Default width
+ a.Justify(b,aWidth,ELeft,c);
+ test(a==b);
+ test(a.Length()==3);
+ a.AppendJustify(b,aWidth,ELeft,c);
+ test(a==_TL("abcabc"));
+ test(a.Length()==6);
+ aWidth=1; // Width < String length
+ a.Justify(b,aWidth,ELeft,c);
+ test(a==_TL("a"));
+ test(a.Length()==1);
+ a.AppendJustify(b,aWidth,ELeft,c);
+ test(a==_TL("aa"));
+ test(a.Length()==2);
+ aWidth=5; // Width > String length
+ a.Justify(b,aWidth,ELeft,c);
+ test(a==_TL("abcxx"));
+ test(a.Length()==5);
+ a.AppendJustify(b,aWidth,ELeft,c);
+ test(a==_TL("abcxxabcxx"));
+ test(a.Length()==10);
+
+ aWidth=KDefaultJustifyWidth; // Right justified, Default width
+ a.Justify(b,aWidth,ERight,c);
+ test(a==b);
+ test(a.Length()==3);
+ a.AppendJustify(b,aWidth,ERight,c);
+ test(a==_TL("abcabc"));
+ test(a.Length()==6);
+ aWidth=1; // Right justified, Width < String length
+ a.Justify(b,aWidth,ERight,c);
+ test(a==_TL("a"));
+ test(a.Length()==1);
+ a.AppendJustify(b,aWidth,ERight,c);
+ test(a==_TL("aa"));
+ test(a.Length()==2);
+ aWidth=5; // Right justified, width > String length
+ a.Justify(b,aWidth,ERight,c);
+ test(a==_TL("xxabc"));
+ test(a.Length()==5);
+ a.AppendJustify(b,aWidth,ERight,c);
+ test(a==_TL("xxabcxxabc"));
+ test(a.Length()==10);
+
+ aWidth=KDefaultJustifyWidth; // Center justified, Default width
+ a.Justify(b,aWidth,ECenter,c);
+ test(a==b);
+ test(a.Length()==3);
+ a.AppendJustify(b,aWidth,ECenter,c);
+ test(a==_TL("abcabc"));
+ test(a.Length()==6);
+ aWidth=1; // Centre justified, width < String length
+ a.Justify(b,aWidth,ECenter,c);
+ test(a==_TL("a"));
+ test(a.Length()==1);
+ a.AppendJustify(b,aWidth,ECenter,c);
+ test(a==_TL("aa"));
+ test(a.Length()==2);
+ aWidth=5; // Centre justified, width > String length
+ a.Justify(b,aWidth,ECenter,c);
+ test(a==_TL("xabcx"));
+ test(a.Length()==5);
+ a.AppendJustify(b,aWidth,ECenter,c);
+ test(a==_TL("xabcxxabcx"));
+ test(a.Length()==10);
+
+ test.Next(_L("Num"));
+ TInt j=-2147483647-1;
+ a.Num(j);
+ test(a==_TL("-2147483648"));
+ test(a.Length()==11);
+ TUint i=2147483648u;
+ a.Num(i);
+ test(a==_TL("2147483648"));
+ test(a.Length()==10);
+ if (a.MaxLength()>31)
+ {
+ a.Num(i,EBinary);
+ test(a==_TL("10000000000000000000000000000000"));
+ test(a.Length()==32);
+ a=_TL("");
+ a.NumUC(i,EBinary);
+ test(a==_TL("10000000000000000000000000000000"));
+ test(a.Length()==32);
+ }
+ i=31;
+ a.Num(i,EBinary);
+ test(a==_TL("11111"));
+ test(a.Length()==5);
+ a=_TL("");
+ a.NumUC(i,EBinary);
+ test(a==_TL("11111"));
+ test(a.Length()==5);
+ i=2147483648u;
+ a.Num(i,EOctal);
+ test(a==_TL("20000000000"));
+ test(a.Length()==11);
+ a=_TL("");
+ a.NumUC(i,EOctal);
+ test(a==_TL("20000000000"));
+ test(a.Length()==11);
+ a.Num(i,EDecimal);
+ test(a==_TL("2147483648"));
+ test(a.Length()==10);
+ a=_TL("");
+ a.NumUC(i,EDecimal);
+ test(a==_TL("2147483648"));
+ test(a.Length()==10);
+ a.Num(i,EHex);
+ test(a==_TL("80000000"));
+ test(a.Length()==8);
+ a=_TL("");
+ a.NumUC(i,EHex);
+ test(a==_TL("80000000"));
+ test(a.Length()==8);
+ i=0;
+ a.Num(i);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+ a=_TL("abc");
+ a.Num(i,EBinary);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+ a=_TL("abc");
+ a.NumUC(i,EBinary);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+ a=_TL("abc");
+ a.Num(i,EOctal);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+ a=_TL("");
+ a.NumUC(i,EOctal);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+ a=_TL("abc");
+ a.Num(i,EDecimal);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+ a=_TL("");
+ a.NumUC(i,EDecimal);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+ a=_TL("abc");
+ a.Num(i,EHex);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+ a=_TL("");
+ a.NumUC(i,EHex);
+ test(a==_TL("0"));
+ test(a.Length()==1);
+// TInt i=a.Num(6.2,format); NOT IMPLEMENTED
+ a.AppendNum(j);
+ test(a==_TL("0-2147483648"));
+ test(a.Length()==12);
+ a=_TL("abc");
+ i=4294967295u;
+ a.AppendNum(i);
+ test(a==_TL("abc4294967295"));
+ test(a.Length()==13);
+ j=2147483647;
+ a=_TL("abc");
+ a.AppendNum(j);
+ test(a==_TL("abc2147483647"));
+ test(a.Length()==13);
+ a=_TL("a");
+ i=180150000;
+ if (a.MaxLength()>28)
+ {
+ a.AppendNum(i,EBinary);
+ test(a==_TL("a1010101111001101111011110000"));
+ test(a.Length()==29);
+ }
+ a=_TL("a");
+ a.AppendNum(15,EBinary);
+ test(a==_TL("a1111"));
+ test(a.Length()==5);
+ a=_TL("a");
+ a.AppendNum(i,EDecimal);
+ test(a==_TL("a180150000"));
+ test(a.Length()==10);
+ a=_TL("a");
+ a.AppendNum(i,EOctal);
+ test(a==_TL("a1257157360"));
+ test(a.Length()==11);
+ a=_TL("a");
+ a.AppendNumUC(i,EHex);
+ test(a==_TL("aABCDEF0"));
+ test(a.Length()==8);
+// i=a.AppendNum(6.32, format); NOT IMPLEMENTED
+
+ test.Next(_L("Format"));
+ a=_TL("");
+ b=_TL("cde");
+ a.Format(_TL("%S"),&b);
+ test(a==b);
+ test(a.Length()==3);
+ DESTEMPLATE xyz=_TL("xyzwpq");
+ a.Format(_TL("%S"),&xyz);
+ test(a==_TL("xyzwpq"));
+ test(a.Length()==6);
+ DESTEMPLATE cde=_TL("cde");
+ a.Format(_TL("ab %-x5S"),&cde);
+ test(a==_TL("ab cdexx"));
+ test(a.Length()==8);
+ a.Format(_TL("ab %=x5S"),&cde);
+ test(a==_TL("ab xcdex"));
+ test(a.Length()==8);
+ a.Format(_TL("ab %+x5S"),&cde);
+ test(a==_TL("ab xxcde"));
+ test(a.Length()==8);
+ a.Format(_TL("ab %5S"),&cde);
+ test(a==_TL("ab cde"));
+ test(a.Length()==8);
+ a.Format(_TL("ab %-**S"),'x',5,&cde);
+ test(a==_TL("ab cdexx"));
+ test(a.Length()==8);
+ a.Format(_TL("ab %*S"),5,&cde);
+ test(a==_TL("ab cde"));
+ test(a.Length()==8);
+ a=_TL("xyz");
+ a.Format(_TL("ab %-x5S"),&b);
+ test(a==_TL("ab cdexx"));
+ test(a.Length()==8);
+ a=_TL("xyz");
+ a.Format(_TL("ab %-**S"),'x',5,&b);
+ test(a==_TL("ab cdexx"));
+ test(a.Length()==8);
+ a=_TL("xyz");
+ a.Format(_TL("ab %*S"),5,&b);
+ test(a==_TL("ab cde"));
+ test(a.Length()==8);
+
+ DESTEMPLATE fred=_TL("fred");
+ a.Format(_TL("%+0*S"),10,&fred);
+ test(a==_TL("000000fred"));
+ test(a.Length()==10);
+ a.Format(_TL("%-0*S"),7,&fred);
+ test(a==_TL("fred000"));
+ test(a.Length()==7);
+ a.Format(_TL("%0*S"),11,&fred);
+ test(a==_TL("0000000fred"));
+ test(a.Length()==11);
+ a.Format(_TL("c=%s"),pD);
+ TESTEQ(a,_TL("c=299792458"));
+ a.Format(_TL("c=%10.6s"),pD);
+ test(a==_TL("c= 299792"));
+ a.Format(_TL("c=%*.*s"),5,4,pD);
+ test(a==_TL("c= 2997"));
+ a.Format(_TL("%S"),&d);
+ test(a==_TL("linearisation"));
+ a.Format(_TL("%10.6S"),&d);
+ test(a==_TL(" linear"));
+ a.Format(_TL("%*.*S"),5,4,&d);
+ test(a==_TL(" line"));
+ a.Format(_TL("%*.*Sed"),10,8,&d);
+ test(a==_TL(" linearised"));
+ a.Format(_TL("%*.*S"),14,20,&d);
+ test(a==_TL(" linearisation"));
+
+ a.Format(_TL("ab %-,5b"),7);
+ test(a==_TL("ab 111,,"));
+ test(a.Length()==8);
+ a.Format(_TL("ab %=,5O"),31);
+ test(a==_TL("ab ,37,,"));
+ test(a.Length()==8);
+ a.Format(_TL("ab %+xlx"),TInt64(171));
+ test(a==_TL("ab ab"));
+ test(a.Length()==5);
+ a.Format(_TL("ab %+xlX %+xlx"),TInt64(171),TInt64(171));
+ TESTEQ(a,_TL("ab AB ab"));
+ test(a.Length()==8);
+ a.Format(_TL("ab %lu"),MAKE_TINT64((TUint)(KMinTInt),0));
+ test(a==_TL("ab 9223372036854775808"));
+ test(a.Length()==22);
+ a.Format(_TL("ab %ld"),MAKE_TINT64((TUint)(KMinTInt),1));
+ test(a==_TL("ab -9223372036854775807"));
+ test(a.Length()==23);
+ a.Format(_TL("ab %ld"),MAKE_TINT64((TUint)(KMinTInt),0));
+ test(a==_TL("ab -9223372036854775808"));
+ test(a.Length()==23);
+ a.Format(_TL("ab %ld"),MAKE_TINT64((TUint)(KMaxTInt),KMaxTUint));
+ test(a==_TL("ab 9223372036854775807"));
+ test(a.Length()==22);
+ a.Format(_TL("ab %ld"),MAKE_TINT64(KMaxTUint,KMaxTUint));
+ test(a==_TL("ab -1"));
+ test(a.Length()==5);
+ a.Format(_TL("ab %lu"),MAKE_TINT64(KMaxTUint,KMaxTUint));
+ test(a==_TL("ab 18446744073709551615"));
+ test(a.Length()==23);
+ a.Format(_TL("ab %ld"),TInt64(0));
+ test(a==_TL("ab 0"));
+ test(a.Length()==4);
+ a.Format(_TL("ab %lb"),TInt64(0));
+ test(a==_TL("ab 0"));
+ test(a.Length()==4);
+ a.Format(_TL("ab %lx"),TInt64(0));
+ test(a==_TL("ab 0"));
+ test(a.Length()==4);
+ a.Format(_TL("ab %lo"),TInt64(0));
+ test(a==_TL("ab 0"));
+ test(a.Length()==4);
+ a.Format(_TL("ab %lu"),TInt64(0));
+ test(a==_TL("ab 0"));
+ test(a.Length()==4);
+ a.Format(_TL("ab %lb"),MAKE_TINT64((TUint)(KMaxTInt),KMaxTUint));
+ test(a==_TL("ab 111111111111111111111111111111111111111111111111111111111111111"));
+ test(a.Length()==66);
+ a.Format(_TL("ab %lb"),MAKE_TINT64(KMaxTUint,KMaxTUint));
+ test(a==_TL("ab 1111111111111111111111111111111111111111111111111111111111111111"));
+ test(a.Length()==67);
+ a.Format(_TL("ab %lx"),MAKE_TINT64((TUint)(KMaxTInt),KMaxTUint));
+ test(a==_TL("ab 7fffffffffffffff"));
+ test(a.Length()==19);
+ a.Format(_TL("ab %lx"),MAKE_TINT64(KMaxTUint,KMaxTUint));
+ test(a==_TL("ab ffffffffffffffff"));
+ test(a.Length()==19);
+ a.Format(_TL("ab %lo"),MAKE_TINT64((TUint)(KMaxTInt),KMaxTUint));
+ test(a==_TL("ab 777777777777777777777"));
+ test(a.Length()==24);
+ // tests which excercise any 8 byte alignment requirement on 64bit integers
+ a.Format(_TL("%li%S"),MAKE_TINT64(1,2),&fred);
+ test(a==_TL("4294967298fred"));
+ a.Format(_TL("%S%li%S"),&fred,MAKE_TINT64(1,2),&fred);
+ test(a==_TL("fred4294967298fred"));
+ a.Format(_TL("%lu%S"),MAKE_TINT64(1,2),&fred);
+ test(a==_TL("4294967298fred"));
+ a.Format(_TL("%S%lu%S"),&fred,MAKE_TINT64(1,2),&fred);
+ test(a==_TL("fred4294967298fred"));
+
+ a.Format(_TL("ab %U"),233);
+ test(a==_TL("ab 233"));
+ test(a.Length()==6);
+ a.Format(_TL("ab %*d"),5,-131);
+ test(a==_TL("ab -131"));
+ test(a.Length()==8);
+ a.Format(_TL("ab%c"),'x');
+ test(a==_TL("abx"));
+ test(a.Length()==3);
+ a.Format(_TL("%W"),-131);
+ test(*(TInt32*)a.Ptr()==-131);
+ a.Format(_TL("%M"),-131);
+ test(*(TInt32*)a.Ptr()==2113929215);
+ a.Format(_TL("%w"),-131);
+ test(*(TInt16*)a.Ptr()==-131);
+ a.Format(_TL("%m"),-131);
+ test(*(TInt16*)a.Ptr()==32255);
+ a=_TL("xyz");
+ a.AppendFormat(_TL("ab %+xlx"),TInt64(171));
+ test(a==_TL("xyzab ab"));
+ test(a.Length()==8);
+ a=_TL("xyz");
+ a.AppendFormat(_TL("ab %5S"),&b);
+ test(a==_TL("xyzab cde"));
+ test(a.Length()==11);
+ a=_TL("xyz");
+ a.AppendFormat(_TL("%W"),-131);
+// test(*(TInt32*)(a.Ptr()+3)==-131); // Alignment-safe version:
+ TInt val;
+ Mem::Copy(&val,&a[3],4);
+ test(val==-131);
+ a=_TL("xyz");
+// a.Append(_TL("abc"),3);
+// test(a==_TL("xyzabc"));
+
+ a.Format(_TL(""));
+ test(a==_TL(""));
+ a.Format(_TL(""),9,5);
+ test(a==_TL(""));
+ a.Format(_TL("qwerty"));
+ test(a==_TL("qwerty"));
+ a.Format(_TL("qwerty"),9,5);
+ test(a==_TL("qwerty"));
+ a.Format(_TL("%$1$d%$2$d"),9,5);
+ test(a==_TL("95"));
+ test(a.Length()==2);
+ a.Format(_TL("%$2$d%$1$d"),9,5);
+ test(a==_TL("59"));
+ test(a.Length()==2);
+ b=_TL("eb");
+ a.Format(_TL("%$1$S%$2$d"),&b,205);
+ test(a==_TL("eb205"));
+ test(a.Length()==5);
+ a.Format(_TL("%$2$d%$1$S"),&b,205);
+ test(a==_TL("205eb"));
+ test(a.Length()==5);
+ b=_TL("ebdb");
+
+// Cannot do this on GCC (X86) because of "Cannot pass objects of non-POD type through '...'. Call will abort at runtime".
+#if !(defined(__GCC32__) && defined(__X86__))
+ const TAny* const zeroTerminatedString=(sizeof(S)==2)? (const TAny*)_S16(":-)E"): (const TAny*)_S8(":-)E");
+ const TInt dummyParameter=0;
+ Test14_ReorderedParameterFormatting(dummyParameter, 0x20ac, 11, 3, 13.89543, zeroTerminatedString, '!', TInt64(199), 2, &b, 6, 30005, TRealX(0.125), 0x8bdd);
+#endif
+
+ test.Next(_L("Print some numbers"));
+ TInt64 TI64 = MAKE_TINT64(0x101010u,0x10101010u);
+ test.Printf(_L(" %%ld: %ld\n"),TI64);
+ test.Printf(_L(" %%lu: %lu\n"),TI64);
+ test.Printf(_L(" %%lx: %lx\n"),TI64);
+ test.Printf(_L(" %%lb: %lb\n"),TI64);
+ test.Printf(_L(" %%lo: %lo\n\n"),TI64);
+ TI64 = UI64LIT(0xabcdef12345678);
+ test.Printf(_L(" %%ld: %ld\n"),TI64);
+ test.Printf(_L(" %%lu: %lu\n"),TI64);
+ test.Printf(_L(" %%lx: %lx\n"),TI64);
+ test.Printf(_L(" %%lb: %lb\n"),TI64);
+ test.Printf(_L(" %%lo: %lo\n\n"),TI64);
+ TI64 = UI64LIT(0x7fffffffffffffff);
+ test.Printf(_L(" %%ld: %ld\n"),TI64);
+ test.Printf(_L(" %%lu: %lu\n"),TI64);
+ test.Printf(_L(" %%lx: %lx\n"),TI64);
+ test.Printf(_L(" %%lb: %lb\n"),TI64);
+ test.Printf(_L(" %%lo: %lo\n\n"),TI64);
+ TI64 = UI64LIT(0x8000000000000000);
+ test.Printf(_L(" %%ld: %ld\n"),TI64);
+ test.Printf(_L(" %%lu: %lu\n"),TI64);
+ test.Printf(_L(" %%lx: %lx\n"),TI64);
+ test.Printf(_L(" %%lb: %lb\n"),TI64);
+ test.Printf(_L(" %%lo: %lo\n\n"),TI64);
+ TI64 = UI64LIT(0xffffffffffffffff);
+ test.Printf(_L(" %%ld: %ld\n"),TI64);
+ test.Printf(_L(" %%lu: %lu\n"),TI64);
+ test.Printf(_L(" %%lx: %lx\n"),TI64);
+ test.Printf(_L(" %%lb: %lb\n"),TI64);
+ test.Printf(_L(" %%lo: %lo\n\n"),TI64);
+
+ test.Next(_L("Regression tests"));
+ a.Format(_TL("[%-A4p]"));
+ test(a==_TL("[AAAA]"));
+
+ test.End();
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test14_ReorderedParameterFormatting(TInt aDummyParameter, ...)
+ {
+ VA_LIST parameterList;
+ T generated;
+ T expected;
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%-**.*fqq%.3swww%+*5Ldeeee%.*Srrrrr%0*xtttttt%.3Fyyyyyyy%c"), parameterList);
+ test(generated.Length()==61);
+ expected.Format(_TL("\t13.895%c%c%c%c%cqq:-)www!!199eeeeebrrrrr007535tttttt0.125yyyyyyy"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Left(generated.Length()-1)==expected);
+ test(generated[generated.Length()-1]==(S)0x8bdd);
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%$1$-**.*fqq%.3swww%+*5Ldeeee%.*Srrrrr%0*xtttttt%$6$.3Fyyyyyyy%c"), parameterList);
+ test(generated.Length()==61);
+ expected.Format(_TL("\t13.895%c%c%c%c%cqq:-)www!!199eeeeebrrrrr007535tttttt0.125yyyyyyy"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Left(generated.Length()-1)==expected);
+ test(generated[generated.Length()-1]==(S)0x8bdd);
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%$6$.3Fqq%.3swww%+*5Ldeeee%.*Srrrrr%0*xtttttt%$1$-**.*fyyyyyyy%c"), parameterList);
+ test(generated.Length()==61);
+ expected.Format(_TL("\t0.125qq:-)www!!199eeeeebrrrrr007535tttttt13.895%c%c%c%c%cyyyyyyy"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Left(generated.Length()-1)==expected);
+ test(generated[generated.Length()-1]==(S)0x8bdd);
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%-**.*fqq%.3swww%$5$0*xeeee%.*Srrrrr%$3$+*5Ldtttttt%.3Fyyyyyyy%c"), parameterList);
+ test(generated.Length()==61);
+ expected.Format(_TL("\t13.895%c%c%c%c%cqq:-)www007535eeeeebrrrrr!!199tttttt0.125yyyyyyy"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Left(generated.Length()-1)==expected);
+ test(generated[generated.Length()-1]==(S)0x8bdd);
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%-**.*fqq%$4$.*Swww%+*5Ldeeee%$2$.3srrrrr%0*xtttttt%.3Fyyyyyyy%c"), parameterList);
+ test(generated.Length()==61);
+ expected.Format(_TL("\t13.895%c%c%c%c%cqqebwww!!199eeee:-)rrrrr007535tttttt0.125yyyyyyy"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Left(generated.Length()-1)==expected);
+ test(generated[generated.Length()-1]==(S)0x8bdd);
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%-**.*fqq%.3swww%+*5Ldeeee%$7$crrrrr%0*xtttttt%.3Fyyyyyyy%$4$.*S"), parameterList);
+ test(generated.Length()==61);
+ expected.Format(_TL("\t13.895%c%c%c%c%cqq:-)www!!199eeee"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Left(29)==expected);
+ test(generated[29]==(S)0x8bdd);
+ test(generated.Mid(29+1)==_TL("rrrrr007535tttttt0.125yyyyyyyeb"));
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%$4$.*Sqq%.3swww%+*5Ldeeee%$6$.3Frrrrr%0*xtttttt%$1$-**.*fyyyyyyy%c"), parameterList);
+ test(generated.Length()==61);
+ expected.Format(_TL("\tebqq:-)www!!199eeee0.125rrrrr007535tttttt13.895%c%c%c%c%cyyyyyyy"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Left(generated.Length()-1)==expected);
+ test(generated[generated.Length()-1]==(S)0x8bdd);
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%$7$cqq%$6$.3Fwww%$5$0*xeeee%.*Srrrrr%$3$+*5Ldtttttt%$2$.3syyyyyyy%$1$-**.*f"), parameterList);
+ test(generated.Length()==61);
+ test(generated.Left(1)==_TL("\t"));
+ test(generated[1]==(S)0x8bdd);
+ expected.Format(_TL("qq0.125www007535eeeeebrrrrr!!199tttttt:-)yyyyyyy13.895%c%c%c%c%c"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Mid(2)==expected);
+
+ VA_START(parameterList, aDummyParameter);
+ generated.FormatList(_TL("\t%$7$cqq%$6$.3Fwww%$5$0*xeeee%$4$.*Srrrrr%$3$+*5Ldtttttt%$2$.3syyyyyyy%$1$-**.*f"), parameterList);
+ test(generated.Length()==61);
+ test(generated.Left(1)==_TL("\t"));
+ test(generated[1]==(S)0x8bdd);
+ expected.Format(_TL("qq0.125www007535eeeeebrrrrr!!199tttttt:-)yyyyyyy13.895%c%c%c%c%c"), (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac, (S)0x20ac);
+ test(generated.Mid(2)==expected);
+ }
+
+template <class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::Test15()
+// Replacing
+ {
+ test.Start(_L("Replace"));
+ T a,b;
+ test(a.MaxLength()>=9);
+ a=_TL("abccccc");
+ b=_TL("def");
+ a.Replace(3,4,b); // Replace with smaller in middle (insert and delete)
+ test(a==_TL("abcdef"));
+ a.Replace(1,1,b); // Replace with larger in middle (insert and delete)
+ test(a==_TL("adefcdef"));
+ a.Replace(0,8,_TL("")); // Replace complete string (delete)
+ test(a==_TL(""));
+ a.Replace(0,0,b); // Replace at beginning (insert)
+ test(a==b);
+ a.Replace(3,0,_TL("xyz")); // Replace at end (append)
+ test(a==_TL("defxyz"));
+ a.Replace(0,0,_TL("")); // Replace nothing at beginning (do nothing)
+ test(a==_TL("defxyz"));
+ a.Replace(6,0,_TL("")); // Replace nothing at end (do nothing)
+ test(a==_TL("defxyz"));
+ //a.Replace(6,1,_TL("")); // this will panic - no char after end to replace
+ //a.Replace(0,7,_TL("")); // this will panic - aint 7 chars to replace
+ test.End();
+ }
+
+template<class T,class S,class DESTEMPLATE>
+GLDEF_C void TestTBuf<T,S,DESTEMPLATE>::test_TBuf()
+// Test the TBuf class.
+ {
+ test.Start(_L("All operations"));
+ Test1();
+ test.Next(_L("Constructors"));
+ Test2();
+ test.Next(_L("Additional tests"));
+ Test3();
+ test.Next(_L("Comparison operators"));
+ Test4();
+ test.Next(_L("Property access"));
+ Test5();
+ test.Next(_L("Fill and swap"));
+ Test6();
+ test.Next(_L("Conversion operators"));
+ Test7();
+ test.Next(_L("Comparison"));
+ Test8();
+ test.Next(_L("Matching"));
+ Test9();
+ test.Next(_L("Locating"));
+ Test10();
+ test.Next(_L("Copying"));
+ Test11();
+ test.Next(_L("Finding"));
+ Test12();
+ test.Next(_L("Basic like ops"));
+ Test13();
+ test.Next(_L("Formating"));
+ Test14();
+ test.Next(_L("Replacing"));
+ Test15();
+ test.End();
+ }
+
+LOCAL_C void testFormat()
+ {
+ TBuf<0x100> aa;
+ aa.Format(_L("x%- 5fx"), 6.2345678);
+ test(aa==_L("x6.234568x"));
+ aa.Format(_L("x%+ 5fx"), 6.2345678);
+ test(aa==_L("x6.234568x"));
+ aa.Format(_L("x% 5fx"), 6.2345678);
+ test(aa==_L("x6.234568x"));
+ aa.Format(_L("x%= 5fx"), 6.2345678);
+ test(aa==_L("x6.234568x"));
+ aa.Format(_L("x%- 10fx"), 6.2345);
+ test(aa==_L("x6.234500 x"));
+ aa.Format(_L("x%+ 10fx"), 6.2345);
+ test(aa==_L("x 6.234500x"));
+ aa.Format(_L("x% 10fx"), 6.2345);
+ test(aa==_L("x 6.234500x"));
+ aa.Format(_L("x%= 10fx"), 6.2345);
+ test(aa==_L("x 6.234500 x"));
+ aa.Format(_L("x%10fx"), 12345352342.545);
+ test(aa==_L("x12,345,352,342.545000x"));
+ aa.Format(_L("x%20.9fx"), 1.0123456789);
+ test(aa==_L("x 1.012345679x"));
+ aa.Format(_L("x%5.1fx"), 1.99);
+ test(aa==_L("x 2.0x"));
+
+// Cannot do these on GCC (X86) because of "Cannot pass objects of non-POD type through '...'. Call will abort at runtime".
+#if !(defined(__GCC32__) && defined(__X86__))
+ aa.Format(_L("x%- 5Fx"), TRealX(6.2345678));
+ test(aa==_L("x6.234568x"));
+ aa.Format(_L("x%+ 5Fx"), TRealX(6.2345678));
+ test(aa==_L("x6.234568x"));
+ aa.Format(_L("x% 5Fx"), TRealX(6.2345678));
+ test(aa==_L("x6.234568x"));
+ aa.Format(_L("x%= 5Fx"), TRealX(6.2345678));
+ test(aa==_L("x6.234568x"));
+ aa.Format(_L("x%- 10Fx"), TRealX(6.2345));
+ test(aa==_L("x6.234500 x"));
+ aa.Format(_L("x%+ 10Fx"), TRealX(6.2345));
+ test(aa==_L("x 6.234500x"));
+ aa.Format(_L("x% 10Fx"), TRealX(6.2345));
+ test(aa==_L("x 6.234500x"));
+ aa.Format(_L("x%+010Fx"), TRealX(6.2345));
+ test(aa==_L("x006.234500x"));
+ aa.Format(_L("x%+10Fx"), TRealX(6.2345));
+ test(aa==_L("x 6.234500x"));
+ aa.Format(_L("x%10Fx"), TRealX(6.2345));
+ test(aa==_L("x 6.234500x"));
+ aa.Format(_L("x%010Fx"), TRealX(6.2345));
+ test(aa==_L("x006.234500x"));
+ aa.Format(_L("x%= 10Fx"), TRealX(6.2345));
+ test(aa==_L("x 6.234500 x"));
+ aa.Format(_L("x%10Fx"), TRealX(12345352342.545));
+ test(aa==_L("x12,345,352,342.545000x"));
+ aa.Format(_L("x%20.9Fx"), TRealX(1.0123456789));
+ test(aa==_L("x 1.012345679x"));
+ aa.Format(_L("x%5.1Fx"), TRealX(1.99));
+ test(aa==_L("x 2.0x"));
+#endif
+
+ aa.Format(_L("x%- 5ex"), 6.2345678);
+ test(aa==_L("x6.234568E+00x"));
+ aa.Format(_L("x%+ 5ex"), 6.2345678);
+ test(aa==_L("x6.234568E+00x"));
+ aa.Format(_L("x% 5ex"), 6.2345678);
+ test(aa==_L("x6.234568E+00x"));
+ aa.Format(_L("x%= 5ex"), 6.2345678);
+ test(aa==_L("x6.234568E+00x"));
+ aa.Format(_L("x%- 14ex"), 6.2345);
+ test(aa==_L("x6.234500E+00 x"));
+ aa.Format(_L("x%+ 14ex"), 6.2345);
+ test(aa==_L("x 6.234500E+00x"));
+ aa.Format(_L("x% 14ex"), 6.2345);
+ test(aa==_L("x 6.234500E+00x"));
+ aa.Format(_L("x%= 14ex"), 6.2345);
+ test(aa==_L("x 6.234500E+00 x"));
+ aa.Format(_L("x%10ex"), 12345352342.545);
+ test(aa==_L("x1.234535E+10x"));
+ aa.Format(_L("x%20.9ex"), 1.0123456789);
+ test(aa==_L("x 1.012345679E+00x"));
+ aa.Format(_L("x%5.1ex"), 1.99);
+ test(aa==_L("x2.0E+00x"));
+ }
+
+
+class TO8 : public TDes8Overflow
+ {
+public:
+ virtual void Overflow(TDes8 &aDes);
+ };
+
+void TO8::Overflow(TDes8 &aDes)
+ {
+ aDes=_L8("OVERFLOW");
+ }
+
+class TO8L : public TDes8Overflow
+ {
+public:
+ virtual void Overflow(TDes8 &aDes);
+ };
+
+void TO8L::Overflow(TDes8 &/*aDes*/)
+ {
+ User::Leave(KErrOverflow);
+ }
+
+class TO16 : public TDes16Overflow
+ {
+public:
+ virtual void Overflow(TDes16 &aDes);
+ };
+
+void TO16::Overflow(TDes16 &aDes)
+ {
+ aDes=_L16("OVERFLOW");
+ }
+
+class TO16L : public TDes16Overflow
+ {
+public:
+ virtual void Overflow(TDes16 &aDes);
+ };
+
+void TO16L::Overflow(TDes16 &/*aDes*/)
+ {
+ User::Leave(KErrOverflow);
+ }
+
+void append8(TDes8 &aBuf, TDes8Overflow *aHandler, TRefByValue<const TDesC8> aFmt, ...)
+ {
+ VA_LIST list;
+ VA_START(list, aFmt);
+ aBuf.AppendFormatList(aFmt, list, aHandler);
+ }
+
+void append16(TDes16 &aBuf, TDes16Overflow *aHandler, TRefByValue<const TDesC16> aFmt, ...)
+ {
+ VA_LIST list;
+ VA_START(list, aFmt);
+ aBuf.AppendFormatList(aFmt, list, aHandler);
+ }
+
+void testOverflow()
+ {
+ test.Start(_L("Test no overflow"));
+ TBuf8<16> buf=_L8("A ");
+ append8(buf, NULL, _L8("Descriptor"));
+ test(buf==_L8("A Descriptor"));
+
+ test.Printf(_L("Use a non-leaving overflow handler\n"));
+ test.Next(_L("Force overflow with no conversions"));
+ TO8 overflow;
+ append8(buf, &overflow, _L8("12345678901234567"));
+ test(buf==_L8("OVERFLOW"));
+
+ test.Next(_L("Force overflow with decimal conversion"));
+ buf=_L8("A Descriptor");
+ append8(buf, &overflow, _L8("%d"), 12345678);
+ test(buf==_L8("OVERFLOW"));
+
+ test.Printf(_L("Use a leaving overflow handler\n"));
+ test.Next(_L("AppendFormatList with no overflow"));
+ buf=_L8("A Descriptor");
+ TO8L overflowLeave;
+ TRAPD(r, append8(buf, &overflowLeave, _L8("ONE")));
+ test(r==KErrNone);
+ test(buf==_L8("A DescriptorONE"));
+ test.Next(_L("Force overflow with hexadecimal conversion"));
+ buf=_L8("A Descriptor");
+ TRAP(r, append8(buf, &overflowLeave, _L8("%08x"), 0));
+ test(r==KErrOverflow);
+ {
+ test.Printf(_L("Repeat tests with TBuf16\n"));
+ test.Next(_L("Test no overflow"));
+ TBuf16<16> buf=_L16("A ");
+ append16(buf, NULL, _L16("Descriptor"));
+ test(buf==_L16("A Descriptor"));
+
+ test.Printf(_L("Use a non-leaving overflow handler\n"));
+ test.Next(_L("Force overflow with no conversions"));
+ TO16 overflow;
+ append16(buf, &overflow, _L16("12345678901234567"));
+ test(buf==_L16("OVERFLOW"));
+
+ test.Next(_L("Force overflow with decimal conversion"));
+ buf=_L16("A Descriptor");
+ append16(buf, &overflow, _L16("%d"), 12345678);
+ test(buf==_L16("OVERFLOW"));
+
+ test.Printf(_L("Use a leaving overflow handler\n"));
+ test.Next(_L("AppendFormatList with no overflow"));
+ buf=_L16("A Descriptor");
+ TO16L overflowLeave;
+ TRAPD(r, append16(buf, &overflowLeave, _L16("ONE")));
+ test(r==KErrNone);
+ test(buf==_L16("A DescriptorONE"));
+ test.Next(_L("Force overflow with hexadecimal conversion"));
+ buf=_L16("A Descriptor");
+ TRAP(r, append16(buf, &overflowLeave, _L16("%08x"), 0));
+ test(r==KErrOverflow);
+ }
+ test.End();
+ }
+
+void testIgnoreOverflow()
+ {
+ test.Start(_L("Test no overflow"));
+ TBuf8<16> buf=_L8("A ");
+ append8(buf, NULL, _L8("Descriptor"));
+ test(buf==_L8("A Descriptor"));
+
+ test.Printf(_L("Use a non-leaving overflow handler\n"));
+ test.Next(_L("Force overflow with no conversions"));
+ TDes8IgnoreOverflow overflow;
+ append8(buf, &overflow, _L8("12345678901234567"));
+ test(buf==_L8("A Descriptor1234"));
+
+ test.Next(_L("Force overflow with decimal conversion"));
+ buf=_L8("A Descriptor");
+ append8(buf, &overflow, _L8("%d"), 123456789);
+ test(buf==_L8("A Descriptor"));
+
+ //test.Printf(_L("Repeat tests with TBuf16\n"));
+ test.Next(_L("Test no overflow"));
+ TBuf16<17> buf2=_L16("A ");
+ append16(buf2, NULL, _L16("Descriptor"));
+ test(buf2==_L16("A Descriptor"));
+
+ test.Printf(_L("Use a non-leaving overflow handler\n"));
+ test.Next(_L("Force overflow with no conversions"));
+ TDes16IgnoreOverflow overflow2;
+ append16(buf2, &overflow2, _L16("12345678901234567"));
+ test(buf2==_L16("A Descriptor12345"));
+
+ test.Next(_L("Force overflow with decimal conversion"));
+ buf2=_L16("A Descriptor");
+ append16(buf2, &overflow2, _L16("%d"), 123456789);
+ test(buf2==_L16("A Descriptor"));
+
+ test.End();
+ }
+
+void testAppendFormatIgnoreOverflow()
+ {
+ test.Start(_L("Test no overflow"));
+ TBuf8<16> buf;
+ buf.AppendFormat(_L8("A Descriptor"));
+ test(buf==_L8("A Descriptor"));
+
+ test.Next(_L("Force overflow with no conversions"));
+ TDes8IgnoreOverflow overflow;
+ buf.AppendFormat(_L8("123456789012345679"),&overflow);
+ test(buf==_L8("A Descriptor1234"));
+
+ test.Next(_L("Force overflow with decimal conversion"));
+ buf = _L8("Symbian OS");
+ buf.AppendFormat(_L8("%d"), &overflow, 1234567);
+ test(buf==_L8("Symbian OS"));
+
+ test.Next(_L("Test no overflow"));
+ TBuf16<16> buf2;
+ buf2.AppendFormat(_L16("A Descriptor"));
+ test(buf2==_L16("A Descriptor"));
+
+ test.Next(_L("Force overflow with no conversions"));
+ TDes16IgnoreOverflow overflow2;
+ buf2.AppendFormat(_L16("123456789012345679"),&overflow2);
+ test(buf2==_L16("A Descriptor1234"));
+
+ test.Next(_L("Force overflow with decimal conversion"));
+ buf2 = _L16("Symbian OS");
+ buf2.AppendFormat(_L16("%d"), &overflow2, 1234567);
+ test(buf2==_L16("Symbian OS"));
+
+ test.End();
+
+
+ }
+
+// INC061330 AV28Crit: NTT - TInt TDesC16.FindC -method is giving strange output values
+// This test should pass with "ELangPrcChinese" locale.
+void INC061330()
+ {
+ TLanguage defaultLang = User::Language();
+
+ TInt err = HAL::Set(HAL::ELanguageIndex, ELangPrcChinese);
+ test(err == KErrNone);
+
+ TBuf<50> libraryName;
+
+ libraryName.Format(_L("ELOCL.%02d"), ELangPrcChinese);
+
+ //Reset the locale
+ err=UserSvr::ChangeLocale(KNullDesC);
+ test(err==KErrNone);
+
+ //Now change to chinese locale
+ err = UserSvr::ChangeLocale(libraryName);
+ if(err==KErrNotFound)
+ {
+ test.Printf(_L("TEST CASE NOT RUN BECAUSE ELangPrcChinese LOCALE NOT FOUND!\n"));
+ HAL::Set(HAL::ELanguageIndex, defaultLang);
+ return;
+ }
+ test(err == KErrNone);
+
+ TLanguage lang = User::Language();
+ test(lang == ELangPrcChinese);
+
+ TInt pos;
+ _LIT(KBuf, "hello");
+
+ pos = KBuf().FindC(_L("a"));
+ test(pos == KErrNotFound);
+
+ pos = KBuf().FindC(_L("zzz"));
+ test(pos == KErrNotFound);
+
+ pos = KBuf().FindC(_L("."));
+ test(pos == KErrNotFound);
+
+ pos = KBuf().FindC(_L(":"));
+ test(pos == KErrNotFound);
+
+ pos = KBuf().FindC(_L("hela"));
+ test(pos == KErrNotFound);
+
+ //Reset the locale
+ err=UserSvr::ChangeLocale(KNullDesC);
+ test(err==KErrNone);
+
+ //Now revert to the original default english locale
+ libraryName.Format(_L("ELOCL.%02d"), defaultLang);
+ test(err == KErrNone);
+ err = UserSvr::ChangeLocale(libraryName);
+ test(err == KErrNone);
+
+ lang = User::Language();
+ test(lang == defaultLang);
+ }
+#ifndef _DEBUG
+#pragma warning( disable : 4702) //Unreachable code
+#pragma warning( disable : 4710) //Function not expanded
+#endif
+GLDEF_C TInt E32Main()
+// Test the TBuf type.
+ {
+ test.Title();
+
+ test.Start(_L("class TBuf16<0x50>"));
+ TestTBuf<TBuf16<0x50>,TText16,TPtrC16> c(0x50);
+ c.test_TBuf();
+
+ test.Next(_L("class TBuf8<0x50>"));
+ TestTBuf<TBuf8<0x50>,TText8,TPtrC8> b(0x50);
+ b.test_TBuf();
+
+ test.Next(_L("class TBuf<0x50>"));
+ TestTBuf<TBuf<0x50>,TText,TPtrC> a(0x50);
+ a.test_TBuf();
+
+ test.Next(_L("TReal formating"));
+ testFormat();
+
+ test.Next(_L("Test overflow handler"));
+ testOverflow();
+
+ test.Next(_L("Test ignore overflow handler"));
+ testIgnoreOverflow();
+
+ test.Next(_L("Test Format ignore overflow handler"));
+ testAppendFormatIgnoreOverflow();
+
+ test.Next(_L("INC061330"));
+ INC061330();
+
+ test.End();
+
+ return(KErrNone);
+ }
+
+//#pragma warning( default : 4702)
+//#pragma warning( default : 4710)
+
+