patch 9.0.0166: when using text properties line text length computed twice
Problem: When using text properties the line text length is computed twice. Solution: If the text lenght was already computed don't do it again.
This commit is contained in:
		| @ -2821,6 +2821,9 @@ ml_append_int( | ||||
|     infoptr_T	*ip; | ||||
| #ifdef FEAT_PROP_POPUP | ||||
|     char_u	*tofree = NULL; | ||||
| # ifdef FEAT_BYTEOFF | ||||
|     colnr_T	text_len = 0;	// text len with NUL without text properties | ||||
| # endif | ||||
| #endif | ||||
|     int		ret = FAIL; | ||||
|  | ||||
| @ -2831,7 +2834,19 @@ ml_append_int( | ||||
| 	lowest_marked = lnum + 1; | ||||
|  | ||||
|     if (len == 0) | ||||
|     { | ||||
| 	len = (colnr_T)STRLEN(line) + 1;	// space needed for the text | ||||
| #if defined(FEAT_PROP_POPUP) && defined(FEAT_BYTEOFF) | ||||
| 	text_len = len; | ||||
| #endif | ||||
|     } | ||||
| #if defined(FEAT_PROP_POPUP) && defined(FEAT_BYTEOFF) | ||||
|     else if (curbuf->b_has_textprop) | ||||
| 	// "len" may include text properties, get the length of the text. | ||||
| 	text_len = (colnr_T)STRLEN(line) + 1; | ||||
|     else | ||||
| 	text_len = len; | ||||
| #endif | ||||
|  | ||||
| #ifdef FEAT_PROP_POPUP | ||||
|     if (curbuf->b_has_textprop && lnum > 0 | ||||
| @ -3292,13 +3307,14 @@ ml_append_int( | ||||
|     } | ||||
|  | ||||
| #ifdef FEAT_BYTEOFF | ||||
| # ifdef FEAT_PROP_POPUP | ||||
|     if (curbuf->b_has_textprop) | ||||
| 	// only use the space needed for the text, ignore properties | ||||
| 	len = (colnr_T)STRLEN(line) + 1; | ||||
| # endif | ||||
|     // The line was inserted below 'lnum' | ||||
|     ml_updatechunk(buf, lnum + 1, (long)len, ML_CHNK_ADDLINE); | ||||
|     ml_updatechunk(buf, lnum + 1, | ||||
| # ifdef FEAT_PROP_POPUP | ||||
| 	    (long)text_len | ||||
| # else | ||||
| 	    (long)len | ||||
| #endif | ||||
| 	    , ML_CHNK_ADDLINE); | ||||
| #endif | ||||
|  | ||||
| #ifdef FEAT_NETBEANS_INTG | ||||
|  | ||||
		Reference in New Issue
	
	Block a user