// Copyright (c) 2011 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; using System.Collections.Generic; using ICSharpCode.ILSpy.Options; namespace ICSharpCode.ILSpy { /// /// ExtensionMethods used in ILSpy. /// public static class ExtensionMethods { public static void AddRange(this ICollection list, IEnumerable items) { foreach (T item in items) if (!list.Contains(item)) list.Add(item); } public static T PeekOrDefault(this Stack stack) { if (stack.Count == 0) return default(T); return stack.Peek(); } public static int BinarySearch(this IList list, T item, int start, int count, IComparer comparer) { if (list == null) throw new ArgumentNullException(nameof(list)); if (start < 0 || start >= list.Count) throw new ArgumentOutOfRangeException(nameof(start), start, "Value must be between 0 and " + (list.Count - 1)); if (count < 0 || count > list.Count - start) throw new ArgumentOutOfRangeException(nameof(count), count, "Value must be between 0 and " + (list.Count - start)); int end = start + count - 1; while (start <= end) { int pivot = (start + end) / 2; int result = comparer.Compare(item, list[pivot]); if (result == 0) return pivot; if (result < 0) end = pivot - 1; else start = pivot + 1; } return ~start; } public static int BinarySearch(this IList instance, TKey itemKey, Func keySelector) where TKey : IComparable, IComparable { if (instance == null) throw new ArgumentNullException(nameof(instance)); if (keySelector == null) throw new ArgumentNullException(nameof(keySelector)); int start = 0; int end = instance.Count - 1; while (start <= end) { int m = (start + end) / 2; TKey key = keySelector(instance[m]); int result = key.CompareTo(itemKey); if (result == 0) return m; if (result < 0) start = m + 1; else end = m - 1; } return ~start; } /* public static bool IsCustomAttribute(this TypeDefinition type) { while (type.FullName != "System.Object") { var resolvedBaseType = type.BaseType.Resolve(); if (resolvedBaseType == null) return false; if (resolvedBaseType.FullName == "System.Attribute") return true; type = resolvedBaseType; } return false; } */ public static string ToSuffixString(this System.Reflection.Metadata.EntityHandle token) { if (!DisplaySettingsPanel.CurrentDisplaySettings.ShowMetadataTokens) return string.Empty; return " @" + System.Reflection.Metadata.Ecma335.MetadataTokens.GetToken(token).ToString("x8"); } public static string ToSuffixString(this System.Reflection.Metadata.MethodDefinitionHandle token) { if (!DisplaySettingsPanel.CurrentDisplaySettings.ShowMetadataTokens) return string.Empty; return " @" + System.Reflection.Metadata.Ecma335.MetadataTokens.GetToken(token).ToString("x8"); } public static string ToSuffixString(this System.Reflection.Metadata.PropertyDefinitionHandle token) { if (!DisplaySettingsPanel.CurrentDisplaySettings.ShowMetadataTokens) return string.Empty; return " @" + System.Reflection.Metadata.Ecma335.MetadataTokens.GetToken(token).ToString("x8"); } public static string ToSuffixString(this System.Reflection.Metadata.EventDefinitionHandle token) { if (!DisplaySettingsPanel.CurrentDisplaySettings.ShowMetadataTokens) return string.Empty; return " @" + System.Reflection.Metadata.Ecma335.MetadataTokens.GetToken(token).ToString("x8"); } public static string ToSuffixString(this System.Reflection.Metadata.FieldDefinitionHandle token) { if (!DisplaySettingsPanel.CurrentDisplaySettings.ShowMetadataTokens) return string.Empty; return " @" + System.Reflection.Metadata.Ecma335.MetadataTokens.GetToken(token).ToString("x8"); } public static string ToSuffixString(this System.Reflection.Metadata.TypeDefinitionHandle token) { if (!DisplaySettingsPanel.CurrentDisplaySettings.ShowMetadataTokens) return string.Empty; return " @" + System.Reflection.Metadata.Ecma335.MetadataTokens.GetToken(token).ToString("x8"); } /// /// Takes at most first characters from string, and appends '...' if string is longer. /// String can be null. /// public static string TakeStartEllipsis(this string s, int length) { if (string.IsNullOrEmpty(s) || length >= s.Length) return s; return s.Substring(0, length) + "..."; } /// /// Equivalent to collection.Select(func).ToArray(), but more efficient as it makes /// use of the input collection's known size. /// public static U[] SelectArray(this ICollection collection, Func func) { U[] result = new U[collection.Count]; int index = 0; foreach (var element in collection) { result[index++] = func(element); } return result; } } }