updated for version 7.3.1005
Problem: Get stuck on regexp "\n*" and on "%s/^\n\+/\r". Solution: Fix handling of matching a line break. (idea by Hirohito Higashi)
This commit is contained in:
		| @ -2462,7 +2462,7 @@ addstate(l, state, m, off, lid, match) | |||||||
|     List		*l;	/* runtime state list */ |     List		*l;	/* runtime state list */ | ||||||
|     nfa_state_T		*state;	/* state to update */ |     nfa_state_T		*state;	/* state to update */ | ||||||
|     regsub_T		*m;	/* pointers to subexpressions */ |     regsub_T		*m;	/* pointers to subexpressions */ | ||||||
|     int			off; |     int			off;	/* byte offset, when -1 go to next line */ | ||||||
|     int			lid; |     int			lid; | ||||||
|     int			*match;	/* found match? */ |     int			*match;	/* found match? */ | ||||||
| { | { | ||||||
| @ -2585,8 +2585,17 @@ addstate(l, state, m, off, lid, match) | |||||||
| 	    { | 	    { | ||||||
| 		save.startpos[subidx] = m->startpos[subidx]; | 		save.startpos[subidx] = m->startpos[subidx]; | ||||||
| 		save.endpos[subidx] = m->endpos[subidx]; | 		save.endpos[subidx] = m->endpos[subidx]; | ||||||
| 		m->startpos[subidx].lnum = reglnum; | 		if (off == -1) | ||||||
| 		m->startpos[subidx].col = (colnr_T)(reginput - regline + off); | 		{ | ||||||
|  | 		    m->startpos[subidx].lnum = reglnum + 1; | ||||||
|  | 		    m->startpos[subidx].col = 0; | ||||||
|  | 		} | ||||||
|  | 		else | ||||||
|  | 		{ | ||||||
|  | 		    m->startpos[subidx].lnum = reglnum; | ||||||
|  | 		    m->startpos[subidx].col = | ||||||
|  | 					  (colnr_T)(reginput - regline + off); | ||||||
|  | 		} | ||||||
| 	    } | 	    } | ||||||
| 	    else | 	    else | ||||||
| 	    { | 	    { | ||||||
| @ -2633,8 +2642,16 @@ addstate(l, state, m, off, lid, match) | |||||||
| 	    { | 	    { | ||||||
| 		save.startpos[subidx] = m->startpos[subidx]; | 		save.startpos[subidx] = m->startpos[subidx]; | ||||||
| 		save.endpos[subidx] = m->endpos[subidx]; | 		save.endpos[subidx] = m->endpos[subidx]; | ||||||
| 		m->endpos[subidx].lnum = reglnum; | 		if (off == -1) | ||||||
| 		m->endpos[subidx].col = (colnr_T)(reginput - regline + off); | 		{ | ||||||
|  | 		    m->endpos[subidx].lnum = reglnum + 1; | ||||||
|  | 		    m->endpos[subidx].col = 0; | ||||||
|  | 		} | ||||||
|  | 		else | ||||||
|  | 		{ | ||||||
|  | 		    m->endpos[subidx].lnum = reglnum; | ||||||
|  | 		    m->endpos[subidx].col = (colnr_T)(reginput - regline + off); | ||||||
|  | 		} | ||||||
| 	    } | 	    } | ||||||
| 	    else | 	    else | ||||||
| 	    { | 	    { | ||||||
| @ -2834,7 +2851,7 @@ nfa_regmatch(start, submatch, m) | |||||||
|     int		match = FALSE; |     int		match = FALSE; | ||||||
|     int		flag = 0; |     int		flag = 0; | ||||||
|     int		old_reglnum = -1; |     int		old_reglnum = -1; | ||||||
|     int		reginput_updated = FALSE; |     int		go_to_nextline; | ||||||
|     thread_T	*t; |     thread_T	*t; | ||||||
|     char_u	*old_reginput = NULL; |     char_u	*old_reginput = NULL; | ||||||
|     char_u	*old_regline = NULL; |     char_u	*old_regline = NULL; | ||||||
| @ -2917,8 +2934,8 @@ nfa_regmatch(start, submatch, m) | |||||||
|     /* |     /* | ||||||
|      * Run for each character. |      * Run for each character. | ||||||
|      */ |      */ | ||||||
|     do { |     for (;;) | ||||||
| again: |     { | ||||||
| #ifdef FEAT_MBYTE | #ifdef FEAT_MBYTE | ||||||
| 	if (has_mbyte) | 	if (has_mbyte) | ||||||
| 	{ | 	{ | ||||||
| @ -2932,7 +2949,10 @@ again: | |||||||
| 	    n = 1; | 	    n = 1; | ||||||
| 	} | 	} | ||||||
| 	if (c == NUL) | 	if (c == NUL) | ||||||
|  | 	{ | ||||||
| 	    n = 0; | 	    n = 0; | ||||||
|  | 	    go_to_nextline = FALSE; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	/* swap lists */ | 	/* swap lists */ | ||||||
| 	thislist = &list[flag]; | 	thislist = &list[flag]; | ||||||
| @ -3007,7 +3027,9 @@ again: | |||||||
| 				(char *)t->sub.end[j]); | 				(char *)t->sub.end[j]); | ||||||
| 		fprintf(log_fd, "\n"); | 		fprintf(log_fd, "\n"); | ||||||
| #endif | #endif | ||||||
| 		goto nextchar;		/* found the left-most longest match */ | 		/* Found the left-most longest match, do not look at any other | ||||||
|  | 		 * states at this position. */ | ||||||
|  | 		goto nextchar; | ||||||
|  |  | ||||||
| 	    case NFA_END_INVISIBLE: | 	    case NFA_END_INVISIBLE: | ||||||
| 		/* This is only encountered after a NFA_START_INVISIBLE node. | 		/* This is only encountered after a NFA_START_INVISIBLE node. | ||||||
| @ -3206,15 +3228,13 @@ again: | |||||||
|  |  | ||||||
| 	    case NFA_NEWL: | 	    case NFA_NEWL: | ||||||
| 		if (!reg_line_lbr && REG_MULTI | 		if (!reg_line_lbr && REG_MULTI | ||||||
| 				&& c == NUL && reglnum <= reg_maxline) | 					&& c == NUL && reglnum <= reg_maxline) | ||||||
| 		{ | 		{ | ||||||
| 		    if (reginput_updated == FALSE) | 		    go_to_nextline = TRUE; | ||||||
| 		    { | 		    /* Pass -1 for the offset, which means taking the position | ||||||
| 			reg_nextline(); | 		     * at the start of the next line. */ | ||||||
| 			reginput_updated = TRUE; | 		    addstate(nextlist, t->state->out, &t->sub, -1, | ||||||
| 		    } | 							  listid + 1, &match); | ||||||
| 		    addstate(nextlist, t->state->out, &t->sub, n, listid + 1, |  | ||||||
| 								    &match); |  | ||||||
| 		} | 		} | ||||||
| 		break; | 		break; | ||||||
|  |  | ||||||
| @ -3247,8 +3267,7 @@ again: | |||||||
| 		break; | 		break; | ||||||
|  |  | ||||||
| 	    case NFA_ANY: | 	    case NFA_ANY: | ||||||
| 		/* Any printable char, not just any char. '\0' (end of input) | 		/* Any char except '\0', (end of input) does not match. */ | ||||||
| 		 * must not match */ |  | ||||||
| 		if (c > 0) | 		if (c > 0) | ||||||
| 		    addstate(nextlist, t->state->out, &t->sub, n, listid + 1, | 		    addstate(nextlist, t->state->out, &t->sub, n, listid + 1, | ||||||
| 								    &match); | 								    &match); | ||||||
| @ -3433,12 +3452,6 @@ again: | |||||||
| 	    addstate(nextlist, start, m, n, listid + 1, &match); | 	    addstate(nextlist, start, m, n, listid + 1, &match); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if (reginput_updated) |  | ||||||
| 	{ |  | ||||||
| 	    reginput_updated = FALSE; |  | ||||||
| 	    goto again; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| #ifdef ENABLE_LOG | #ifdef ENABLE_LOG | ||||||
| 	fprintf(log_fd, ">>> Thislist had %d states available: ", thislist->n); | 	fprintf(log_fd, ">>> Thislist had %d states available: ", thislist->n); | ||||||
| 	for (i = 0; i< thislist->n; i++) | 	for (i = 0; i< thislist->n; i++) | ||||||
| @ -3447,8 +3460,15 @@ again: | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| nextchar: | nextchar: | ||||||
| 	reginput += n; | 	/* Advance to the next character, or advance to the next line, or | ||||||
|     } while (c || reginput_updated); | 	 * finish. */ | ||||||
|  | 	if (n != 0) | ||||||
|  | 	    reginput += n; | ||||||
|  | 	else if (go_to_nextline) | ||||||
|  | 	    reg_nextline(); | ||||||
|  | 	else | ||||||
|  | 	    break; | ||||||
|  |     } | ||||||
|  |  | ||||||
| #ifdef ENABLE_LOG | #ifdef ENABLE_LOG | ||||||
|     if (log_fd != stderr) |     if (log_fd != stderr) | ||||||
|  | |||||||
| @ -728,6 +728,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 */ | ||||||
|  | /**/ | ||||||
|  |     1005, | ||||||
| /**/ | /**/ | ||||||
|     1004, |     1004, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user