1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski 
25*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
26*b1cdbd2cSJim Jagielski #include "precompiled_sal.hxx"
27*b1cdbd2cSJim Jagielski // This is a test of helperfunctions
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski #include <osl/time.h>
30*b1cdbd2cSJim Jagielski #include <osl/thread.hxx>
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski #include "stringhelper.hxx"
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski #include <testshl/simpleheader.hxx>
35*b1cdbd2cSJim Jagielski 
36*b1cdbd2cSJim Jagielski // void isJaBloed()
37*b1cdbd2cSJim Jagielski // {
38*b1cdbd2cSJim Jagielski //     t_print("Ist ja echt bloed.\n");
39*b1cdbd2cSJim Jagielski // }
40*b1cdbd2cSJim Jagielski 
t_abs64(sal_Int64 _nValue)41*b1cdbd2cSJim Jagielski inline sal_Int64 t_abs64(sal_Int64 _nValue)
42*b1cdbd2cSJim Jagielski {
43*b1cdbd2cSJim Jagielski     // std::abs() seems to have some ambiguity problems (so-texas)
44*b1cdbd2cSJim Jagielski     // return abs(_nValue);
45*b1cdbd2cSJim Jagielski     t_print("t_abs64(%ld)\n", _nValue);
46*b1cdbd2cSJim Jagielski     // CPPUNIT_ASSERT(_nValue < 2147483647);
47*b1cdbd2cSJim Jagielski 
48*b1cdbd2cSJim Jagielski     if (_nValue < 0)
49*b1cdbd2cSJim Jagielski     {
50*b1cdbd2cSJim Jagielski         _nValue = -_nValue;
51*b1cdbd2cSJim Jagielski     }
52*b1cdbd2cSJim Jagielski     return _nValue;
53*b1cdbd2cSJim Jagielski }
54*b1cdbd2cSJim Jagielski 
t_print64(sal_Int64 n)55*b1cdbd2cSJim Jagielski void t_print64(sal_Int64 n)
56*b1cdbd2cSJim Jagielski {
57*b1cdbd2cSJim Jagielski     if (n < 0)
58*b1cdbd2cSJim Jagielski     {
59*b1cdbd2cSJim Jagielski         // negativ
60*b1cdbd2cSJim Jagielski         printf("-");
61*b1cdbd2cSJim Jagielski         n = -n;
62*b1cdbd2cSJim Jagielski     }
63*b1cdbd2cSJim Jagielski     if (n > 2147483647)
64*b1cdbd2cSJim Jagielski     {
65*b1cdbd2cSJim Jagielski         sal_Int64 n64 = n >> 32;
66*b1cdbd2cSJim Jagielski         sal_uInt32 n32 = n64 & 0xffffffff;
67*b1cdbd2cSJim Jagielski         printf("0x%.8x ", n32);
68*b1cdbd2cSJim Jagielski         n32 = n & 0xffffffff;
69*b1cdbd2cSJim Jagielski         printf("%.8x (64bit)", n32);
70*b1cdbd2cSJim Jagielski     }
71*b1cdbd2cSJim Jagielski     else
72*b1cdbd2cSJim Jagielski     {
73*b1cdbd2cSJim Jagielski         sal_uInt32 n32 = n & 0xffffffff;
74*b1cdbd2cSJim Jagielski         printf("0x%.8x (32bit) ", n32);
75*b1cdbd2cSJim Jagielski     }
76*b1cdbd2cSJim Jagielski     printf("\n");
77*b1cdbd2cSJim Jagielski }
78*b1cdbd2cSJim Jagielski 
79*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
80*b1cdbd2cSJim Jagielski namespace testOfHelperFunctions
81*b1cdbd2cSJim Jagielski {
82*b1cdbd2cSJim Jagielski     class test_t_abs64 : public CppUnit::TestFixture
83*b1cdbd2cSJim Jagielski     {
84*b1cdbd2cSJim Jagielski     public:
85*b1cdbd2cSJim Jagielski         void test0();
86*b1cdbd2cSJim Jagielski         void test1_0();
87*b1cdbd2cSJim Jagielski         void test1();
88*b1cdbd2cSJim Jagielski         void test1_1();
89*b1cdbd2cSJim Jagielski         void test2();
90*b1cdbd2cSJim Jagielski         void test3();
91*b1cdbd2cSJim Jagielski         void test4();
92*b1cdbd2cSJim Jagielski 
93*b1cdbd2cSJim Jagielski         CPPUNIT_TEST_SUITE( test_t_abs64 );
94*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( test0 );
95*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( test1_0 );
96*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( test1 );
97*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( test1_1 );
98*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( test2 );
99*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( test3 );
100*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( test4 );
101*b1cdbd2cSJim Jagielski         CPPUNIT_TEST_SUITE_END( );
102*b1cdbd2cSJim Jagielski     };
103*b1cdbd2cSJim Jagielski 
test0()104*b1cdbd2cSJim Jagielski     void test_t_abs64::test0()
105*b1cdbd2cSJim Jagielski     {
106*b1cdbd2cSJim Jagielski         // this values has an overrun!
107*b1cdbd2cSJim Jagielski         sal_Int32 n32 = 2147483648;
108*b1cdbd2cSJim Jagielski         t_print("n32 should be -2^31 is: %d\n", n32);
109*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n32!=2147483648", n32 == -2147483648 );
110*b1cdbd2cSJim Jagielski     }
111*b1cdbd2cSJim Jagielski 
112*b1cdbd2cSJim Jagielski 
test1_0()113*b1cdbd2cSJim Jagielski     void test_t_abs64::test1_0()
114*b1cdbd2cSJim Jagielski     {
115*b1cdbd2cSJim Jagielski         sal_Int64 n;
116*b1cdbd2cSJim Jagielski         n = 1073741824;
117*b1cdbd2cSJim Jagielski         n <<= 9;
118*b1cdbd2cSJim Jagielski         t_print("Value of n is ");
119*b1cdbd2cSJim Jagielski         t_print64(n);
120*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=2^30 << 9", t_abs64(n) > 0 );
121*b1cdbd2cSJim Jagielski     }
122*b1cdbd2cSJim Jagielski 
test1()123*b1cdbd2cSJim Jagielski     void test_t_abs64::test1()
124*b1cdbd2cSJim Jagielski     {
125*b1cdbd2cSJim Jagielski         sal_Int64 n;
126*b1cdbd2cSJim Jagielski         n = 2147483648 << 8;
127*b1cdbd2cSJim Jagielski         t_print("Value of n is ");
128*b1cdbd2cSJim Jagielski         t_print64(n);
129*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=2^31 << 8", t_abs64(n) > 0 );
130*b1cdbd2cSJim Jagielski     }
test1_1()131*b1cdbd2cSJim Jagielski     void test_t_abs64::test1_1()
132*b1cdbd2cSJim Jagielski     {
133*b1cdbd2cSJim Jagielski         sal_Int64 n;
134*b1cdbd2cSJim Jagielski         n = sal_Int64(2147483648) << 8;
135*b1cdbd2cSJim Jagielski         t_print("Value of n is ");
136*b1cdbd2cSJim Jagielski         t_print64(n);
137*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=2^31 << 8", t_abs64(n) > 0 );
138*b1cdbd2cSJim Jagielski     }
139*b1cdbd2cSJim Jagielski 
test2()140*b1cdbd2cSJim Jagielski     void test_t_abs64::test2()
141*b1cdbd2cSJim Jagielski     {
142*b1cdbd2cSJim Jagielski         sal_Int64 n;
143*b1cdbd2cSJim Jagielski         n = 2147483648 << 1;
144*b1cdbd2cSJim Jagielski         t_print("Value of n is ");
145*b1cdbd2cSJim Jagielski         t_print64(n);
146*b1cdbd2cSJim Jagielski 
147*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("(2147483648 << 1) is != 0", n != 0 );
148*b1cdbd2cSJim Jagielski 
149*b1cdbd2cSJim Jagielski         sal_Int64 n2 = 2147483648 * 2;
150*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("2147483648 * 2 is != 0", n2 != 0 );
151*b1cdbd2cSJim Jagielski 
152*b1cdbd2cSJim Jagielski         sal_Int64 n3 = 4294967296LL;
153*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("4294967296 is != 0", n3 != 0 );
154*b1cdbd2cSJim Jagielski 
155*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=2^31 << 1, n2 = 2^31 * 2, n3 = 2^32, all should equal!", n == n2 && n == n3 );
156*b1cdbd2cSJim Jagielski     }
157*b1cdbd2cSJim Jagielski 
158*b1cdbd2cSJim Jagielski 
test3()159*b1cdbd2cSJim Jagielski     void test_t_abs64::test3()
160*b1cdbd2cSJim Jagielski     {
161*b1cdbd2cSJim Jagielski         sal_Int64 n = 0;
162*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=0", t_abs64(n) == 0 );
163*b1cdbd2cSJim Jagielski 
164*b1cdbd2cSJim Jagielski         n = 1;
165*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=1", t_abs64(n) > 0 );
166*b1cdbd2cSJim Jagielski 
167*b1cdbd2cSJim Jagielski         n = 2147483647;
168*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=2^31 - 1", t_abs64(n) > 0 );
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski         n = 2147483648;
171*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=2^31", t_abs64(n) > 0 );
172*b1cdbd2cSJim Jagielski     }
173*b1cdbd2cSJim Jagielski 
test4()174*b1cdbd2cSJim Jagielski     void test_t_abs64::test4()
175*b1cdbd2cSJim Jagielski     {
176*b1cdbd2cSJim Jagielski         sal_Int64 n = 0;
177*b1cdbd2cSJim Jagielski         n = -1;
178*b1cdbd2cSJim Jagielski         t_print("Value of n is -1 : ");
179*b1cdbd2cSJim Jagielski         t_print64(n);
180*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=-1", t_abs64(n) > 0 );
181*b1cdbd2cSJim Jagielski 
182*b1cdbd2cSJim Jagielski         n = -2147483648;
183*b1cdbd2cSJim Jagielski         t_print("Value of n is -2^31 : ");
184*b1cdbd2cSJim Jagielski         t_print64(n);
185*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=-2^31", t_abs64(n) > 0 );
186*b1cdbd2cSJim Jagielski 
187*b1cdbd2cSJim Jagielski         n = -8589934592LL;
188*b1cdbd2cSJim Jagielski         t_print("Value of n is -2^33 : ");
189*b1cdbd2cSJim Jagielski         t_print64(n);
190*b1cdbd2cSJim Jagielski         CPPUNIT_ASSERT_MESSAGE("n=-2^33", t_abs64(n) > 0 );
191*b1cdbd2cSJim Jagielski     }
192*b1cdbd2cSJim Jagielski 
193*b1cdbd2cSJim Jagielski 
194*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
195*b1cdbd2cSJim Jagielski     class test_t_print : public CppUnit::TestFixture
196*b1cdbd2cSJim Jagielski     {
197*b1cdbd2cSJim Jagielski     public:
198*b1cdbd2cSJim Jagielski         void t_print_001();
199*b1cdbd2cSJim Jagielski 
200*b1cdbd2cSJim Jagielski         CPPUNIT_TEST_SUITE( test_t_print );
201*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( t_print_001 );
202*b1cdbd2cSJim Jagielski         CPPUNIT_TEST_SUITE_END( );
203*b1cdbd2cSJim Jagielski     };
204*b1cdbd2cSJim Jagielski 
t_print_001()205*b1cdbd2cSJim Jagielski     void test_t_print::t_print_001( )
206*b1cdbd2cSJim Jagielski     {
207*b1cdbd2cSJim Jagielski         t_print("This is only a test of some helper functions\n");
208*b1cdbd2cSJim Jagielski         sal_Int32 nValue = 12345;
209*b1cdbd2cSJim Jagielski         t_print("a value %d (should be 12345)\n", nValue);
210*b1cdbd2cSJim Jagielski 
211*b1cdbd2cSJim Jagielski         rtl::OString sValue("foo bar");
212*b1cdbd2cSJim Jagielski         t_print("a String '%s' (should be 'foo bar')\n", sValue.getStr());
213*b1cdbd2cSJim Jagielski 
214*b1cdbd2cSJim Jagielski         rtl::OUString suValue(rtl::OUString::createFromAscii("a unicode string"));
215*b1cdbd2cSJim Jagielski         sValue <<= suValue;
216*b1cdbd2cSJim Jagielski         t_print("a String '%s'\n", sValue.getStr());
217*b1cdbd2cSJim Jagielski     }
218*b1cdbd2cSJim Jagielski 
219*b1cdbd2cSJim Jagielski 
220*b1cdbd2cSJim Jagielski     class StopWatch
221*b1cdbd2cSJim Jagielski     {
222*b1cdbd2cSJim Jagielski         TimeValue m_aStartTime;
223*b1cdbd2cSJim Jagielski         TimeValue m_aEndTime;
224*b1cdbd2cSJim Jagielski         bool m_bStarted;
225*b1cdbd2cSJim Jagielski     public:
StopWatch()226*b1cdbd2cSJim Jagielski         StopWatch()
227*b1cdbd2cSJim Jagielski                 :m_bStarted(false)
228*b1cdbd2cSJim Jagielski             {
229*b1cdbd2cSJim Jagielski             }
230*b1cdbd2cSJim Jagielski 
start()231*b1cdbd2cSJim Jagielski         void start()
232*b1cdbd2cSJim Jagielski             {
233*b1cdbd2cSJim Jagielski                 m_bStarted = true;
234*b1cdbd2cSJim Jagielski                 osl_getSystemTime(&m_aStartTime);
235*b1cdbd2cSJim Jagielski             }
stop()236*b1cdbd2cSJim Jagielski         void stop()
237*b1cdbd2cSJim Jagielski             {
238*b1cdbd2cSJim Jagielski                 osl_getSystemTime(&m_aEndTime);
239*b1cdbd2cSJim Jagielski                 OSL_ENSURE(m_bStarted, "Not Started.");
240*b1cdbd2cSJim Jagielski                 m_bStarted = false;
241*b1cdbd2cSJim Jagielski             }
makeTwoDigits(rtl::OString const & _sStr)242*b1cdbd2cSJim Jagielski         rtl::OString makeTwoDigits(rtl::OString const& _sStr)
243*b1cdbd2cSJim Jagielski             {
244*b1cdbd2cSJim Jagielski                 rtl::OString sBack;
245*b1cdbd2cSJim Jagielski                 if (_sStr.getLength() == 0)
246*b1cdbd2cSJim Jagielski                 {
247*b1cdbd2cSJim Jagielski                     sBack = "00";
248*b1cdbd2cSJim Jagielski                 }
249*b1cdbd2cSJim Jagielski                 else
250*b1cdbd2cSJim Jagielski                 {
251*b1cdbd2cSJim Jagielski                     if (_sStr.getLength() == 1)
252*b1cdbd2cSJim Jagielski                     {
253*b1cdbd2cSJim Jagielski                         sBack = "0" + _sStr;
254*b1cdbd2cSJim Jagielski                     }
255*b1cdbd2cSJim Jagielski                     else
256*b1cdbd2cSJim Jagielski                     {
257*b1cdbd2cSJim Jagielski                         sBack = _sStr;
258*b1cdbd2cSJim Jagielski                     }
259*b1cdbd2cSJim Jagielski                 }
260*b1cdbd2cSJim Jagielski                 return sBack;
261*b1cdbd2cSJim Jagielski             }
makeThreeDigits(rtl::OString const & _sStr)262*b1cdbd2cSJim Jagielski         rtl::OString makeThreeDigits(rtl::OString const& _sStr)
263*b1cdbd2cSJim Jagielski             {
264*b1cdbd2cSJim Jagielski                 rtl::OString sBack;
265*b1cdbd2cSJim Jagielski                 if (_sStr.getLength() == 0)
266*b1cdbd2cSJim Jagielski                 {
267*b1cdbd2cSJim Jagielski                     sBack = "000";
268*b1cdbd2cSJim Jagielski                 }
269*b1cdbd2cSJim Jagielski                 else
270*b1cdbd2cSJim Jagielski                 {
271*b1cdbd2cSJim Jagielski                     if (_sStr.getLength() == 1)
272*b1cdbd2cSJim Jagielski                     {
273*b1cdbd2cSJim Jagielski                         sBack = "00" + _sStr;
274*b1cdbd2cSJim Jagielski                     }
275*b1cdbd2cSJim Jagielski                     else
276*b1cdbd2cSJim Jagielski                     {
277*b1cdbd2cSJim Jagielski                         if (_sStr.getLength() == 2)
278*b1cdbd2cSJim Jagielski                         {
279*b1cdbd2cSJim Jagielski                             sBack = "0" + _sStr;
280*b1cdbd2cSJim Jagielski                         }
281*b1cdbd2cSJim Jagielski                         else
282*b1cdbd2cSJim Jagielski                         {
283*b1cdbd2cSJim Jagielski                             sBack = _sStr;
284*b1cdbd2cSJim Jagielski                         }
285*b1cdbd2cSJim Jagielski                     }
286*b1cdbd2cSJim Jagielski                 }
287*b1cdbd2cSJim Jagielski                 return sBack;
288*b1cdbd2cSJim Jagielski             }
289*b1cdbd2cSJim Jagielski 
showTime(const rtl::OString & aWhatStr)290*b1cdbd2cSJim Jagielski         void  showTime(const rtl::OString & aWhatStr)
291*b1cdbd2cSJim Jagielski             {
292*b1cdbd2cSJim Jagielski                 OSL_ENSURE(!m_bStarted, "Not Stopped.");
293*b1cdbd2cSJim Jagielski 
294*b1cdbd2cSJim Jagielski                 sal_Int32 nSeconds = m_aEndTime.Seconds - m_aStartTime.Seconds;
295*b1cdbd2cSJim Jagielski                 sal_Int32 nNanoSec = sal_Int32(m_aEndTime.Nanosec) - sal_Int32(m_aStartTime.Nanosec);
296*b1cdbd2cSJim Jagielski                 // printf("Seconds: %d Nanosec: %d ", nSeconds, nNanoSec);
297*b1cdbd2cSJim Jagielski                 if (nNanoSec < 0)
298*b1cdbd2cSJim Jagielski                 {
299*b1cdbd2cSJim Jagielski                     nNanoSec = 1000000000 + nNanoSec;
300*b1cdbd2cSJim Jagielski                     nSeconds--;
301*b1cdbd2cSJim Jagielski                     // printf(" NEW Seconds: %d Nanosec: %d\n", nSeconds, nNanoSec);
302*b1cdbd2cSJim Jagielski                 }
303*b1cdbd2cSJim Jagielski 
304*b1cdbd2cSJim Jagielski                 rtl::OString aStr = "Time for ";
305*b1cdbd2cSJim Jagielski                 aStr += aWhatStr;
306*b1cdbd2cSJim Jagielski                 aStr += " ";
307*b1cdbd2cSJim Jagielski                 aStr += makeTwoDigits(rtl::OString::valueOf(nSeconds / 3600));
308*b1cdbd2cSJim Jagielski                 aStr += ":";
309*b1cdbd2cSJim Jagielski                 aStr += makeTwoDigits(rtl::OString::valueOf((nSeconds % 3600) / 60));
310*b1cdbd2cSJim Jagielski                 aStr += ":";
311*b1cdbd2cSJim Jagielski                 aStr += makeTwoDigits(rtl::OString::valueOf((nSeconds % 60)));
312*b1cdbd2cSJim Jagielski                 aStr += ":";
313*b1cdbd2cSJim Jagielski                 aStr += makeThreeDigits(rtl::OString::valueOf((nNanoSec % 1000000000) / 1000000));
314*b1cdbd2cSJim Jagielski                 aStr += ":";
315*b1cdbd2cSJim Jagielski                 aStr += makeThreeDigits(rtl::OString::valueOf((nNanoSec % 1000000) / 1000));
316*b1cdbd2cSJim Jagielski                 aStr += ":";
317*b1cdbd2cSJim Jagielski                 aStr += makeThreeDigits(rtl::OString::valueOf((nNanoSec % 1000)));
318*b1cdbd2cSJim Jagielski 
319*b1cdbd2cSJim Jagielski                 printf("%s\n", aStr.getStr());
320*b1cdbd2cSJim Jagielski                 // cout << aStr.getStr() << endl;
321*b1cdbd2cSJim Jagielski             }
322*b1cdbd2cSJim Jagielski 
323*b1cdbd2cSJim Jagielski     };
324*b1cdbd2cSJim Jagielski 
isEqualTimeValue(const TimeValue * time1,const TimeValue * time2)325*b1cdbd2cSJim Jagielski static sal_Bool isEqualTimeValue ( const TimeValue* time1,  const TimeValue* time2)
326*b1cdbd2cSJim Jagielski {
327*b1cdbd2cSJim Jagielski 	if( time1->Seconds == time2->Seconds &&
328*b1cdbd2cSJim Jagielski 		time1->Nanosec == time2->Nanosec)
329*b1cdbd2cSJim Jagielski 		return sal_True;
330*b1cdbd2cSJim Jagielski 	else
331*b1cdbd2cSJim Jagielski 		return sal_False;
332*b1cdbd2cSJim Jagielski }
333*b1cdbd2cSJim Jagielski 
isGreaterTimeValue(const TimeValue * time1,const TimeValue * time2)334*b1cdbd2cSJim Jagielski static sal_Bool isGreaterTimeValue(  const TimeValue* time1,  const TimeValue* time2)
335*b1cdbd2cSJim Jagielski {
336*b1cdbd2cSJim Jagielski 	sal_Bool retval= sal_False;
337*b1cdbd2cSJim Jagielski 	if ( time1->Seconds > time2->Seconds)
338*b1cdbd2cSJim Jagielski 		retval= sal_True;
339*b1cdbd2cSJim Jagielski 	else if ( time1->Seconds == time2->Seconds)
340*b1cdbd2cSJim Jagielski 	{
341*b1cdbd2cSJim Jagielski 		if( time1->Nanosec > time2->Nanosec)
342*b1cdbd2cSJim Jagielski 			retval= sal_True;
343*b1cdbd2cSJim Jagielski 	}
344*b1cdbd2cSJim Jagielski 	return retval;
345*b1cdbd2cSJim Jagielski }
346*b1cdbd2cSJim Jagielski 
isGreaterEqualTimeValue(const TimeValue * time1,const TimeValue * time2)347*b1cdbd2cSJim Jagielski static sal_Bool isGreaterEqualTimeValue( const TimeValue* time1, const TimeValue* time2)
348*b1cdbd2cSJim Jagielski {
349*b1cdbd2cSJim Jagielski 	if( isEqualTimeValue( time1, time2) )
350*b1cdbd2cSJim Jagielski 		return sal_True;
351*b1cdbd2cSJim Jagielski 	else if( isGreaterTimeValue( time1, time2))
352*b1cdbd2cSJim Jagielski 		return sal_True;
353*b1cdbd2cSJim Jagielski 	else
354*b1cdbd2cSJim Jagielski 		return sal_False;
355*b1cdbd2cSJim Jagielski }
356*b1cdbd2cSJim Jagielski 
isBTimeGreaterATime(TimeValue const & A,TimeValue const & B)357*b1cdbd2cSJim Jagielski bool isBTimeGreaterATime(TimeValue const& A, TimeValue const& B)
358*b1cdbd2cSJim Jagielski {
359*b1cdbd2cSJim Jagielski 	if (B.Seconds > A.Seconds) return true;
360*b1cdbd2cSJim Jagielski 	if (B.Nanosec > A.Nanosec) return true;
361*b1cdbd2cSJim Jagielski 
362*b1cdbd2cSJim Jagielski 	// lower or equal
363*b1cdbd2cSJim Jagielski 	return false;
364*b1cdbd2cSJim Jagielski }
365*b1cdbd2cSJim Jagielski     // -----------------------------------------------------------------------------
366*b1cdbd2cSJim Jagielski 
367*b1cdbd2cSJim Jagielski 
368*b1cdbd2cSJim Jagielski     class test_TimeValues : public CppUnit::TestFixture
369*b1cdbd2cSJim Jagielski     {
370*b1cdbd2cSJim Jagielski     public:
371*b1cdbd2cSJim Jagielski 
372*b1cdbd2cSJim Jagielski         void t_time1();
373*b1cdbd2cSJim Jagielski         void t_time2();
374*b1cdbd2cSJim Jagielski         void t_time3();
375*b1cdbd2cSJim Jagielski 
376*b1cdbd2cSJim Jagielski         CPPUNIT_TEST_SUITE( test_TimeValues );
377*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( t_time1 );
378*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( t_time2 );
379*b1cdbd2cSJim Jagielski         CPPUNIT_TEST( t_time3 );
380*b1cdbd2cSJim Jagielski         CPPUNIT_TEST_SUITE_END( );
381*b1cdbd2cSJim Jagielski     };
382*b1cdbd2cSJim Jagielski 
t_time1()383*b1cdbd2cSJim Jagielski void test_TimeValues::t_time1()
384*b1cdbd2cSJim Jagielski {
385*b1cdbd2cSJim Jagielski     StopWatch aWatch;
386*b1cdbd2cSJim Jagielski     aWatch.start();
387*b1cdbd2cSJim Jagielski     TimeValue aTimeValue={3,0};
388*b1cdbd2cSJim Jagielski     osl::Thread::wait(aTimeValue);
389*b1cdbd2cSJim Jagielski     aWatch.stop();
390*b1cdbd2cSJim Jagielski     aWatch.showTime("Wait for 3 seconds");
391*b1cdbd2cSJim Jagielski }
392*b1cdbd2cSJim Jagielski 
t_time2()393*b1cdbd2cSJim Jagielski void test_TimeValues::t_time2()
394*b1cdbd2cSJim Jagielski {
395*b1cdbd2cSJim Jagielski     t_print("Wait repeats 20 times.\n");
396*b1cdbd2cSJim Jagielski     int i=0;
397*b1cdbd2cSJim Jagielski     while(i++<20)
398*b1cdbd2cSJim Jagielski     {
399*b1cdbd2cSJim Jagielski         StopWatch aWatch;
400*b1cdbd2cSJim Jagielski         aWatch.start();
401*b1cdbd2cSJim Jagielski         TimeValue aTimeValue={0,1000 * 1000 * 500};
402*b1cdbd2cSJim Jagielski         osl::Thread::wait(aTimeValue);
403*b1cdbd2cSJim Jagielski         aWatch.stop();
404*b1cdbd2cSJim Jagielski         aWatch.showTime("wait for 500msec");
405*b1cdbd2cSJim Jagielski     }
406*b1cdbd2cSJim Jagielski }
407*b1cdbd2cSJim Jagielski 
t_time3()408*b1cdbd2cSJim Jagielski void test_TimeValues::t_time3()
409*b1cdbd2cSJim Jagielski {
410*b1cdbd2cSJim Jagielski     t_print("Wait repeats 100 times.\n");
411*b1cdbd2cSJim Jagielski     int i=0;
412*b1cdbd2cSJim Jagielski     while(i++<20)
413*b1cdbd2cSJim Jagielski     {
414*b1cdbd2cSJim Jagielski         StopWatch aWatch;
415*b1cdbd2cSJim Jagielski         aWatch.start();
416*b1cdbd2cSJim Jagielski         TimeValue aTimeValue={0,1000*1000*100};
417*b1cdbd2cSJim Jagielski         osl::Thread::wait(aTimeValue);
418*b1cdbd2cSJim Jagielski         aWatch.stop();
419*b1cdbd2cSJim Jagielski         aWatch.showTime("wait for 100msec");
420*b1cdbd2cSJim Jagielski     }
421*b1cdbd2cSJim Jagielski }
422*b1cdbd2cSJim Jagielski 
423*b1cdbd2cSJim Jagielski     // void demoTimeValue()
424*b1cdbd2cSJim Jagielski     // {
425*b1cdbd2cSJim Jagielski     //     TimeValue aStartTime, aEndTime;
426*b1cdbd2cSJim Jagielski     //     osl_getSystemTime(&aStartTime);
427*b1cdbd2cSJim Jagielski     //     // testSession(xORB, false);
428*b1cdbd2cSJim Jagielski     //     osl_getSystemTime(&aEndTime);
429*b1cdbd2cSJim Jagielski     //
430*b1cdbd2cSJim Jagielski     //     sal_Int32 nSeconds = aEndTime.Seconds - aStartTime.Seconds;
431*b1cdbd2cSJim Jagielski     //     sal_Int32 nNanoSec = aEndTime.Nanosec - aStartTime.Nanosec;
432*b1cdbd2cSJim Jagielski     //     if (nNanoSec < 0)
433*b1cdbd2cSJim Jagielski     //     {
434*b1cdbd2cSJim Jagielski     //         nNanoSec = 1000000000 - nNanoSec;
435*b1cdbd2cSJim Jagielski     //         nSeconds++;
436*b1cdbd2cSJim Jagielski     //     }
437*b1cdbd2cSJim Jagielski     //
438*b1cdbd2cSJim Jagielski     //     // cout << "Time: " << nSeconds << ". " << nNanoSec << endl;
439*b1cdbd2cSJim Jagielski     // }
440*b1cdbd2cSJim Jagielski 
441*b1cdbd2cSJim Jagielski 
442*b1cdbd2cSJim Jagielski } // namespace testOfHelperFunctions
443*b1cdbd2cSJim Jagielski 
444*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
445*b1cdbd2cSJim Jagielski CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( testOfHelperFunctions::test_t_print, "helperFunctions" );
446*b1cdbd2cSJim Jagielski CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( testOfHelperFunctions::test_t_abs64, "helperFunctions" );
447*b1cdbd2cSJim Jagielski CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( testOfHelperFunctions::test_TimeValues, "helperFunctions" );
448*b1cdbd2cSJim Jagielski 
449*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------------
450*b1cdbd2cSJim Jagielski NOADDITIONAL;
451