12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- /*
- * @version 1.4.0
- * @date 2015-10-26
- * @stability 3 - Stable
- * @author Lauri Rooden (https://github.com/litejs/natural-compare-lite)
- * @license MIT License
- */
- var naturalCompare = function(a, b) {
- var i, codeA
- , codeB = 1
- , posA = 0
- , posB = 0
- , alphabet = String.alphabet
- function getCode(str, pos, code) {
- if (code) {
- for (i = pos; code = getCode(str, i), code < 76 && code > 65;) ++i;
- return +str.slice(pos - 1, i)
- }
- code = alphabet && alphabet.indexOf(str.charAt(pos))
- return code > -1 ? code + 76 : ((code = str.charCodeAt(pos) || 0), code < 45 || code > 127) ? code
- : code < 46 ? 65 // -
- : code < 48 ? code - 1
- : code < 58 ? code + 18 // 0-9
- : code < 65 ? code - 11
- : code < 91 ? code + 11 // A-Z
- : code < 97 ? code - 37
- : code < 123 ? code + 5 // a-z
- : code - 63
- }
- if ((a+="") != (b+="")) for (;codeB;) {
- codeA = getCode(a, posA++)
- codeB = getCode(b, posB++)
- if (codeA < 76 && codeB < 76 && codeA > 66 && codeB > 66) {
- codeA = getCode(a, posA, posA)
- codeB = getCode(b, posB, posA = i)
- posB = i
- }
- if (codeA != codeB) return (codeA < codeB) ? -1 : 1
- }
- return 0
- }
- try {
- module.exports = naturalCompare;
- } catch (e) {
- String.naturalCompare = naturalCompare;
- }
|