mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-10-30 18:22:48 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Text;
 | |
| 
 | |
| namespace Rssdp.Infrastructure
 | |
| {
 | |
|     /// <summary>
 | |
|     /// Correctly implements the <see cref="IDisposable"/> interface and pattern for an object containing only managed resources, and adds a few common niceties not on the interface such as an <see cref="IsDisposed"/> property.
 | |
|     /// </summary>
 | |
|     public abstract class DisposableManagedObjectBase : IDisposable
 | |
|     {
 | |
|         /// <summary>
 | |
|         /// Override this method and dispose any objects you own the lifetime of if disposing is true;
 | |
|         /// </summary>
 | |
|         /// <param name="disposing">True if managed objects should be disposed, if false, only unmanaged resources should be released.</param>
 | |
|         protected abstract void Dispose(bool disposing);
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Throws and <see cref="ObjectDisposedException"/> if the <see cref="IsDisposed"/> property is true.
 | |
|         /// </summary>
 | |
|         /// <seealso cref="IsDisposed"/>
 | |
|         /// <exception cref="ObjectDisposedException">Thrown if the <see cref="IsDisposed"/> property is true.</exception>
 | |
|         /// <seealso cref="Dispose()"/>
 | |
|         protected virtual void ThrowIfDisposed()
 | |
|         {
 | |
|             if (this.IsDisposed)
 | |
|             {
 | |
|                 throw new ObjectDisposedException(this.GetType().FullName);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Sets or returns a boolean indicating whether or not this instance has been disposed.
 | |
|         /// </summary>
 | |
|         /// <seealso cref="Dispose()"/>
 | |
|         public bool IsDisposed
 | |
|         {
 | |
|             get;
 | |
|             private set;
 | |
|         }
 | |
| 
 | |
|         public string BuildMessage(string header, Dictionary<string, string> values)
 | |
|         {
 | |
|             var builder = new StringBuilder();
 | |
| 
 | |
|             const string ArgFormat = "{0}: {1}\r\n";
 | |
| 
 | |
|             builder.AppendFormat("{0}\r\n", header);
 | |
| 
 | |
|             foreach (var pair in values)
 | |
|             {
 | |
|                 builder.AppendFormat(ArgFormat, pair.Key, pair.Value);
 | |
|             }
 | |
| 
 | |
|             builder.Append("\r\n");
 | |
| 
 | |
|             return builder.ToString();
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Disposes this object instance and all internally managed resources.
 | |
|         /// </summary>
 | |
|         /// <remarks>
 | |
|         /// <para>Sets the <see cref="IsDisposed"/> property to true. Does not explicitly throw an exception if called multiple times, but makes no promises about behavior of derived classes.</para>
 | |
|         /// </remarks>
 | |
|         /// <seealso cref="IsDisposed"/>
 | |
|         [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Design", "CA1063:ImplementIDisposableCorrectly", Justification = "We do exactly as asked, but CA doesn't seem to like us also setting the IsDisposed property. Too bad, it's a good idea and shouldn't cause an exception or anything likely to interfere with the dispose process.")]
 | |
|         public void Dispose()
 | |
|         {
 | |
|             IsDisposed = true;
 | |
| 
 | |
|             Dispose(true);
 | |
|         }
 | |
|     }
 | |
| }
 |