summaryrefslogtreecommitdiffstats
path: root/avahi-sharp/HostNameResolver.cs
diff options
context:
space:
mode:
authorJames Willcox <snopr@snorp.net>2005-09-26 06:57:41 +0000
committerJames Willcox <snopr@snorp.net>2005-09-26 06:57:41 +0000
commit6d952319b1a15b439150e7f5911b12e7fc204b69 (patch)
tree9b09aa181c45e416ca54f93a92ca87afb6d64a12 /avahi-sharp/HostNameResolver.cs
parenta4c2edcece605452c4d72da36b8c39da5e514314 (diff)
add base class for resolvers, and add some missing events there
git-svn-id: file:///home/lennart/svn/public/avahi/trunk@636 941a03a8-eaeb-0310-b9a0-b1bbd8fe43fe
Diffstat (limited to 'avahi-sharp/HostNameResolver.cs')
-rw-r--r--avahi-sharp/HostNameResolver.cs12
1 files changed, 9 insertions, 3 deletions
diff --git a/avahi-sharp/HostNameResolver.cs b/avahi-sharp/HostNameResolver.cs
index fad5d77..44febcd 100644
--- a/avahi-sharp/HostNameResolver.cs
+++ b/avahi-sharp/HostNameResolver.cs
@@ -32,7 +32,7 @@ namespace Avahi
ResolverEvent revent, IntPtr hostname, IntPtr address,
LookupResultFlags flags, IntPtr userdata);
- public class HostNameResolver : IDisposable
+ public class HostNameResolver : ResolverBase, IDisposable
{
private IntPtr handle;
private Client client;
@@ -151,18 +151,24 @@ namespace Avahi
ResolverEvent revent, IntPtr hostname, IntPtr address,
LookupResultFlags flags, IntPtr userdata)
{
- if (revent == ResolverEvent.Found) {
+ switch (revent) {
+ case ResolverEvent.Found:
currentAddress = Utility.PtrToAddress (address);
currentHost = Utility.PtrToString (hostname);
foreach (HostAddressHandler handler in foundListeners)
handler (this, currentHost, currentAddress);
- } else {
+ break;
+ case ResolverEvent.Timeout:
currentAddress = null;
currentHost = null;
foreach (EventHandler handler in timeoutListeners)
handler (this, new EventArgs ());
+ break;
+ default:
+ EmitResolverEvent (revent);
+ break;
}
}
}