Arrays.cs 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. namespace SharpCifs.Util.Sharpen
  5. {
  6. public class Arrays
  7. {
  8. public static List<T> AsList<T> (params T[] array)
  9. {
  10. return array.ToList ();
  11. }
  12. public static bool Equals<T> (T[] a1, T[] a2)
  13. {
  14. if (a1.Length != a2.Length) {
  15. return false;
  16. }
  17. return !a1.Where((t, i) => !t.Equals(a2[i])).Any();
  18. }
  19. public static void Fill<T> (T[] array, T val)
  20. {
  21. Fill (array, 0, array.Length, val);
  22. }
  23. public static void Fill<T> (T[] array, int start, int end, T val)
  24. {
  25. for (int i = start; i < end; i++) {
  26. array[i] = val;
  27. }
  28. }
  29. public static void Sort (string[] array)
  30. {
  31. Array.Sort (array, (s1,s2) => string.CompareOrdinal (s1,s2));
  32. }
  33. public static void Sort<T> (T[] array)
  34. {
  35. Array.Sort (array);
  36. }
  37. public static void Sort<T> (T[] array, IComparer<T> c)
  38. {
  39. Array.Sort (array, c);
  40. }
  41. public static void Sort<T> (T[] array, int start, int count)
  42. {
  43. Array.Sort (array, start, count);
  44. }
  45. public static void Sort<T> (T[] array, int start, int count, IComparer<T> c)
  46. {
  47. Array.Sort (array, start, count, c);
  48. }
  49. }
  50. }