mirror of https://github.com/icsharpcode/ILSpy.git
				
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							101 lines
						
					
					
						
							3.8 KiB
						
					
					
				
			
		
		
	
	
							101 lines
						
					
					
						
							3.8 KiB
						
					
					
				// Copyright (c) 2010-2013 AlphaSierraPapa for the SharpDevelop Team | 
						|
//  | 
						|
// Permission is hereby granted, free of charge, to any person obtaining a copy of this | 
						|
// software and associated documentation files (the "Software"), to deal in the Software | 
						|
// without restriction, including without limitation the rights to use, copy, modify, merge, | 
						|
// publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons | 
						|
// to whom the Software is furnished to do so, subject to the following conditions: | 
						|
//  | 
						|
// The above copyright notice and this permission notice shall be included in all copies or | 
						|
// substantial portions of the Software. | 
						|
//  | 
						|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, | 
						|
// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR | 
						|
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE | 
						|
// FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR | 
						|
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 
						|
// DEALINGS IN THE SOFTWARE. | 
						|
 | 
						|
using System.Collections.Generic; | 
						|
 | 
						|
namespace ICSharpCode.Decompiler.TypeSystem | 
						|
{ | 
						|
	/// <summary> | 
						|
	/// Provider used for interning. | 
						|
	/// </summary> | 
						|
	/// <remarks> | 
						|
	/// A simple IInterningProvider implementation could use 3 dictionaries: | 
						|
	///  1. using value equality comparer (for certain types known to implement value equality, e.g. string and IType) | 
						|
	///  2. using comparer that calls into ISupportsInterning (for types implementing ISupportsInterning) | 
						|
	///  3. list comparer (for InternList method) | 
						|
	///  | 
						|
	/// On the first Intern()-call, the provider tells the object to prepare for interning (ISupportsInterning.PrepareForInterning) | 
						|
	/// and stores it into a dictionary. On further Intern() calls, the original object is returned for all equal objects. | 
						|
	/// This allows reducing the memory usage by using a single object instance where possible. | 
						|
	///  | 
						|
	/// Interning provider implementations could also use the interning logic for different purposes: | 
						|
	/// for example, it could be used to determine which objects are used jointly between multiple type definitions | 
						|
	/// and which are used only within a single type definition. Then a persistent file format could be organized so | 
						|
	/// that shared objects are loaded only once, yet non-shared objects get loaded lazily together with the class. | 
						|
	/// </remarks> | 
						|
	public abstract class InterningProvider | 
						|
	{ | 
						|
		public static readonly InterningProvider Dummy = new DummyInterningProvider(); | 
						|
		 | 
						|
		/// <summary> | 
						|
		/// Interns the specified object. | 
						|
		///  | 
						|
		/// If the object is freezable, it will be frozen. | 
						|
		/// </summary> | 
						|
		public abstract ISupportsInterning Intern(ISupportsInterning obj); | 
						|
		 | 
						|
		/// <summary> | 
						|
		/// Interns the specified object. | 
						|
		///  | 
						|
		/// If the object is freezable, it will be frozen. | 
						|
		/// </summary> | 
						|
		public T Intern<T>(T obj) where T : class, ISupportsInterning | 
						|
		{ | 
						|
			ISupportsInterning input = obj; | 
						|
			return (T)Intern(input); | 
						|
		} | 
						|
		 | 
						|
		/// <summary> | 
						|
		/// Interns the specified string. | 
						|
		/// </summary> | 
						|
		public abstract string Intern(string text); | 
						|
		 | 
						|
		/// <summary> | 
						|
		/// Inters a boxed value type. | 
						|
		/// </summary> | 
						|
		public abstract object InternValue(object obj); | 
						|
		 | 
						|
		/// <summary> | 
						|
		/// Interns the given list. Uses reference equality to compare the list elements. | 
						|
		/// </summary> | 
						|
		public abstract IList<T> InternList<T>(IList<T> list) where T : class; | 
						|
		 | 
						|
		sealed class DummyInterningProvider : InterningProvider | 
						|
		{ | 
						|
			public override ISupportsInterning Intern(ISupportsInterning obj) | 
						|
			{ | 
						|
				return obj; | 
						|
			} | 
						|
			 | 
						|
			public override string Intern(string text) | 
						|
			{ | 
						|
				return text; | 
						|
			} | 
						|
			 | 
						|
			public override object InternValue(object obj) | 
						|
			{ | 
						|
				return obj; | 
						|
			} | 
						|
			 | 
						|
			public override IList<T> InternList<T>(IList<T> list) | 
						|
			{ | 
						|
				return list; | 
						|
			} | 
						|
		} | 
						|
	} | 
						|
}
 | 
						|
 |