updated for version 7.3.029
Problem:    ":sort n" sorts lines without a number as number zero. (Beeyawned)
Solution:   Make lines without a number sort before lines with a number.  Also
            fix sorting negative numbers.
			
			
This commit is contained in:
		| @ -323,7 +323,8 @@ sort_compare(s1, s2) | |||||||
|     /* When sorting numbers "start_col_nr" is the number, not the column |     /* When sorting numbers "start_col_nr" is the number, not the column | ||||||
|      * number. */ |      * number. */ | ||||||
|     if (sort_nr) |     if (sort_nr) | ||||||
| 	result = l1.start_col_nr - l2.start_col_nr; | 	result = l1.start_col_nr == l2.start_col_nr ? 0 | ||||||
|  | 				 : l1.start_col_nr > l2.start_col_nr ? 1 : -1; | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
| 	/* We need to copy one line into "sortbuf1", because there is no | 	/* We need to copy one line into "sortbuf1", because there is no | ||||||
| @ -482,7 +483,7 @@ ex_sort(eap) | |||||||
| 	     * of the match, by temporarily terminating the string there */ | 	     * of the match, by temporarily terminating the string there */ | ||||||
| 	    s2 = s + end_col; | 	    s2 = s + end_col; | ||||||
| 	    c = *s2; | 	    c = *s2; | ||||||
| 	    (*s2) = 0; | 	    *s2 = NUL; | ||||||
| 	    /* Sorting on number: Store the number itself. */ | 	    /* Sorting on number: Store the number itself. */ | ||||||
| 	    p = s + start_col; | 	    p = s + start_col; | ||||||
| 	    if (sort_hex) | 	    if (sort_hex) | ||||||
| @ -491,9 +492,13 @@ ex_sort(eap) | |||||||
| 		s = skiptodigit(p); | 		s = skiptodigit(p); | ||||||
| 	    if (s > p && s[-1] == '-') | 	    if (s > p && s[-1] == '-') | ||||||
| 		--s;  /* include preceding negative sign */ | 		--s;  /* include preceding negative sign */ | ||||||
|  | 	    if (*s == NUL) | ||||||
|  | 		/* empty line should sort before any number */ | ||||||
|  | 		nrs[lnum - eap->line1].start_col_nr = -MAXLNUM; | ||||||
|  | 	    else | ||||||
| 		vim_str2nr(s, NULL, NULL, sort_oct, sort_hex, | 		vim_str2nr(s, NULL, NULL, sort_oct, sort_hex, | ||||||
| 				  &nrs[lnum - eap->line1].start_col_nr, NULL); | 				  &nrs[lnum - eap->line1].start_col_nr, NULL); | ||||||
| 	    (*s2) = c; | 	    *s2 = c; | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
| 	{ | 	{ | ||||||
| @ -6556,8 +6561,7 @@ typedef struct sign sign_T; | |||||||
| struct sign | struct sign | ||||||
| { | { | ||||||
|     sign_T	*sn_next;	/* next sign in list */ |     sign_T	*sn_next;	/* next sign in list */ | ||||||
|     int		sn_typenr;	/* type number of sign (negative if not equal |     int		sn_typenr;	/* type number of sign */ | ||||||
| 				   to name) */ |  | ||||||
|     char_u	*sn_name;	/* name of sign */ |     char_u	*sn_name;	/* name of sign */ | ||||||
|     char_u	*sn_icon;	/* name of pixmap */ |     char_u	*sn_icon;	/* name of pixmap */ | ||||||
| #ifdef FEAT_SIGN_ICONS | #ifdef FEAT_SIGN_ICONS | ||||||
|  | |||||||
| @ -53,15 +53,19 @@ b321b | |||||||
| t02: numeric | t02: numeric | ||||||
| abc | abc | ||||||
| ab | ab | ||||||
| a |  | ||||||
| a321 | a321 | ||||||
| a123 | a123 | ||||||
| a122 | a122 | ||||||
|  | a | ||||||
|  | x-22 | ||||||
| b321 | b321 | ||||||
| b123 | b123 | ||||||
|  |  | ||||||
| c123d | c123d | ||||||
|  | -24 | ||||||
|  123b |  123b | ||||||
| c321d | c321d | ||||||
|  | 0 | ||||||
| b322b | b322b | ||||||
| b321 | b321 | ||||||
| b321b | b321b | ||||||
|  | |||||||
| @ -21,6 +21,10 @@ ab | |||||||
| a | a | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | -24 | ||||||
|  | x-22 | ||||||
|  | 0 | ||||||
| a122 | a122 | ||||||
| a123 | a123 | ||||||
| b123 | b123 | ||||||
|  | |||||||
| @ -714,6 +714,8 @@ static char *(features[]) = | |||||||
|  |  | ||||||
| static int included_patches[] = | static int included_patches[] = | ||||||
| {   /* Add new patch number below this line */ | {   /* Add new patch number below this line */ | ||||||
|  | /**/ | ||||||
|  |     29, | ||||||
| /**/ | /**/ | ||||||
|     28, |     28, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user