You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					58 lines
				
				1.3 KiB
			
		
		
			
		
	
	
					58 lines
				
				1.3 KiB
			| 
								 
											4 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * @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;
							 | 
						||
| 
								 | 
							
								}
							 |