summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2012-07-06 16:49:40 +0200
committerBram Moolenaar <Bram@vim.org>2012-07-06 16:49:40 +0200
commitbef4790c236327ebb77cd438d49ac9b8e7dc6542 (patch)
treebbb6e766e134977f234bd5fa39fb4e4f01695e23
parent756287da38076a25fda0ecb75254ef75afb9c931 (diff)
updated for version 7.3.589v7.3.589
Problem: Crash when $HOME is not set. Solution: Check for a NULL pointer. (Chris Webb)
-rw-r--r--src/misc1.c8
-rw-r--r--src/version.c2
2 files changed, 7 insertions, 3 deletions
diff --git a/src/misc1.c b/src/misc1.c
index 99881dccdf..3482272060 100644
--- a/src/misc1.c
+++ b/src/misc1.c
@@ -4496,8 +4496,12 @@ home_replace(buf, src, dst, dstlen, one)
#else
homedir_env_orig = homedir_env = mch_getenv((char_u *)"HOME");
#endif
+ /* Empty is the same as not set. */
+ if (homedir_env != NULL && *homedir_env == NUL)
+ homedir_env = NULL;
+
#if defined(FEAT_MODIFY_FNAME) || defined(WIN3264)
- if (vim_strchr(homedir_env, '~') != NULL)
+ if (homedir_env != NULL && vim_strchr(homedir_env, '~') != NULL)
{
int usedlen = 0;
int flen;
@@ -4513,8 +4517,6 @@ home_replace(buf, src, dst, dstlen, one)
}
#endif
- if (homedir_env != NULL && *homedir_env == NUL)
- homedir_env = NULL;
if (homedir_env != NULL)
envlen = STRLEN(homedir_env);
diff --git a/src/version.c b/src/version.c
index 2676fa7fc8..0acbce0abf 100644
--- a/src/version.c
+++ b/src/version.c
@@ -715,6 +715,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 589,
+/**/
588,
/**/
587,