gil/test/core/pixel/is_planar.cpp
Mateusz Łoskot 96df5442bc
Move tests of extensions inside test/ directory (#302)
Split header tests accordingly i.e. test core headers as part of
core tests, numeric extension headers as part of numeric tests, etc.

It extends the convention of sub-directories already established in
`include/boost/gil` directory. It is sensible to follow it in other
areas of the source tree (i.e. `test/`, `doc/` and `benchmark/`).

Another important reason to move the tests is to enable removal of
the top-level `Jamfile` with all its definitions of test-specific
requirements.
The top-level `Jamfile` is not advised, especially if it specifies
build requirements like C++ language version.
Those affect non-tests builds e.g. documentation, causing failures
during generation of HTML documentation (leads to missing docs).

(cherry picked from develop branch commit 4ed7701b47)
2019-09-26 11:43:13 +02:00

138 lines
3.7 KiB
C++

//
// Copyright 2019 Mateusz Loskot <mateusz at loskot dot net>
//
// 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
//
#include <boost/gil/pixel.hpp>
#include <boost/gil/planar_pixel_iterator.hpp>
#include <boost/gil/typedefs.hpp>
#include <boost/mp11.hpp>
namespace gil = boost::gil;
using namespace boost::mp11;
int main()
{
using non_planar_pixels = mp_list
<
gil::gray8_pixel_t,
gil::gray8c_pixel_t,
gil::gray8s_pixel_t,
gil::gray8sc_pixel_t,
gil::gray16_pixel_t,
gil::gray16c_pixel_t,
gil::gray16s_pixel_t,
gil::gray16sc_pixel_t,
gil::gray16_pixel_t,
gil::gray32_pixel_t,
gil::gray32c_pixel_t,
gil::gray32f_pixel_t,
gil::gray32fc_pixel_t,
gil::gray32s_pixel_t,
gil::gray32sc_pixel_t,
gil::bgr8_pixel_t,
gil::bgr8c_pixel_t,
gil::bgr8s_pixel_t,
gil::bgr8sc_pixel_t,
gil::bgr16_pixel_t,
gil::bgr16c_pixel_t,
gil::bgr16s_pixel_t,
gil::bgr16sc_pixel_t,
gil::bgr32_pixel_t,
gil::bgr32c_pixel_t,
gil::bgr32f_pixel_t,
gil::bgr32fc_pixel_t,
gil::bgr32s_pixel_t,
gil::bgr32sc_pixel_t,
gil::rgb8_pixel_t,
gil::rgb8c_pixel_t,
gil::rgb8s_pixel_t,
gil::rgb8sc_pixel_t,
gil::rgb16_pixel_t,
gil::rgb16c_pixel_t,
gil::rgb16s_pixel_t,
gil::rgb16sc_pixel_t,
gil::rgb32_pixel_t,
gil::rgb32c_pixel_t,
gil::rgb32f_pixel_t,
gil::rgb32fc_pixel_t,
gil::rgb32s_pixel_t,
gil::rgb32sc_pixel_t,
gil::abgr8_pixel_t,
gil::abgr8c_pixel_t,
gil::abgr8s_pixel_t,
gil::abgr8sc_pixel_t,
gil::abgr16_pixel_t,
gil::abgr16c_pixel_t,
gil::abgr16s_pixel_t,
gil::abgr16sc_pixel_t,
gil::abgr32_pixel_t,
gil::abgr32c_pixel_t,
gil::abgr32f_pixel_t,
gil::abgr32fc_pixel_t,
gil::abgr32s_pixel_t,
gil::abgr32sc_pixel_t,
gil::bgra8_pixel_t,
gil::bgra8c_pixel_t,
gil::bgra8s_pixel_t,
gil::bgra8sc_pixel_t,
gil::bgra16_pixel_t,
gil::bgra16c_pixel_t,
gil::bgra16s_pixel_t,
gil::bgra16sc_pixel_t,
gil::bgra32_pixel_t,
gil::bgra32c_pixel_t,
gil::bgra32f_pixel_t,
gil::bgra32fc_pixel_t,
gil::bgra32s_pixel_t,
gil::bgra32sc_pixel_t,
gil::cmyk8_pixel_t,
gil::cmyk8c_pixel_t,
gil::cmyk8s_pixel_t,
gil::cmyk8sc_pixel_t,
gil::cmyk16_pixel_t,
gil::cmyk16c_pixel_t,
gil::cmyk16s_pixel_t,
gil::cmyk16sc_pixel_t,
gil::cmyk32_pixel_t,
gil::cmyk32c_pixel_t,
gil::cmyk32f_pixel_t,
gil::cmyk32fc_pixel_t,
gil::cmyk32s_pixel_t,
gil::cmyk32sc_pixel_t,
gil::rgba8_pixel_t,
gil::rgba8c_pixel_t,
gil::rgba8s_pixel_t,
gil::rgba8sc_pixel_t,
gil::rgba16_pixel_t,
gil::rgba16c_pixel_t,
gil::rgba16s_pixel_t,
gil::rgba16sc_pixel_t,
gil::rgba32_pixel_t,
gil::rgba32c_pixel_t,
gil::rgba32f_pixel_t,
gil::rgba32fc_pixel_t,
gil::rgba32s_pixel_t,
gil::rgba32sc_pixel_t
>;
static_assert(
std::is_same
<
mp_all_of<non_planar_pixels, gil::is_planar>,
std::false_type
>::value,
"is_planar yields true for non-planar pixel type");
static_assert(
std::is_same
<
mp_none_of<non_planar_pixels, gil::is_planar>,
std::true_type
>::value,
"is_planar yields true for non-planar pixel type");
}