using System.Collections; using System.Collections.Generic; using System; using System.Reflection; using System.Text.RegularExpressions; namespace Rokojori { public class ValueSorter { Func getFloatValue; bool reverse_highestFirst = false; Dictionary cachedValues = new Dictionary(); public static ValueSorter Create( Func getFloatValue, bool reverse_highestFirst = false ) { var vs = new ValueSorter(); vs.getFloatValue = getFloatValue; vs.reverse_highestFirst = reverse_highestFirst; return vs; } public void ClearCache() { cachedValues.Clear(); } public float GetValue( T t ) { if ( ! cachedValues.ContainsKey( t ) ) { cachedValues[ t ] = getFloatValue( t );; } return cachedValues[ t ]; } public int Compare( T a, T b ) { var valueA = GetValue( a ); var valueB = GetValue( b ); if ( valueA != valueB ) { var difference = valueA - valueB; if ( reverse_highestFirst ) { difference = - difference; } return MathF.Sign( difference ); } return 0; } public void Sort( List data ) { ClearCache(); data.Sort( ( a, b ) => Compare( a, b ) ); } public void Sort( int index, int count, List data ) { ClearCache(); data.Sort( index, count, Comparer.Create( ( a, b ) => Compare( a, b ) ) ); } } }