1 | "use strict";
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports.default = naturalCompare;
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 | function naturalCompare(aStr, bStr) {
|
16 | var aIdx = 0;
|
17 | var bIdx = 0;
|
18 |
|
19 | while (aIdx < aStr.length && bIdx < bStr.length) {
|
20 | var aChar = aStr.charCodeAt(aIdx);
|
21 | var bChar = bStr.charCodeAt(bIdx);
|
22 |
|
23 | if (isDigit(aChar) && isDigit(bChar)) {
|
24 | var aNum = 0;
|
25 |
|
26 | do {
|
27 | ++aIdx;
|
28 | aNum = aNum * 10 + aChar - DIGIT_0;
|
29 | aChar = aStr.charCodeAt(aIdx);
|
30 | } while (isDigit(aChar) && aNum > 0);
|
31 |
|
32 | var bNum = 0;
|
33 |
|
34 | do {
|
35 | ++bIdx;
|
36 | bNum = bNum * 10 + bChar - DIGIT_0;
|
37 | bChar = bStr.charCodeAt(bIdx);
|
38 | } while (isDigit(bChar) && bNum > 0);
|
39 |
|
40 | if (aNum < bNum) {
|
41 | return -1;
|
42 | }
|
43 |
|
44 | if (aNum > bNum) {
|
45 | return 1;
|
46 | }
|
47 | } else {
|
48 | if (aChar < bChar) {
|
49 | return -1;
|
50 | }
|
51 |
|
52 | if (aChar > bChar) {
|
53 | return 1;
|
54 | }
|
55 |
|
56 | ++aIdx;
|
57 | ++bIdx;
|
58 | }
|
59 | }
|
60 |
|
61 | return aStr.length - bStr.length;
|
62 | }
|
63 |
|
64 | var DIGIT_0 = 48;
|
65 | var DIGIT_9 = 57;
|
66 |
|
67 | function isDigit(code) {
|
68 | return !isNaN(code) && DIGIT_0 <= code && code <= DIGIT_9;
|
69 | }
|