]> git.eshelyaron.com Git - emacs.git/commitdiff
* w32proc.c: Include "coding.h".
authorJuanma Barranquero <lekktu@gmail.com>
Sat, 29 Nov 2008 18:35:33 +0000 (18:35 +0000)
committerJuanma Barranquero <lekktu@gmail.com>
Sat, 29 Nov 2008 18:35:33 +0000 (18:35 +0000)
  (Fw32_short_file_name): Encode filename passed to Windows API.
  (Fw32_long_file_name): Encode filename passed to Windows API and
  decode back the result.  (Bug#1433)

src/ChangeLog
src/w32proc.c

index 1cb44419d1f56e38799071565c3385cb644c8916..143d8730bab8bab514afa2da495d12656eaad93d 100644 (file)
@@ -1,3 +1,10 @@
+2008-11-29  Juanma Barranquero  <lekktu@gmail.com>
+
+       * w32proc.c: Include "coding.h".
+       (Fw32_short_file_name): Encode filename passed to Windows API.
+       (Fw32_long_file_name): Encode filename passed to Windows API and
+       decode back the result.  (Bug#1433)
+
 2008-11-29  Kenichi Handa  <handa@m17n.org>
 
        * charset.h (CHAR_CHARSET_P): Check if the encoder is loaded or
index ed405cce9fff2c8ba05e5fb07531913f347b3262..081749257f591412e216dcd084985774549732f4 100644 (file)
@@ -63,6 +63,7 @@ extern BOOL WINAPI IsValidLocale(LCID, DWORD);
 #include "syssignal.h"
 #include "w32term.h"
 #include "dispextern.h"                /* for xstrcasecmp */
+#include "coding.h"
 
 #define RVA_TO_PTR(var,section,filedata) \
   ((void *)((section)->PointerToRawData                                        \
@@ -1781,7 +1782,7 @@ All path elements in FILENAME are converted to their short names.  */)
   filename = Fexpand_file_name (filename, Qnil);
 
   /* luckily, this returns the short version of each element in the path.  */
-  if (GetShortPathName (SDATA (filename), shortname, MAX_PATH) == 0)
+  if (GetShortPathName (SDATA (ENCODE_FILE (filename)), shortname, MAX_PATH) == 0)
     return Qnil;
 
   CORRECT_DIR_SEPS (shortname);
@@ -1810,7 +1811,7 @@ All path elements in FILENAME are converted to their long names.  */)
   /* first expand it.  */
   filename = Fexpand_file_name (filename, Qnil);
 
-  if (!w32_get_long_filename (SDATA (filename), longname, MAX_PATH))
+  if (!w32_get_long_filename (SDATA (ENCODE_FILE (filename)), longname, MAX_PATH))
     return Qnil;
 
   CORRECT_DIR_SEPS (longname);
@@ -1821,7 +1822,7 @@ All path elements in FILENAME are converted to their long names.  */)
   if (drive_only && longname[1] == ':' && longname[2] == '/' && !longname[3])
     longname[2] = '\0';
 
-  return build_string (longname);
+  return DECODE_FILE (build_string (longname));
 }
 
 DEFUN ("w32-set-process-priority", Fw32_set_process_priority,