You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | //------------------------------------------------------------ | ||
|  | // Copyright (c) Microsoft Corporation.  All rights reserved. | ||
|  | //------------------------------------------------------------ | ||
|  | namespace System.ServiceModel | ||
|  | { | ||
|  |     // see SynchronizedPool<T> for a threadsafe implementation | ||
|  |     class Pool<T> where T : class | ||
|  |     { | ||
|  |         T[] items; | ||
|  |         int count; | ||
|  | 
 | ||
|  |         public Pool(int maxCount) | ||
|  |         { | ||
|  |             items = new T[maxCount]; | ||
|  |         } | ||
|  | 
 | ||
|  |         public int Count | ||
|  |         { | ||
|  |             get { return count; } | ||
|  |         } | ||
|  | 
 | ||
|  |         public T Take() | ||
|  |         { | ||
|  |             if (count > 0) | ||
|  |             { | ||
|  |                 T item = items[--count]; | ||
|  |                 items[count] = null; | ||
|  |                 return item; | ||
|  |             } | ||
|  |             else | ||
|  |             { | ||
|  |                 return null; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public bool Return(T item) | ||
|  |         { | ||
|  |             if (count < items.Length) | ||
|  |             { | ||
|  |                 items[count++] = item; | ||
|  |                 return true; | ||
|  |             } | ||
|  |             else | ||
|  |             { | ||
|  |                 return false; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public void Clear() | ||
|  |         { | ||
|  |             for (int i = 0; i < count; i++) | ||
|  |                 items[i] = null; | ||
|  |             count = 0; | ||
|  |         } | ||
|  |     } | ||
|  | } |