note description: "[ Base interface for connecting observers to an interface, to be notified when an event is published on the inheriting interface. The default implementation is {EVENT_OBSERVER_CONNECTION}. ]" legal: "See notice at end of class." status: "See notice at end of class."; date: "$Date$"; revision: "$Revision $" deferred class EVENT_CONNECTION_I [G -> EVENT_OBSERVER_I, I -> USABLE_I] inherit USABLE_I feature -- Status report is_connected (a_observer: G): BOOLEAN -- Determines if an event handler interface has already been connected to Current. -- -- `a_observer': The event handler interface to test for an establish connection. -- `Result': True if the event handler interface has already been connected, False otherwise. require a_observer_attached: a_observer /= Void deferred end is_valid_connection (a_observer: EVENT_OBSERVER_I): BOOLEAN -- Determines is an observer can be used as a valid connection for Current. -- -- `a_observer': The observer event connection to determin validity for. -- `Result': True if the observer represents a valid connection; False otherwise. require a_observer_attached: a_observer /= Void do Result := ((attached {USABLE_I} a_observer as l_usable) implies l_usable.is_interface_usable) and then (attached {G} a_observer) ensure a_observer_is_interface_usable: Result implies ((attached {USABLE_I} a_observer as l_usable) implies l_usable.is_interface_usable) a_observer_conforms: Result implies (attached {G} a_observer) end feature -- Event connection connect_events (a_observer: G) -- Connects event handler interface to Current. -- -- `a_observer': Event handler interface to connection to current. require is_interface_usable: is_interface_usable a_observer_attached: a_observer /= Void a_observer_is_valid_connection: is_valid_connection (a_observer) not_a_observer_is_connected: not is_connected (a_observer) deferred ensure a_observer_is_connected: is_connected (a_observer) end disconnect_events (a_observer: G) -- Connects event handler interface from Current. -- -- `a_observer': Event handler interface to disconnection from current. require is_interface_usable: is_interface_usable a_observer_attached: a_observer /= Void a_observer_is_connected: is_connected (a_observer) deferred ensure not_a_observer_is_connected: not is_connected (a_observer) end ;note copyright: "Copyright (c) 1984-2009, Eiffel Software" license: "GPL version 2 (see http://www.eiffel.com/licensing/gpl.txt)" licensing_options: "http://www.eiffel.com/licensing" copying: "[ This file is part of Eiffel Software's Eiffel Development Environment. Eiffel Software's Eiffel Development Environment is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2 of the License (available at the URL listed under "license" above). Eiffel Software's Eiffel Development Environment 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 General Public License for more details. You should have received a copy of the GNU General Public License along with Eiffel Software's Eiffel Development Environment; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA ]" source: "[ Eiffel Software 5949 Hollister Ave., Goleta, CA 93117 USA Telephone 805-685-1006, Fax 805-685-6869 Website http://www.eiffel.com Customer support http://support.eiffel.com ]" end