123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- (function (global, factory) {
- typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
- typeof define === 'function' && define.amd ? define(factory) :
- (global.stable = factory());
- }(this, (function () { 'use strict';
-
-
- var stable = function (arr, comp) {
- return exec(arr.slice(), comp)
- };
- stable.inplace = function (arr, comp) {
- var result = exec(arr, comp);
-
-
- if (result !== arr) {
- pass(result, null, arr.length, arr);
- }
- return arr
- };
-
-
- function exec(arr, comp) {
- if (typeof(comp) !== 'function') {
- comp = function (a, b) {
- return String(a).localeCompare(b)
- };
- }
-
- var len = arr.length;
- if (len <= 1) {
- return arr
- }
-
-
-
- var buffer = new Array(len);
- for (var chk = 1; chk < len; chk *= 2) {
- pass(arr, comp, chk, buffer);
- var tmp = arr;
- arr = buffer;
- buffer = tmp;
- }
- return arr
- }
-
- var pass = function (arr, comp, chk, result) {
- var len = arr.length;
- var i = 0;
-
- var dbl = chk * 2;
-
- var l, r, e;
-
- var li, ri;
-
- for (l = 0; l < len; l += dbl) {
- r = l + chk;
- e = r + chk;
- if (r > len) r = len;
- if (e > len) e = len;
-
- li = l;
- ri = r;
- while (true) {
-
- if (li < r && ri < e) {
-
-
- if (comp(arr[li], arr[ri]) <= 0) {
- result[i++] = arr[li++];
- }
- else {
- result[i++] = arr[ri++];
- }
- }
-
- else if (li < r) {
- result[i++] = arr[li++];
- }
- else if (ri < e) {
- result[i++] = arr[ri++];
- }
-
- else {
- break
- }
- }
- }
- };
- return stable;
- })));
|