mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-10-26 00:02:44 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			37 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Text;
 | |
| 
 | |
| namespace Rssdp
 | |
| {
 | |
| 	/// <summary>
 | |
| 	/// Extensions for <see cref="SsdpDevice"/> and derived types.
 | |
| 	/// </summary>
 | |
| 	public static class SsdpDeviceExtensions
 | |
| 	{
 | |
| 
 | |
| 		/// <summary>
 | |
| 		/// Returns the root device associated with a device instance derived from <see cref="SsdpDevice"/>.
 | |
| 		/// </summary>
 | |
| 		/// <param name="device">The device instance to find the <see cref="SsdpRootDevice"/> for.</param>
 | |
| 		/// <remarks>
 | |
| 		/// <para>The <paramref name="device"/> must be or inherit from <see cref="SsdpRootDevice"/> or <see cref="SsdpEmbeddedDevice"/>, otherwise an <see cref="System.InvalidCastException"/> will occur.</para>
 | |
| 		/// <para>May return null if the <paramref name="device"/> instance is an embedded device not yet associated with a <see cref="SsdpRootDevice"/> instance yet.</para>
 | |
| 		/// <para>If <paramref name="device"/> is an instance of <see cref="SsdpRootDevice"/> (or derives from it), returns the same instance cast to <see cref="SsdpRootDevice"/>.</para>
 | |
| 		/// </remarks>
 | |
| 		/// <returns>The <see cref="SsdpRootDevice"/> instance associated with the device instance specified, or null otherwise.</returns>
 | |
| 		/// <exception cref="System.ArgumentNullException">Thrown if <paramref name="device"/> is null.</exception>
 | |
| 		/// <exception cref="System.InvalidCastException">Thrown if <paramref name="device"/> is not an instance of or dervied from either <see cref="SsdpRootDevice"/> or <see cref="SsdpEmbeddedDevice"/>.</exception>
 | |
| 		public static SsdpRootDevice ToRootDevice(this SsdpDevice device)
 | |
| 		{
 | |
| 			if (device == null) throw new System.ArgumentNullException("device");
 | |
| 
 | |
| 			var rootDevice = device as SsdpRootDevice;
 | |
| 			if (rootDevice == null)
 | |
| 				rootDevice = ((SsdpEmbeddedDevice)device).RootDevice;
 | |
| 
 | |
| 			return rootDevice;
 | |
| 		}
 | |
| 	}
 | |
| }
 |