X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=boost%2Fboost%2Fsignals%2Fslot.hpp;h=bbf18480106f0551eb2a5601574fe3dafe7f7ec0;hb=ebf6773c50989372bf1a4d6a3ba66673634e65ff;hp=a4c48835d275347b431d2e115485dae1459b9cdb;hpb=786216c0899498434cab9f33780f9c178a0a4006;p=lyx.git diff --git a/boost/boost/signals/slot.hpp b/boost/boost/signals/slot.hpp index a4c48835d2..bbf1848010 100644 --- a/boost/boost/signals/slot.hpp +++ b/boost/boost/signals/slot.hpp @@ -1,6 +1,6 @@ // Boost.Signals library -// Copyright Doug Gregor 2001-2003. Use, modification and +// 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) @@ -14,6 +14,7 @@ #include #include #include +#include #include #ifdef BOOST_HAS_ABI_HEADERS @@ -28,20 +29,26 @@ namespace boost { // friends to make this private (as it otherwise should be). We can't // name all of them because we don't know how many there are. public: + struct data_t { + std::vector bound_objects; + connection watch_bound_objects; + }; + shared_ptr get_data() const { return data; } + // Get the set of bound objects std::vector& get_bound_objects() const - { return bound_objects; } + { return data->bound_objects; } // Determine if this slot is still "active", i.e., all of the bound // objects still exist - bool is_active() const { return watch_bound_objects.connected(); } + bool is_active() const + { return data->watch_bound_objects.connected(); } protected: // Create a connection for this slot void create_connection(); - mutable std::vector bound_objects; - connection watch_bound_objects; + shared_ptr data; private: static void bound_object_destructed(void*, void*) {} @@ -96,17 +103,24 @@ namespace boost { template class slot : public BOOST_SIGNALS_NAMESPACE::detail::slot_base { + typedef BOOST_SIGNALS_NAMESPACE::detail::slot_base inherited; + typedef typename inherited::data_t data_t; + public: template slot(const F& f) : slot_function(BOOST_SIGNALS_NAMESPACE::get_invocable_slot(f, BOOST_SIGNALS_NAMESPACE::tag_type(f))) { + this->data.reset(new data_t); + // Visit each of the bound objects and store them for later use // An exception thrown here will allow the basic_connection to be // destroyed when this goes out of scope, and no other connections // have been made. - BOOST_SIGNALS_NAMESPACE::detail::bound_objects_visitor do_bind(bound_objects); - visit_each(do_bind, BOOST_SIGNALS_NAMESPACE::get_inspectable_slot(f, BOOST_SIGNALS_NAMESPACE::tag_type(f))); - + BOOST_SIGNALS_NAMESPACE::detail::bound_objects_visitor + do_bind(this->data->bound_objects); + visit_each(do_bind, + BOOST_SIGNALS_NAMESPACE::get_inspectable_slot + (f, BOOST_SIGNALS_NAMESPACE::tag_type(f))); create_connection(); } @@ -114,6 +128,7 @@ namespace boost { template slot(F* f) : slot_function(f) { + this->data.reset(new data_t); create_connection(); } #endif // __BORLANDC__ @@ -125,6 +140,8 @@ namespace boost { // Get the slot function to call the actual slot const SlotFunction& get_slot_function() const { return slot_function; } + void release() const { data->watch_bound_objects.set_controlling(false); } + private: slot(); // no default constructor slot& operator=(const slot&); // no assignment operator