compose_property_map_test.cpp 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. // Copyright (C) 2013 Eurodecision
  2. // Authors: Guillaume Pinot
  3. //
  4. // Distributed under the Boost Software License, Version 1.0. (See
  5. // accompanying file LICENSE_1_0.txt or copy at
  6. // http://www.boost.org/LICENSE_1_0.txt)
  7. #include <boost/property_map/compose_property_map.hpp>
  8. #include <boost/property_map/function_property_map.hpp>
  9. #include <boost/test/minimal.hpp>
  10. void concept_checks()
  11. {
  12. using namespace boost;
  13. {
  14. typedef null_archetype<> Key;
  15. //typedef assignable_archetype<copy_constructible_archetype<> > Value;
  16. typedef copy_constructible_archetype<assignable_archetype<> > Value;
  17. typedef readable_property_map_archetype<Key, Key> GPMap;
  18. typedef readable_property_map_archetype<Key, Value> FPMap;
  19. typedef compose_property_map<FPMap, GPMap> CPM;
  20. BOOST_CONCEPT_ASSERT((ReadablePropertyMapConcept<CPM, Key>));
  21. }
  22. {
  23. typedef null_archetype<> Key;
  24. typedef copy_constructible_archetype<assignable_archetype<> > Value;
  25. typedef readable_property_map_archetype<Key, Key> GPMap;
  26. typedef writable_property_map_archetype<Key, Value> FPMap;
  27. typedef compose_property_map<FPMap, GPMap> CPM;
  28. BOOST_CONCEPT_ASSERT((WritablePropertyMapConcept<CPM, Key>));
  29. }
  30. {
  31. typedef null_archetype<> Key;
  32. typedef copy_constructible_archetype<assignable_archetype<> > Value;
  33. typedef readable_property_map_archetype<Key, Key> GPMap;
  34. typedef read_write_property_map_archetype<Key, Value> FPMap;
  35. typedef compose_property_map<FPMap, GPMap> CPM;
  36. BOOST_CONCEPT_ASSERT((ReadWritePropertyMapConcept<CPM, Key>));
  37. }
  38. {
  39. typedef null_archetype<> Key;
  40. typedef copy_constructible_archetype<assignable_archetype<> > Value;
  41. typedef readable_property_map_archetype<Key, Key> GPMap;
  42. typedef lvalue_property_map_archetype<Key, Value> FPMap;
  43. typedef compose_property_map<FPMap, GPMap> CPM;
  44. BOOST_CONCEPT_ASSERT((LvaluePropertyMapConcept<CPM, Key>));
  45. }
  46. {
  47. typedef null_archetype<> Key;
  48. typedef copy_constructible_archetype<assignable_archetype<> > Value;
  49. typedef readable_property_map_archetype<Key, Key> GPMap;
  50. typedef mutable_lvalue_property_map_archetype<Key, Value> FPMap;
  51. typedef compose_property_map<FPMap, GPMap> CPM;
  52. BOOST_CONCEPT_ASSERT((Mutable_LvaluePropertyMapConcept<CPM, Key>));
  53. }
  54. }
  55. void pointer_pmap_check()
  56. {
  57. const int idx[] = {2, 0, 4, 1, 3};
  58. double v[] = {1., 3., 0., 4., 2.};
  59. boost::compose_property_map<double*, const int*> cpm(v, idx);
  60. for (int i = 0; i < 5; ++i) {
  61. BOOST_CHECK(get(cpm, i) == static_cast<double>(i));
  62. ++cpm[i];
  63. BOOST_CHECK(cpm[i] == static_cast<double>(i + 1));
  64. put(cpm, i, 42.);
  65. BOOST_CHECK(cpm[i] == 42.);
  66. }
  67. }
  68. struct modulo_add_one {
  69. typedef int result_type;
  70. modulo_add_one(int m): modulo(m) {}
  71. int operator()(int i) const {return (i + 1) % modulo;}
  72. int modulo;
  73. };
  74. void readable_pmap_checks()
  75. {
  76. using namespace boost;
  77. typedef function_property_map<modulo_add_one, int> modulo_add_one_pmap;
  78. compose_property_map<modulo_add_one_pmap, modulo_add_one_pmap>
  79. cpm(modulo_add_one(5), modulo_add_one(5));
  80. for (int i = 0; i < 10; ++i)
  81. BOOST_CHECK(get(cpm, i) == (i + 2) % 5);
  82. }
  83. int
  84. test_main(int, char**)
  85. {
  86. concept_checks();
  87. pointer_pmap_check();
  88. readable_pmap_checks();
  89. return 0;
  90. }