summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/hana/test/_include/laws/product.hpp
blob: 18e5a15d25dc0e22838abffe590fd571a945249a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// Copyright Louis Dionne 2013-2017
// Distributed under the Boost Software License, Version 1.0.
// (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt)

#ifndef BOOST_HANA_TEST_LAWS_PRODUCT_HPP
#define BOOST_HANA_TEST_LAWS_PRODUCT_HPP

#include <boost/hana/assert.hpp>
#include <boost/hana/concept/product.hpp>
#include <boost/hana/core/make.hpp>
#include <boost/hana/core/when.hpp>
#include <boost/hana/equal.hpp>
#include <boost/hana/first.hpp>
#include <boost/hana/second.hpp>

#include <laws/base.hpp>


namespace boost { namespace hana { namespace test {
    template <typename P, typename = when<true>>
    struct TestProduct : TestProduct<P, laws> {
        using TestProduct<P, laws>::TestProduct;
    };

    template <typename P>
    struct TestProduct<P, laws> {
        template <typename Elements>
        TestProduct(Elements elements) {
            foreach2(elements, [](auto x, auto y) {
                static_assert(Product<decltype(hana::make<P>(x, y))>{}, "");

                BOOST_HANA_CHECK(hana::equal(
                    hana::first(hana::make<P>(x, y)),
                    x
                ));

                BOOST_HANA_CHECK(hana::equal(
                    hana::second(hana::make<P>(x, y)),
                    y
                ));
            });
        }
    };
}}} // end namespace boost::hana::test

#endif // !BOOST_HANA_TEST_LAWS_PRODUCT_HPP