fail_cview3.cpp 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. // Copyright 2002 The Trustees of Indiana University.
  2. // Use, modification and distribution is subject to the Boost Software
  3. // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
  4. // http://www.boost.org/LICENSE_1_0.txt)
  5. // Boost.MultiArray Library
  6. // Authors: Ronald Garcia
  7. // Jeremy Siek
  8. // Andrew Lumsdaine
  9. // See http://www.boost.org/libs/multi_array for documentation.
  10. //
  11. // fail_cview3.cpp
  12. // ensure const_array_ref doesn't allow assignment.
  13. //
  14. #include <boost/multi_array.hpp>
  15. #include <boost/core/lightweight_test.hpp>
  16. #include <boost/array.hpp>
  17. #include <boost/type.hpp>
  18. int
  19. main()
  20. {
  21. const int ndims=3;
  22. typedef boost::multi_array<int,ndims> array;
  23. boost::array<array::size_type,ndims> sma_dims = {{2,3,4}};
  24. int data[] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,
  25. 14,15,16,17,18,19,20,21,22,23};
  26. const int data_size = 24;
  27. array sma(sma_dims);
  28. sma.assign(data,data+data_size);
  29. //
  30. // subarray dims:
  31. // [base,stride,bound)
  32. // [0,1,2), [1,1,3), [0,2,4)
  33. //
  34. const array& csma = sma;
  35. typedef array::index_range range;
  36. array::index_gen indices;
  37. array::const_array_view<ndims>::type csma2 =
  38. csma[indices[range(0,2)][range(1,3)][range(0,4,2)]];
  39. for (array::index i = 0; i != 2; ++i)
  40. for (array::index j = 0; j != 2; ++j)
  41. for (array::index k = 0; k != 2; ++k)
  42. // FAIL! csma2 cannot be assigned to.
  43. csma2[i][j][k] = 0;
  44. return boost::report_errors();
  45. }