1 // Copyright Louis Dionne 2013-2017
2 // Distributed under the Boost Software License, Version 1.0.
3 // (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt)
5 #ifndef BOOST_HANA_TEST_LAWS_GROUP_HPP
6 #define BOOST_HANA_TEST_LAWS_GROUP_HPP
8 #include <boost/hana/assert.hpp>
9 #include <boost/hana/bool.hpp>
10 #include <boost/hana/concept/comparable.hpp>
11 #include <boost/hana/core/when.hpp>
12 #include <boost/hana/concept/group.hpp>
13 #include <boost/hana/lazy.hpp>
15 #include <laws/base.hpp>
18 namespace boost { namespace hana { namespace test {
19 template <typename G, typename = when<true>>
20 struct TestGroup : TestGroup<G, laws> {
21 using TestGroup<G, laws>::TestGroup;
25 struct TestGroup<G, laws> {
26 template <typename Xs>
28 hana::for_each(xs, [](auto x) {
29 static_assert(Group<decltype(x)>{}, "");
32 #ifdef BOOST_HANA_WORKAROUND_MSVC_DECLTYPEAUTO_RETURNTYPE_662735
33 zero<G>(); // force adding zero<G>'s member function to pending temploid list
36 foreach2(xs, [](auto x, auto y) {
39 BOOST_HANA_CHECK(hana::equal(
40 hana::plus(x, hana::negate(x)),
45 BOOST_HANA_CHECK(hana::equal(
46 hana::plus(hana::negate(x), x),
50 // default definition of minus
51 BOOST_HANA_CHECK(hana::equal(
53 hana::plus(x, hana::negate(y))
56 BOOST_HANA_CHECK(hana::equal(
58 hana::plus(y, hana::negate(x))
61 // default definition of negate
62 BOOST_HANA_CHECK(hana::equal(
63 hana::negate(hana::negate(x)),
71 struct TestGroup<C, when<Constant<C>::value>>
74 template <typename Xs>
75 TestGroup(Xs xs) : TestGroup<C, laws>{xs} {
76 foreach2(xs, [](auto x, auto y) {
78 BOOST_HANA_CHECK(hana::equal(
79 hana::negate(hana::value(x)),
80 hana::value(hana::negate(x))
83 BOOST_HANA_CHECK(hana::equal(
84 hana::minus(hana::value(x), hana::value(y)),
85 hana::value(hana::minus(x, y))
91 }}} // end namespace boost::hana::test
93 #endif // !BOOST_HANA_TEST_LAWS_GROUP_HPP