X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-sharp%2FAvahiTest.cs;h=6ccfd57a46b8f036ba84b0a4e1476139150b5440;hb=468519681b09f00851e1d4dd658b939e4e938cf6;hp=0fac04b09c320a709b544bb1725e04999dd1f15f;hpb=84a9392791c574c56ca148157b8b951851208398;p=catta diff --git a/avahi-sharp/AvahiTest.cs b/avahi-sharp/AvahiTest.cs index 0fac04b..6ccfd57 100644 --- a/avahi-sharp/AvahiTest.cs +++ b/avahi-sharp/AvahiTest.cs @@ -1,5 +1,3 @@ -/* $Id$ */ - /*** This file is part of avahi. @@ -32,13 +30,17 @@ public class AvahiTest { public static void Main () { client = new Client (); + Console.WriteLine ("joined service name: " + Client.JoinServiceName ("FooBar", "_foo", "local")); + EntryGroup eg = new EntryGroup (client); eg.StateChanged += OnEntryGroupChanged; - eg.AddService ("foobar2", "_daap._tcp", client.DomainName, - 444, new string[] { "foo", "bar", "baz" }); + eg.AddService ("foobar2", "_dingdong._tcp", client.DomainName, + 444, new string[] { "foo=stuff", "bar=stuff2", "baz=stuff3" }); eg.Commit (); + BrowseServiceTypes ("local"); Console.WriteLine ("Press enter to quit"); Console.ReadLine (); + client.Dispose (); } private static void OnEntryGroupChanged (object o, EntryGroupStateArgs args) @@ -47,7 +49,7 @@ public class AvahiTest { if (args.State == EntryGroupState.Established) { DomainBrowser browser = new DomainBrowser (client); objects.Add (browser); - + browser.DomainAdded += OnDomainAdded; } } @@ -55,14 +57,14 @@ public class AvahiTest { private static void OnDomainAdded (object o, DomainInfoArgs args) { Console.WriteLine ("Got domain added: " + args.Domain.Domain); - BrowseServiceTypes (args.Domain.Domain); + // BrowseServiceTypes (args.Domain.Domain); } private static void BrowseServiceTypes (string domain) { ServiceTypeBrowser stb = new ServiceTypeBrowser (client, domain); objects.Add (stb); - + stb.CacheExhausted += OnCacheExhausted; stb.ServiceTypeAdded += OnServiceTypeAdded; } @@ -77,7 +79,7 @@ public class AvahiTest { Console.WriteLine ("Got service type: " + args.ServiceType.ServiceType); ServiceBrowser sb = new ServiceBrowser (client, args.ServiceType.ServiceType, args.ServiceType.Domain); objects.Add (sb); - + sb.ServiceAdded += OnServiceAdded; } @@ -92,25 +94,32 @@ public class AvahiTest { private static void OnServiceResolved (object o, ServiceInfoArgs args) { objects.Remove (o); - + Console.WriteLine ("Service '{0}' at {1}:{2}", args.Service.Name, args.Service.HostName, args.Service.Port); foreach (byte[] bytes in args.Service.Text) { Console.WriteLine ("Text: " + Encoding.UTF8.GetString (bytes)); } + AddressResolver ar = new AddressResolver (client, args.Service.Address); objects.Add (ar); - + ar.Found += OnAddressResolved; + ar.Failed += OnAddressResolverFailed; + } + + private static void OnAddressResolverFailed (object o, ErrorCodeArgs args) + { + Console.WriteLine ("Failed to resolve '{0}': {1}", (o as AddressResolver).Address, args.ErrorCode); } private static void OnAddressResolved (object o, HostAddressArgs args) { objects.Remove (o); - + Console.WriteLine ("Resolved {0} to {1}", args.Address, args.Host); HostNameResolver hr = new HostNameResolver (client, args.Host); objects.Add (hr); - + hr.Found += OnHostNameResolved; }