summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2016-02-23 20:44:08 +0100
committerBram Moolenaar <Bram@vim.org>2016-02-23 20:44:08 +0100
commite16e5a9d8d6d3159107541a259c6823ade18fd08 (patch)
tree973d7a3d9f58937ec57a7ca4c5b29dc39b17f945 /src
parent8aefbe0ad5d05ee7225b20024b0f3023286ebd0f (diff)
downloadvim-git-e16e5a9d8d6d3159107541a259c6823ade18fd08.tar.gz
patch 7.4.1406v7.4.1406
Problem: Leaking memory in cs_print_tags_priv(). Solution: Free tbuf. (idea by Forrest Fleming)
Diffstat (limited to 'src')
-rw-r--r--src/if_cscope.c11
-rw-r--r--src/version.c2
2 files changed, 8 insertions, 5 deletions
diff --git a/src/if_cscope.c b/src/if_cscope.c
index c135fe5bb..b5ca6148b 100644
--- a/src/if_cscope.c
+++ b/src/if_cscope.c
@@ -2092,12 +2092,13 @@ cs_print_tags_priv(char **matches, char **cntxts, int num_matches)
continue;
(void)strcpy(tbuf, matches[idx]);
- if (strtok(tbuf, (const char *)"\t") == NULL)
- continue;
- if ((fname = strtok(NULL, (const char *)"\t")) == NULL)
- continue;
- if ((lno = strtok(NULL, (const char *)"\t")) == NULL)
+ if (strtok(tbuf, (const char *)"\t") == NULL
+ || (fname = strtok(NULL, (const char *)"\t")) == NULL
+ || (lno = strtok(NULL, (const char *)"\t")) == NULL)
+ {
+ vim_free(tbuf);
continue;
+ }
extra = strtok(NULL, (const char *)"\t");
lno[strlen(lno)-2] = '\0'; /* ignore ;" at the end */
diff --git a/src/version.c b/src/version.c
index 5696dfc4b..a04a948c6 100644
--- a/src/version.c
+++ b/src/version.c
@@ -749,6 +749,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1406,
+/**/
1405,
/**/
1404,