1e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#include <vector>
2e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#include <algorithm>
3e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott#include <functional>
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 LexcmpTest : public CPPUNIT_NS::TestCase
15e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott{
16e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST_SUITE(LexcmpTest);
17e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST(lexcmp1);
18e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST(lexcmp2);
19e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_TEST_SUITE_END();
20e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
21e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottprotected:
22e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  void lexcmp1();
23e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  void lexcmp2();
24e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott};
25e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
26e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick ScottCPPUNIT_TEST_SUITE_REGISTRATION(LexcmpTest);
27e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
28e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott//
29e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott// tests implementation
30e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott//
31e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottvoid LexcmpTest::lexcmp1()
32e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott{
33e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  const unsigned size = 6;
34e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  char n1[size] = "shoe";
35e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  char n2[size] = "shine";
36e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
37e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  bool before = lexicographical_compare(n1, n1 + size, n2, n2 + size);
38e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(!before);
39e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott}
40e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scottvoid LexcmpTest::lexcmp2()
41e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott{
42e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  const unsigned size = 6;
43e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  char n1[size] = "shoe";
44e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  char n2[size] = "shine";
45e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott
46e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  bool before = lexicographical_compare(n1, n1 + size, n2, n2 + size, greater<char>());
47e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott  CPPUNIT_ASSERT(before);
48e46c9386c4f79aa40185f79a19fc5b2a7ef528b3Patrick Scott}
49