lexicographical_compare.pass.cpp 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. // <algorithm>
  10. // template<InputIterator Iter1, InputIterator Iter2>
  11. // requires HasLess<Iter1::value_type, Iter2::value_type>
  12. // && HasLess<Iter2::value_type, Iter1::value_type>
  13. // bool
  14. // lexicographical_compare(Iter1 first1, Iter1 last1, Iter2 first2, Iter2 last2);
  15. #include <algorithm>
  16. #include <cassert>
  17. #include "../../iterators.h"
  18. template <class Iter1, class Iter2>
  19. void
  20. test()
  21. {
  22. int ia[] = {1, 2, 3, 4};
  23. const unsigned sa = sizeof(ia)/sizeof(ia[0]);
  24. int ib[] = {1, 2, 3};
  25. assert(!std::lexicographical_compare(ia, ia+sa, ib, ib+2));
  26. assert(std::lexicographical_compare(ib, ib+2, ia, ia+sa));
  27. assert(!std::lexicographical_compare(ia, ia+sa, ib, ib+3));
  28. assert(std::lexicographical_compare(ib, ib+3, ia, ia+sa));
  29. assert(std::lexicographical_compare(ia, ia+sa, ib+1, ib+3));
  30. assert(!std::lexicographical_compare(ib+1, ib+3, ia, ia+sa));
  31. }
  32. int main()
  33. {
  34. test<input_iterator<const int*>, input_iterator<const int*> >();
  35. test<input_iterator<const int*>, forward_iterator<const int*> >();
  36. test<input_iterator<const int*>, bidirectional_iterator<const int*> >();
  37. test<input_iterator<const int*>, random_access_iterator<const int*> >();
  38. test<input_iterator<const int*>, const int*>();
  39. test<forward_iterator<const int*>, input_iterator<const int*> >();
  40. test<forward_iterator<const int*>, forward_iterator<const int*> >();
  41. test<forward_iterator<const int*>, bidirectional_iterator<const int*> >();
  42. test<forward_iterator<const int*>, random_access_iterator<const int*> >();
  43. test<forward_iterator<const int*>, const int*>();
  44. test<bidirectional_iterator<const int*>, input_iterator<const int*> >();
  45. test<bidirectional_iterator<const int*>, forward_iterator<const int*> >();
  46. test<bidirectional_iterator<const int*>, bidirectional_iterator<const int*> >();
  47. test<bidirectional_iterator<const int*>, random_access_iterator<const int*> >();
  48. test<bidirectional_iterator<const int*>, const int*>();
  49. test<random_access_iterator<const int*>, input_iterator<const int*> >();
  50. test<random_access_iterator<const int*>, forward_iterator<const int*> >();
  51. test<random_access_iterator<const int*>, bidirectional_iterator<const int*> >();
  52. test<random_access_iterator<const int*>, random_access_iterator<const int*> >();
  53. test<random_access_iterator<const int*>, const int*>();
  54. test<const int*, input_iterator<const int*> >();
  55. test<const int*, forward_iterator<const int*> >();
  56. test<const int*, bidirectional_iterator<const int*> >();
  57. test<const int*, random_access_iterator<const int*> >();
  58. test<const int*, const int*>();
  59. }