| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 | using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;namespace Rssdp{	/// <summary>	/// Event arguments for the <see cref="Rssdp.Infrastructure.SsdpDeviceLocatorBase.DeviceUnavailable"/> event.	/// </summary>	public sealed class DeviceUnavailableEventArgs : EventArgs	{		#region Fields		private readonly DiscoveredSsdpDevice _DiscoveredDevice;		private readonly bool _Expired;		#endregion		#region Constructors		/// <summary>		/// Full constructor.		/// </summary>		/// <param name="discoveredDevice">A <see cref="DiscoveredSsdpDevice"/> instance representing the device that has become unavailable.</param>		/// <param name="expired">A boolean value indicating whether this device is unavailable because it expired, or because it explicitly sent a byebye notification.. See <see cref="Expired"/> for more detail.</param>		/// <exception cref="System.ArgumentNullException">Thrown if the <paramref name="discoveredDevice"/> parameter is null.</exception>		public DeviceUnavailableEventArgs(DiscoveredSsdpDevice discoveredDevice, bool expired) 		{			if (discoveredDevice == null) throw new ArgumentNullException("discoveredDevice");			_DiscoveredDevice = discoveredDevice;			_Expired = expired;		}		#endregion		#region Public Properties		/// <summary>		/// Returns true if the device is considered unavailable because it's cached information expired before a new alive notification or search result was received. Returns false if the device is unavailable because it sent an explicit notification of it's unavailability.		/// </summary>		public bool Expired		{			get { return _Expired; }		}		/// <summary>		/// A reference to a <see cref="Rssdp.DiscoveredSsdpDevice"/> instance containing the discovery details of the removed device.		/// </summary>		public DiscoveredSsdpDevice DiscoveredDevice		{			get { return _DiscoveredDevice; }		} 		#endregion	}}
 |