boost/signals2/slot.hpp
// Boost.Signals2 library
// Copyright Frank Mori Hess 2007-2008.
// Copyright Timmo Stange 2007.
// Copyright Douglas Gregor 2001-2004. Use, modification and
// distribution is subject to 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)
// For more information, see http://www.boost.org
#ifndef BOOST_SIGNALS2_SLOT_HPP
#define BOOST_SIGNALS2_SLOT_HPP
#include <boost/bind.hpp>
#include <boost/function.hpp>
#include <boost/preprocessor/repetition.hpp>
#include <boost/ref.hpp>
#include <boost/signals2/detail/signals_common.hpp>
#include <boost/signals2/detail/signals_common_macros.hpp>
#include <boost/signals2/detail/tracked_objects_visitor.hpp>
#include <boost/signals2/slot_base.hpp>
#include <boost/type_traits.hpp>
#include <boost/visit_each.hpp>
#include <boost/weak_ptr.hpp>
namespace boost
{
namespace signals2
{
namespace detail
{
// Get the slot so that it can be copied
template<typename F>
typename F::weak_signal_type
get_invocable_slot(const F &signal, signal_tag)
{ return typename F::weak_signal_type(signal); }
template<typename F>
const F&
get_invocable_slot(const F& f, reference_tag)
{ return f; }
template<typename F>
const F&
get_invocable_slot(const F& f, value_tag)
{ return f; }
// Determines the type of the slot - is it a signal, a reference to a
// slot or just a normal slot.
template<typename F>
typename get_slot_tag<F>::type
tag_type(const F&)
{
typedef typename get_slot_tag<F>::type
the_tag_type;
the_tag_type tag = the_tag_type();
return tag;
}
}
}
} // end namespace boost
#define BOOST_PP_ITERATION_LIMITS (0, BOOST_PP_INC(BOOST_SIGNALS2_MAX_ARGS))
#define BOOST_PP_FILENAME_1 <boost/signals2/detail/slot_template.hpp>
#include BOOST_PP_ITERATE()
namespace boost
{
namespace signals2
{
template<typename Signature,
typename SlotFunction = boost::function<Signature> >
class slot: public detail::slotN<function_traits<Signature>::arity,
Signature, SlotFunction>::type
{
private:
typedef typename detail::slotN<boost::function_traits<Signature>::arity,
Signature, SlotFunction>::type base_type;
public:
template<typename F>
slot(const F& f): base_type(f)
{}
// bind syntactic sugar
// const AN & aN
#define BOOST_SIGNALS2_SLOT_BINDING_ARG_DECL(z, n, data) \
const BOOST_PP_CAT(A, n) & BOOST_PP_CAT(a, n)
// template<typename F, typename A0, typename A1, ..., typename An-1> slot(...
#define BOOST_SIGNALS2_SLOT_BINDING_CONSTRUCTOR(z, n, data) \
template<typename F, BOOST_PP_ENUM_PARAMS(n, typename A)> \
slot(const F &f, BOOST_PP_ENUM(n, BOOST_SIGNALS2_SLOT_BINDING_ARG_DECL, ~)): \
base_type(f, BOOST_PP_ENUM_PARAMS(n, a)) \
{}
#define BOOST_SIGNALS2_SLOT_MAX_BINDING_ARGS 10
BOOST_PP_REPEAT_FROM_TO(1, BOOST_SIGNALS2_SLOT_MAX_BINDING_ARGS, BOOST_SIGNALS2_SLOT_BINDING_CONSTRUCTOR, ~)
#undef BOOST_SIGNALS2_SLOT_MAX_BINDING_ARGS
#undef BOOST_SIGNALS2_SLOT_BINDING_ARG_DECL
#undef BOOST_SIGNALS2_SLOT_BINDING_CONSTRUCTOR
};
} // namespace signals2
}
#endif // BOOST_SIGNALS2_SLOT_HPP