# HG changeset patch # User vimboss # Date 1171939759 0 # Node ID a112fdce9ebd6d538c70602550e94f29a2fc60fc # Parent ec7a570696ac0e50147e2419d8b269ccfb75f25e updated for version 7.0-200 diff --git a/src/diff.c b/src/diff.c --- a/src/diff.c +++ b/src/diff.c @@ -1822,14 +1822,20 @@ diff_find_change(wp, lnum, startp, endp) idx = diff_buf_idx(wp->w_buffer); if (idx == DB_COUNT) /* cannot happen */ + { + vim_free(line_org); return FALSE; + } /* search for a change that includes "lnum" in the list of diffblocks. */ for (dp = curtab->tp_first_diff; dp != NULL; dp = dp->df_next) if (lnum <= dp->df_lnum[idx] + dp->df_count[idx]) break; if (dp == NULL || diff_check_sanity(curtab, dp) == FAIL) + { + vim_free(line_org); return FALSE; + } off = lnum - dp->df_lnum[idx]; diff --git a/src/edit.c b/src/edit.c --- a/src/edit.c +++ b/src/edit.c @@ -2698,6 +2698,7 @@ ins_compl_dictionaries(dict_start, pat, buf = alloc(LSIZE); if (buf == NULL) return; + regmatch.regprog = NULL; /* so that we can goto theend */ /* If 'infercase' is set, don't use 'smartcase' here */ save_p_scs = p_scs; @@ -2712,13 +2713,13 @@ ins_compl_dictionaries(dict_start, pat, char_u *pat_esc = vim_strsave_escaped(pat, (char_u *)"\\"); if (pat_esc == NULL) - return ; + goto theend ; i = (int)STRLEN(pat_esc) + 10; ptr = alloc(i); if (ptr == NULL) { vim_free(pat_esc); - return; + goto theend; } vim_snprintf((char *)ptr, i, "^\\s*\\zs\\V%s", pat_esc); regmatch.regprog = vim_regcomp(ptr, RE_MAGIC); diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -667,6 +667,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 200, +/**/ 199, /**/ 198,