patch 8.2.0045: script test fails
Problem: Script test fails. Solution: For numbers "is" and "isnot" work like "==" and "!=".
This commit is contained in:
		
							
								
								
									
										15
									
								
								src/eval.c
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								src/eval.c
									
									
									
									
									
								
							| @ -6261,7 +6261,8 @@ typval_compare( | |||||||
|     else if (typ1->v_type == VAR_FUNC || typ2->v_type == VAR_FUNC |     else if (typ1->v_type == VAR_FUNC || typ2->v_type == VAR_FUNC | ||||||
| 	|| typ1->v_type == VAR_PARTIAL || typ2->v_type == VAR_PARTIAL) | 	|| typ1->v_type == VAR_PARTIAL || typ2->v_type == VAR_PARTIAL) | ||||||
|     { |     { | ||||||
| 	if (type != ETYPE_EQUAL && type != ETYPE_NEQUAL) | 	if (type != ETYPE_EQUAL && type != ETYPE_NEQUAL | ||||||
|  | 		&& type != ETYPE_IS && type != ETYPE_ISNOT) | ||||||
| 	{ | 	{ | ||||||
| 	    emsg(_("E694: Invalid operation for Funcrefs")); | 	    emsg(_("E694: Invalid operation for Funcrefs")); | ||||||
| 	    clear_tv(typ1); | 	    clear_tv(typ1); | ||||||
| @ -6306,15 +6307,15 @@ typval_compare( | |||||||
| 	n1 = FALSE; | 	n1 = FALSE; | ||||||
| 	switch (type) | 	switch (type) | ||||||
| 	{ | 	{ | ||||||
|  | 	    case ETYPE_IS: | ||||||
| 	    case ETYPE_EQUAL:    n1 = (f1 == f2); break; | 	    case ETYPE_EQUAL:    n1 = (f1 == f2); break; | ||||||
|  | 	    case ETYPE_ISNOT: | ||||||
| 	    case ETYPE_NEQUAL:   n1 = (f1 != f2); break; | 	    case ETYPE_NEQUAL:   n1 = (f1 != f2); break; | ||||||
| 	    case ETYPE_GREATER:  n1 = (f1 > f2); break; | 	    case ETYPE_GREATER:  n1 = (f1 > f2); break; | ||||||
| 	    case ETYPE_GEQUAL:   n1 = (f1 >= f2); break; | 	    case ETYPE_GEQUAL:   n1 = (f1 >= f2); break; | ||||||
| 	    case ETYPE_SMALLER:  n1 = (f1 < f2); break; | 	    case ETYPE_SMALLER:  n1 = (f1 < f2); break; | ||||||
| 	    case ETYPE_SEQUAL:   n1 = (f1 <= f2); break; | 	    case ETYPE_SEQUAL:   n1 = (f1 <= f2); break; | ||||||
| 	    case ETYPE_UNKNOWN: | 	    case ETYPE_UNKNOWN: | ||||||
| 	    case ETYPE_IS: |  | ||||||
| 	    case ETYPE_ISNOT: |  | ||||||
| 	    case ETYPE_MATCH: | 	    case ETYPE_MATCH: | ||||||
| 	    case ETYPE_NOMATCH:  break;  // avoid gcc warning | 	    case ETYPE_NOMATCH:  break;  // avoid gcc warning | ||||||
| 	} | 	} | ||||||
| @ -6332,15 +6333,15 @@ typval_compare( | |||||||
| 	n2 = tv_get_number(typ2); | 	n2 = tv_get_number(typ2); | ||||||
| 	switch (type) | 	switch (type) | ||||||
| 	{ | 	{ | ||||||
|  | 	    case ETYPE_IS: | ||||||
| 	    case ETYPE_EQUAL:    n1 = (n1 == n2); break; | 	    case ETYPE_EQUAL:    n1 = (n1 == n2); break; | ||||||
|  | 	    case ETYPE_ISNOT: | ||||||
| 	    case ETYPE_NEQUAL:   n1 = (n1 != n2); break; | 	    case ETYPE_NEQUAL:   n1 = (n1 != n2); break; | ||||||
| 	    case ETYPE_GREATER:  n1 = (n1 > n2); break; | 	    case ETYPE_GREATER:  n1 = (n1 > n2); break; | ||||||
| 	    case ETYPE_GEQUAL:   n1 = (n1 >= n2); break; | 	    case ETYPE_GEQUAL:   n1 = (n1 >= n2); break; | ||||||
| 	    case ETYPE_SMALLER:  n1 = (n1 < n2); break; | 	    case ETYPE_SMALLER:  n1 = (n1 < n2); break; | ||||||
| 	    case ETYPE_SEQUAL:   n1 = (n1 <= n2); break; | 	    case ETYPE_SEQUAL:   n1 = (n1 <= n2); break; | ||||||
| 	    case ETYPE_UNKNOWN: | 	    case ETYPE_UNKNOWN: | ||||||
| 	    case ETYPE_IS: |  | ||||||
| 	    case ETYPE_ISNOT: |  | ||||||
| 	    case ETYPE_MATCH: | 	    case ETYPE_MATCH: | ||||||
| 	    case ETYPE_NOMATCH:  break;  // avoid gcc warning | 	    case ETYPE_NOMATCH:  break;  // avoid gcc warning | ||||||
| 	} | 	} | ||||||
| @ -6356,7 +6357,9 @@ typval_compare( | |||||||
| 	n1 = FALSE; | 	n1 = FALSE; | ||||||
| 	switch (type) | 	switch (type) | ||||||
| 	{ | 	{ | ||||||
|  | 	    case ETYPE_IS: | ||||||
| 	    case ETYPE_EQUAL:    n1 = (i == 0); break; | 	    case ETYPE_EQUAL:    n1 = (i == 0); break; | ||||||
|  | 	    case ETYPE_ISNOT: | ||||||
| 	    case ETYPE_NEQUAL:   n1 = (i != 0); break; | 	    case ETYPE_NEQUAL:   n1 = (i != 0); break; | ||||||
| 	    case ETYPE_GREATER:  n1 = (i > 0); break; | 	    case ETYPE_GREATER:  n1 = (i > 0); break; | ||||||
| 	    case ETYPE_GEQUAL:   n1 = (i >= 0); break; | 	    case ETYPE_GEQUAL:   n1 = (i >= 0); break; | ||||||
| @ -6370,8 +6373,6 @@ typval_compare( | |||||||
| 			n1 = !n1; | 			n1 = !n1; | ||||||
| 		    break; | 		    break; | ||||||
|  |  | ||||||
| 	    case ETYPE_IS: |  | ||||||
| 	    case ETYPE_ISNOT: |  | ||||||
| 	    case ETYPE_UNKNOWN:  break;  // avoid gcc warning | 	    case ETYPE_UNKNOWN:  break;  // avoid gcc warning | ||||||
| 	} | 	} | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -742,6 +742,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 */ | ||||||
|  | /**/ | ||||||
|  |     45, | ||||||
| /**/ | /**/ | ||||||
|     44, |     44, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user