87 lines
		
	
	
		
			No EOL
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			No EOL
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Collections.Concurrent;
 | |
| using System.Collections.Generic;
 | |
| 
 | |
| namespace Ryujinx.HLE.OsHle
 | |
| {
 | |
|     class IdDictionary
 | |
|     {
 | |
|         private ConcurrentDictionary<int, object> Objs;
 | |
| 
 | |
|         private int FreeIdHint = 1;
 | |
| 
 | |
|         public IdDictionary()
 | |
|         {
 | |
|             Objs = new ConcurrentDictionary<int, object>();
 | |
|         }
 | |
| 
 | |
|         public bool Add(int Id, object Data)
 | |
|         {
 | |
|             return Objs.TryAdd(Id, Data);
 | |
|         }
 | |
| 
 | |
|         public int Add(object Data)
 | |
|         {
 | |
|             if (Objs.TryAdd(FreeIdHint, Data))
 | |
|             {
 | |
|                 return FreeIdHint++;
 | |
|             }
 | |
| 
 | |
|             return AddSlow(Data);
 | |
|         }
 | |
| 
 | |
|         private int AddSlow(object Data)
 | |
|         {
 | |
|             for (int Id = 1; Id < int.MaxValue; Id++)
 | |
|             {
 | |
|                 if (Objs.TryAdd(Id, Data))
 | |
|                 {
 | |
|                     return Id;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             throw new InvalidOperationException();
 | |
|         }
 | |
| 
 | |
|         public object GetData(int Id)
 | |
|         {
 | |
|             if (Objs.TryGetValue(Id, out object Data))
 | |
|             {
 | |
|                 return Data;
 | |
|             }
 | |
| 
 | |
|             return null;
 | |
|         }
 | |
| 
 | |
|         public T GetData<T>(int Id)
 | |
|         {
 | |
|             if (Objs.TryGetValue(Id, out object Data) && Data is T)
 | |
|             {
 | |
|                 return (T)Data;
 | |
|             }
 | |
| 
 | |
|             return default(T);
 | |
|         }
 | |
| 
 | |
|         public object Delete(int Id)
 | |
|         {
 | |
|             if (Objs.TryRemove(Id, out object Obj))
 | |
|             {
 | |
|                 FreeIdHint = Id;
 | |
| 
 | |
|                 return Obj;
 | |
|             }
 | |
| 
 | |
|             return null;
 | |
|         }
 | |
| 
 | |
|         public ICollection<object> Clear()
 | |
|         {
 | |
|             ICollection<object> Values = Objs.Values;
 | |
| 
 | |
|             Objs.Clear();
 | |
| 
 | |
|             return Values;
 | |
|         }
 | |
|     }
 | |
| } | 
