X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-sharp%2FClient.cs;h=b3815b32cb5d3120bacf2b83bad89c82ae5819bf;hb=fe8f5ec6f8e86c6eea88dd196fbcb60deeef0795;hp=40ca4119adc917d560913578c34d251aaab2223a;hpb=bd121fc9b9f6bdcd7074e4fb15b195ce0e491b5c;p=catta diff --git a/avahi-sharp/Client.cs b/avahi-sharp/Client.cs index 40ca411..b3815b3 100644 --- a/avahi-sharp/Client.cs +++ b/avahi-sharp/Client.cs @@ -1,5 +1,3 @@ -/* $Id$ */ - /*** This file is part of avahi. @@ -35,7 +33,7 @@ namespace Avahi Found, Failure } - + internal enum BrowserEvent { Added, Removed, @@ -70,7 +68,7 @@ namespace Avahi this.error = error; } } - + public enum Protocol { Unspecified = -1, IPv4 = 0, @@ -83,7 +81,7 @@ namespace Avahi Running, Collision } - + public enum ClientState { Registering = ServerState.Registering, Running = ServerState.Running, @@ -117,7 +115,7 @@ namespace Avahi IgnoreUserConfig = 1, NoFail = 2 } - + public class Client : IDisposable { private IntPtr handle; @@ -151,7 +149,7 @@ namespace Avahi [DllImport ("avahi-client")] private static extern int avahi_client_errno (IntPtr handle); - + [DllImport ("avahi-common")] private static extern IntPtr avahi_simple_poll_new (); @@ -192,7 +190,7 @@ namespace Avahi { get { return handle; } } - + public string Version { get { @@ -271,6 +269,7 @@ namespace Avahi throw new ClientException (error); thread = new Thread (PollLoop); + thread.IsBackground = true; thread.Start (); } @@ -287,9 +286,12 @@ namespace Avahi if (handle != IntPtr.Zero) { lock (this) { avahi_client_free (handle); + handle = IntPtr.Zero; + avahi_simple_poll_quit (spoll); + Monitor.Wait (this); + avahi_simple_poll_free (spoll); - handle = IntPtr.Zero; } } } @@ -322,7 +324,7 @@ namespace Avahi IntPtr namePtr = Stdlib.malloc ((ulong) len); IntPtr typePtr = Stdlib.malloc ((ulong) len); IntPtr domainPtr = Stdlib.malloc ((ulong) len); - + int ret = avahi_service_name_split (Utility.StringToBytes (service), namePtr, len, typePtr, len, domainPtr, len); @@ -330,7 +332,7 @@ namespace Avahi Utility.Free (namePtr); Utility.Free (typePtr); Utility.Free (domainPtr); - + name = null; type = null; domain = null; @@ -353,7 +355,7 @@ namespace Avahi if (error != ErrorCode.Ok) throw new ClientException (error); } - + private void OnClientCallback (IntPtr client, ClientState state, IntPtr userData) { if (StateChanged != null) @@ -371,6 +373,7 @@ namespace Avahi try { lock (this) { avahi_simple_poll_loop (spoll); + Monitor.Pulse (this); } } catch (Exception e) { Console.Error.WriteLine ("Error in avahi-sharp event loop: " + e);