• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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)
4 
5 #include <boost/hana/assert.hpp>
6 #include <boost/hana/integral_constant.hpp>
7 #include <boost/hana/less.hpp>
8 #include <boost/hana/lexicographical_compare.hpp>
9 #include <boost/hana/tuple.hpp>
10 #include <boost/hana/type.hpp>
11 namespace hana = boost::hana;
12 
13 
main()14 int main() {
15     // works with elements whose `less` does not return a Constant
16     {
17         constexpr auto xs = hana::make_tuple(1, 2, 3, 4);
18         constexpr auto ys = hana::make_tuple(1, 6, 3, 4);
19         static_assert(hana::lexicographical_compare(xs, ys), "");
20     }
21 
22     // and with those that do
23     {
24         auto xs = hana::make_tuple(hana::int_c<1>, hana::int_c<2>, hana::int_c<3>);
25         auto ys = hana::make_tuple(hana::int_c<1>, hana::int_c<5>, hana::int_c<3>);
26         BOOST_HANA_CONSTANT_CHECK(hana::lexicographical_compare(xs, ys));
27     }
28 
29     // it also accepts a custom predicate
30     {
31         auto xs = hana::make_tuple(hana::type_c<int>, hana::type_c<char>, hana::type_c<void*>);
32         auto ys = hana::make_tuple(hana::type_c<int>, hana::type_c<long>, hana::type_c<void*>);
33         BOOST_HANA_CONSTANT_CHECK(
34             hana::lexicographical_compare(xs, ys, [](auto t, auto u) {
35                 return hana::sizeof_(t) < hana::sizeof_(u);
36             })
37         );
38     }
39 }
40