9
3

collection.cpp 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. //
  2. // Copyright 2018 Mateusz Loskot <mateusz at loskot dot net>
  3. //
  4. // Distributed under the Boost Software License, Version 1.0
  5. // See accompanying file LICENSE_1_0.txt or copy at
  6. // http://www.boost.org/LICENSE_1_0.txt
  7. //
  8. #include <boost/gil/image.hpp>
  9. #include <boost/gil/image_view.hpp>
  10. #include <boost/gil/typedefs.hpp>
  11. #include <boost/core/lightweight_test.hpp>
  12. namespace gil = boost::gil;
  13. gil::gray8_pixel_t const gray128(128);
  14. gil::gray8_pixel_t const gray255(255);
  15. void test_begin()
  16. {
  17. gil::gray8_image_t image(2, 2, gray255);
  18. auto view = gil::view(image);
  19. BOOST_TEST(*view.begin() == gray255);
  20. }
  21. void test_end()
  22. {
  23. gil::gray8_image_t::view_t view;
  24. BOOST_TEST(view.begin() == view.end());
  25. }
  26. void test_rbegin()
  27. {
  28. gil::gray8_image_t image(2, 2, gray255);
  29. auto view = gil::view(image);
  30. view(1,1) = gray128;
  31. BOOST_TEST(*view.rbegin() == gray128);
  32. }
  33. void test_rend()
  34. {
  35. gil::gray8_image_t::view_t view;
  36. BOOST_TEST(view.rbegin() == view.rend());
  37. }
  38. void test_front()
  39. {
  40. gil::gray8_image_t image(2, 2, gray255);
  41. auto view = gil::view(image);
  42. BOOST_TEST(view.front() == gray255);
  43. }
  44. void test_back()
  45. {
  46. gil::gray8_image_t image(2, 2, gray255);
  47. auto view = gil::view(image);
  48. BOOST_TEST(view.back() == gray255);
  49. }
  50. void test_empty()
  51. {
  52. gil::gray8_image_t::view_t view;
  53. BOOST_TEST(view.empty());
  54. gil::gray8_image_t image(2, 2);
  55. view = gil::view(image);
  56. BOOST_TEST(!view.empty());
  57. }
  58. void test_size()
  59. {
  60. gil::gray8_image_t::view_t view;
  61. BOOST_TEST_EQ(view.size(), 0);
  62. gil::gray8_image_t image(2, 2);
  63. view = gil::view(image);
  64. BOOST_TEST_EQ(view.size(), 4);
  65. }
  66. void test_swap()
  67. {
  68. gil::gray8_image_t::view_t view1;
  69. gil::gray8_image_t::view_t view2;
  70. gil::gray8_image_t image(2, 2);
  71. view1 = gil::view(image);
  72. view1.swap(view2);
  73. BOOST_TEST(view1.empty());
  74. BOOST_TEST(!view2.empty());
  75. }
  76. int main()
  77. {
  78. // Collection
  79. test_begin();
  80. test_end();
  81. test_size();
  82. test_empty();
  83. test_swap();
  84. // ForwardCollection
  85. test_front();
  86. // ReversibleCollection
  87. test_rbegin();
  88. test_rend();
  89. test_back();
  90. return boost::report_errors();
  91. }