51 lines
1.5 KiB
C++
51 lines
1.5 KiB
C++
/*!
|
|
@file
|
|
Forward declares `boost::hana::is_disjoint`.
|
|
|
|
@copyright Louis Dionne 2013-2016
|
|
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_FWD_IS_DISJOINT_HPP
|
|
#define BOOST_HANA_FWD_IS_DISJOINT_HPP
|
|
|
|
#include <boost/hana/config.hpp>
|
|
#include <boost/hana/core/when.hpp>
|
|
|
|
|
|
BOOST_HANA_NAMESPACE_BEGIN
|
|
//! Returns whether two `Searchable`s are disjoint.
|
|
//! @ingroup group-Searchable
|
|
//!
|
|
//! Given two `Searchable`s `xs` and `ys`, `is_disjoint` returns a
|
|
//! `Logical` representing whether the keys in `xs` are disjoint from
|
|
//! the keys in `ys`, i.e. whether both structures have no keys in common.
|
|
//!
|
|
//!
|
|
//! @param xs, ys
|
|
//! Two `Searchable`s to test for disjointness.
|
|
//!
|
|
//!
|
|
//! Example
|
|
//! -------
|
|
//! @include example/is_disjoint.cpp
|
|
#ifdef BOOST_HANA_DOXYGEN_INVOKED
|
|
constexpr auto is_disjoint = [](auto const& xs, auto const& ys) {
|
|
return tag-dispatched;
|
|
};
|
|
#else
|
|
template <typename S1, typename S2, typename = void>
|
|
struct is_disjoint_impl : is_disjoint_impl<S1, S2, when<true>> { };
|
|
|
|
struct is_disjoint_t {
|
|
template <typename Xs, typename Ys>
|
|
constexpr auto operator()(Xs&& xs, Ys&& ys) const;
|
|
};
|
|
|
|
constexpr is_disjoint_t is_disjoint{};
|
|
#endif
|
|
BOOST_HANA_NAMESPACE_END
|
|
|
|
#endif // !BOOST_HANA_FWD_IS_DISJOINT_HPP
|