Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/cecil.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/Mono
diff options
context:
space:
mode:
authorJb Evain <jb@evain.net>2019-01-30 09:38:44 +0300
committerJb Evain <jb@evain.net>2019-01-31 00:56:02 +0300
commit0f2d1802f526c420f68708c3e988f9d90282901a (patch)
treefd7cc1595b159cff5282c56dadbd8b9d9b3ff4f4 /Mono
parent703354805525a3260be5eda86ee7bd8c108ef04c (diff)
Metadata tables should be stable sorted
Diffstat (limited to 'Mono')
-rw-r--r--Mono/MergeSort.cs66
1 files changed, 66 insertions, 0 deletions
diff --git a/Mono/MergeSort.cs b/Mono/MergeSort.cs
new file mode 100644
index 0000000..5d856ea
--- /dev/null
+++ b/Mono/MergeSort.cs
@@ -0,0 +1,66 @@
+//
+// Author:
+// Jb Evain (jbevain@gmail.com)
+//
+// Copyright (c) 2008 - 2015 Jb Evain
+// Copyright (c) 2008 - 2011 Novell, Inc.
+//
+// Licensed under the MIT/X11 license.
+//
+
+using System;
+using System.Collections.Generic;
+
+namespace Mono {
+
+ class MergeSort<T> {
+ private readonly T [] elements;
+ private readonly T [] buffer;
+ private readonly IComparer<T> comparer;
+
+ private MergeSort (T [] elements, IComparer<T> comparer)
+ {
+ this.elements = elements;
+ this.buffer = new T [elements.Length];
+ Array.Copy (this.elements, this.buffer, elements.Length);
+ this.comparer = comparer;
+ }
+
+ public static void Sort (T [] source, IComparer<T> comparer)
+ {
+ Sort (source, 0, source.Length, comparer);
+ }
+
+ public static void Sort (T [] source, int start, int length, IComparer<T> comparer)
+ {
+ new MergeSort<T> (source, comparer).Sort (start, length);
+ }
+
+ private void Sort (int start, int length)
+ {
+ TopDownSplitMerge (this.buffer, this.elements, start, length);
+ }
+
+ private void TopDownSplitMerge (T [] a, T [] b, int start, int end)
+ {
+ if (end - start < 2)
+ return;
+
+ int middle = (end + start) / 2;
+ TopDownSplitMerge (b, a, start, middle);
+ TopDownSplitMerge (b, a, middle, end);
+ TopDownMerge (a, b, start, middle, end);
+ }
+
+ private void TopDownMerge (T [] a, T [] b, int start, int middle, int end)
+ {
+ for (int i = start, j = middle, k = start; k < end; k++) {
+ if (i < middle && (j >= end || comparer.Compare (a [i], a [j]) <= 0)) {
+ b [k] = a [i++];
+ } else {
+ b [k] = a [j++];
+ }
+ }
+ }
+ }
+}