/* signalproxy.cc * * Copyright (C) 2002 The gtkmm Development Team * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #include #include namespace Glib { // SignalProxyBase implementation: SignalProxyBase::SignalProxyBase(Glib::ObjectBase* obj) : obj_ (obj) {} // SignalProxyNormal implementation: SignalProxyNormal::SignalProxyNormal(Glib::ObjectBase* obj, const SignalProxyInfo* info) : SignalProxyBase (obj), info_ (info) {} SignalProxyNormal::~SignalProxyNormal() {} sigc::slot_base& SignalProxyNormal::connect_(const sigc::slot_base& slot, bool after) { return connect_impl_(info_->callback, slot, after); } sigc::slot_base& SignalProxyNormal::connect_notify_(const sigc::slot_base& slot, bool after) { return connect_impl_(info_->notify_callback, slot, after); } sigc::slot_base& SignalProxyNormal::connect_impl_(GCallback callback, const sigc::slot_base& slot, bool after) { // create a proxy to hold our connection info SignalProxyConnectionNode *const pConnectionNode = new SignalProxyConnectionNode(slot, obj_->gobj()); // connect it to glib // pConnectionNode will be passed in the data argument to the callback. pConnectionNode->connection_id_ = g_signal_connect_data( obj_->gobj(), info_->signal_name, callback, pConnectionNode, &SignalProxyConnectionNode::destroy_notify_handler, static_cast((after) ? G_CONNECT_AFTER : 0)); return pConnectionNode->slot_; } void SignalProxyNormal::emission_stop() { g_signal_stop_emission_by_name(obj_->gobj(), info_->signal_name); } // static void SignalProxyNormal::slot0_void_callback(GObject* self, void* data) { // Do not try to call a signal on a disassociated wrapper. if(Glib::ObjectBase::_get_current_wrapper(self)) { try { if(sigc::slot_base *const slot = data_to_slot(data)) (*static_cast*>(slot))(); } catch(...) { Glib::exception_handlers_invoke(); } } } // SignalProxyDetailed implementation: SignalProxyDetailed::SignalProxyDetailed(Glib::ObjectBase* obj, const SignalProxyInfo* info, const Glib::ustring& detail_name) : SignalProxyBase (obj), info_ (info), detailed_name_ (Glib::ustring(info->signal_name) + (detail_name.empty() ? Glib::ustring() : ("::" + detail_name))) {} SignalProxyDetailed::~SignalProxyDetailed() {} sigc::slot_base& SignalProxyDetailed::connect_impl_(bool notify, const sigc::slot_base& slot, bool after) { // create a proxy to hold our connection info SignalProxyConnectionNode *const pConnectionNode = new SignalProxyConnectionNode(slot, obj_->gobj()); // connect it to glib // pConnectionNode will be passed in the data argument to the callback. pConnectionNode->connection_id_ = g_signal_connect_data( obj_->gobj(), detailed_name_.c_str(), notify ? info_->notify_callback : info_->callback, pConnectionNode, &SignalProxyConnectionNode::destroy_notify_handler, static_cast(after ? G_CONNECT_AFTER : 0)); return pConnectionNode->slot_; } void SignalProxyDetailed::emission_stop() { g_signal_stop_emission_by_name(obj_->gobj(), detailed_name_.c_str()); } } // namespace Glib