]> git.eshelyaron.com Git - emacs.git/commitdiff
(Fexpand_file_name): Convert the value of $HOME to a multibyte string.
authorEli Zaretskii <eliz@gnu.org>
Sat, 2 Aug 2008 09:31:21 +0000 (09:31 +0000)
committerEli Zaretskii <eliz@gnu.org>
Sat, 2 Aug 2008 09:31:21 +0000 (09:31 +0000)
src/ChangeLog
src/fileio.c

index 4e41e9be4553415497e672f9abfc23f661b4dcc3..5d190d543c29d25de8d3b5328262d3dc55e37574 100644 (file)
@@ -1,3 +1,8 @@
+2008-08-02  Eli Zaretskii  <eliz@gnu.org>
+
+       * fileio.c (Fexpand_file_name): Convert the value of $HOME to a
+       multibyte string.
+
 2008-08-01  Jason Rumney  <jasonr@gnu.org>
 
         * w32term.c (x_draw_composite_glyph_string_foreground): Force
index cc6c7c2d3a73654473c5c314b3460b0369bef40c..4f703a8a743ed4f772b5a6a9ab20e24af0c8bcda 100644 (file)
@@ -1066,6 +1066,7 @@ See also the function `substitute-in-file-name'.  */)
   int length;
   Lisp_Object handler, result;
   int multibyte;
+  Lisp_Object hdir;
 
   CHECK_STRING (name);
 
@@ -1369,9 +1370,19 @@ See also the function `substitute-in-file-name'.  */)
 #endif /* VMS */
          || nm[1] == 0)        /* ~ by itself */
        {
+         Lisp_Object tem;
+
          if (!(newdir = (unsigned char *) egetenv ("HOME")))
            newdir = (unsigned char *) "";
          nm++;
+         /* egetenv may return a unibyte string, which will bite us since
+            we expect the directory to be multibyte.  */
+         tem = build_string (newdir);
+         if (!STRING_MULTIBYTE (tem))
+           {
+             hdir = DECODE_FILE (tem);
+             newdir = SDATA (hdir);
+           }
 #ifdef DOS_NT
          collapse_newdir = 0;
 #endif