| |
| |
| |
| /* |
| * @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; |
| } |