From 0242b82152e7d1bd529a2248e97a7db0c5b6e4be Mon Sep 17 00:00:00 2001 From: Joe Shaw Date: Sat, 12 Feb 2005 00:51:33 +0000 Subject: 2005-02-11 Joe Shaw * mono/Connection.cs: The unpredictability of finalizers in mono prevents us from deterministically disconnecting the filters from the Service class's finalizer, so move tracking of filters and matches here. Add API for that. * mono/Service.cs: Remove the code, add code which calls the methods now on the Connection class. --- mono/Service.cs | 50 +++----------------------------------------------- 1 file changed, 3 insertions(+), 47 deletions(-) (limited to 'mono/Service.cs') diff --git a/mono/Service.cs b/mono/Service.cs index b5547961..4280c6b3 100644 --- a/mono/Service.cs +++ b/mono/Service.cs @@ -14,9 +14,6 @@ namespace DBus private string name; private bool local = false; private Hashtable registeredHandlers = new Hashtable(); - private delegate int DBusHandleMessageFunction(IntPtr rawConnection, - IntPtr rawMessage, - IntPtr userData); private DBusHandleMessageFunction filterCalled; public delegate void SignalCalledHandler(Signal signal); public event SignalCalledHandler SignalCalled; @@ -50,12 +47,6 @@ namespace DBus this.local = true; } - ~Service () - { - if (this.filterCalled != null) - RemoveFilter (); - } - public static bool HasOwner(Connection connection, string name) { Error error = new Error(); @@ -116,23 +107,9 @@ namespace DBus { // Setup the filter function this.filterCalled = new DBusHandleMessageFunction(Service_FilterCalled); - if (!dbus_connection_add_filter(Connection.RawConnection, - this.filterCalled, - IntPtr.Zero, - IntPtr.Zero)) - throw new OutOfMemoryException(); - - dbus_bus_add_match(connection.RawConnection, MatchRule, IntPtr.Zero); - } - - private void RemoveFilter() - { - dbus_connection_remove_filter (Connection.RawConnection, - this.filterCalled, - IntPtr.Zero); - this.filterCalled = null; - - dbus_bus_remove_match (connection.RawConnection, MatchRule, IntPtr.Zero); + Connection.AddFilter (this.filterCalled); + // Add a match for signals. FIXME: Can we filter the service? + Connection.AddMatch ("type='signal'"); } private int Service_FilterCalled(IntPtr rawConnection, @@ -210,26 +187,5 @@ namespace DBus string serviceName, ref Error error); - [DllImport("dbus-1")] - private extern static bool dbus_connection_add_filter(IntPtr rawConnection, - DBusHandleMessageFunction filter, - IntPtr userData, - IntPtr freeData); - - [DllImport("dbus-1")] - private extern static void dbus_connection_remove_filter(IntPtr rawConnection, - DBusHandleMessageFunction filter, - IntPtr userData); - - [DllImport("dbus-1")] - private extern static void dbus_bus_add_match(IntPtr rawConnection, - string rule, - IntPtr erro); - - [DllImport("dbus-1")] - private extern static void dbus_bus_remove_match(IntPtr rawConnection, - string rule, - IntPtr erro); - } } -- cgit