gil/test/legacy/recreate_image.cpp
Mateusz Łoskot 5611bd5807
Replace Boost.MPL with Boost.MP11 (#274)
Use type traits and features of C++11, then use Boost.MP11.
Remove unused and unnecessary metafunctions in `detail` namespace.
Remove explicit access to ::type as no longer necessary with MP11.
Clean up and reformat code according to the current guidelines.

Legacy tests have been updated where necessary to accommodate
switch to MP11.

Replace std::is_integral with gil::detail::is_channel_integral
Replacing boost::is_integral with std::is_integral is C++ UB:

    C++11 / 20.11.2 Header <type_traits> synopsis
    1 The behavior of a program that adds specializations for any
    of the class templates defined in this subclause is undefined
    unless otherwise specified.


Implements also proposal in #93
Closes #229
2019-04-14 22:13:45 +02:00

106 lines
3.3 KiB
C++

//
// Copyright 2005-2007 Adobe Systems Incorporated
//
// Distributed under the Boost Software License, Version 1.0
// See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt
//
#ifdef _MSC_VER
//#pragma warning(disable : 4244) // conversion from 'gil::image<V,Alloc>::coord_t' to 'int', possible loss of data (visual studio compiler doesn't realize that the two types are the same)
#pragma warning(disable : 4503) // decorated name length exceeded, name was truncated
#endif
#include <boost/gil/extension/dynamic_image/dynamic_image_all.hpp>
#include <boost/test/unit_test.hpp>
#include <ios>
#include <iostream>
#include <fstream>
#include <map>
#include <string>
#include <type_traits>
#include <vector>
using namespace boost::gil;
using namespace std;
using namespace boost;
///////////////////////////////////////////////////////////////
std::size_t is_planar_impl( const std::size_t size_in_units
, const std::size_t channels_in_image
, std::true_type
)
{
return size_in_units * channels_in_image;
}
std::size_t is_planar_impl( const std::size_t size_in_units
, const std::size_t
, std::false_type
)
{
return size_in_units;
}
template< typename View >
std::size_t get_row_size_in_memunits( typename View::x_coord_t width)
{ // number of units per row
std::size_t size_in_memunits = width * memunit_step( typename View::x_iterator() );
return size_in_memunits;
}
template< typename View
, bool IsPlanar
>
std::size_t total_allocated_size_in_bytes( const typename View::point_t& dimensions )
{
using x_iterator = typename View::x_iterator;
// when value_type is a non-pixel, like int or float, num_channels< ... > doesn't work.
const std::size_t _channels_in_image = mp11::mp_eval_if< is_pixel< typename View::value_type >
, num_channels< View >
, std::integral_constant<int, 1>
>::type::value;
std::size_t size_in_units = is_planar_impl( get_row_size_in_memunits< View >( dimensions.x ) * dimensions.y
, _channels_in_image
, typename std::conditional< IsPlanar, std::true_type, std::false_type >::type()
);
// return the size rounded up to the nearest byte
std::size_t btm = byte_to_memunit< typename View::x_iterator >::value;
return ( size_in_units + btm - 1 )
/ btm;
}
BOOST_AUTO_TEST_SUITE(GIL_Tests)
BOOST_AUTO_TEST_CASE(recreate_image_test)
{
auto tasib_1 = total_allocated_size_in_bytes<rgb8_view_t, false>({640, 480});
auto tasib_2 = total_allocated_size_in_bytes<rgb8_view_t, false>({320, 200});
rgb8_image_t img( 640, 480 );
img.recreate( 320, 200 );
}
BOOST_AUTO_TEST_SUITE_END()
#if BOOST_WORKAROUND(BOOST_MSVC, >= 1400)
#pragma warning(push)
#pragma warning(disable:4127) //conditional expression is constant
#endif
#if BOOST_WORKAROUND(BOOST_MSVC, >= 1400)
#pragma warning(pop)
#endif