1e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#include <vector>
2e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#include <list>
3e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#include <algorithm>
4e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
5e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#include "cppunit/cppunit_proxy.h"
6e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
7e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#if !defined (STLPORT) || defined(_STLP_USE_NAMESPACES)
8e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottusing namespace std;
9e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#endif
10e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
11e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott//
12e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott// TestCase class
13e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott//
14e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottclass ReviterTest : public CPPUNIT_NS::TestCase
15e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott{
16e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST_SUITE(ReviterTest);
17e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST(reviter1);
18e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST(reviter2);
19e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST(revbit1);
20e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST_SUITE_END();
21e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
22e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottprotected:
23e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  void reviter1();
24e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  void reviter2();
25e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  void revbit1();
26e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott};
27e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
28e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick ScottCPPUNIT_TEST_SUITE_REGISTRATION(ReviterTest);
29e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
30e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott//
31e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott// tests implementation
32e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott//
33e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottvoid ReviterTest::reviter1()
34e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott{
35e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  int array [] = { 1, 5, 2, 3 };
36e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
37e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  vector<int> v(array, array + 4);
38e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  typedef vector<int>::reverse_iterator reviter;
39e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  reviter r(v.rend());
40e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  r--;
41e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
42e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r-- == 1);
43e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r-- == 5);
44e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r-- == 2);
45e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r == 3);
46e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(r==v.rbegin());
47e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott}
48e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottvoid ReviterTest::reviter2()
49e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott{
50e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  int array [] = { 1, 5, 2, 3 };
51e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
52e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  vector<int> v(array, array + 4);
53e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  vector<int>::reverse_iterator r;
54e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  r = v.rbegin();
55e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r++ == 3);
56e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r++ == 2);
57e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r++ == 5);
58e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r++ == 1);
59e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(r==v.rend());
60e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott}
61e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottvoid ReviterTest::revbit1()
62e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott{
63e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  int array [] = { 1, 5, 2, 3 };
64e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
65e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  list<int> v(array, array + 4);
66e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  list<int>::reverse_iterator r(v.rbegin());
67e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r++ == 3);
68e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r++ == 2);
69e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r++ == 5);
70e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(*r++ == 1);
71e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(r==v.rend());
72e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott}
73