From: Richard M. Stallman Date: Sat, 24 Aug 2002 03:16:03 +0000 (+0000) Subject: (Fstart_process): Remove /: from program name. X-Git-Tag: ttn-vms-21-2-B4~13578 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=ed30cf85d76ca9ea9ac03ed903a4e4b3994a1d81;p=emacs.git (Fstart_process): Remove /: from program name. --- diff --git a/src/process.c b/src/process.c index c4d95c6074f..0a1265f4709 100644 --- a/src/process.c +++ b/src/process.c @@ -1421,7 +1421,8 @@ usage: (start-process NAME BUFFER PROGRAM &rest PROGRAM-ARGS) */) #else /* not VMS */ new_argv = (unsigned char **) alloca ((nargs - 1) * sizeof (char *)); - /* If program file name is not absolute, search our path for it */ + /* If program file name is not absolute, search our path for it. + Put the name we will really use in TEM. */ if (!IS_DIRECTORY_SEP (SREF (program, 0)) && !(SCHARS (program) > 1 && IS_DEVICE_SEP (SREF (program, 1)))) @@ -1435,18 +1436,25 @@ usage: (start-process NAME BUFFER PROGRAM &rest PROGRAM-ARGS) */) if (NILP (tem)) report_file_error ("Searching for program", Fcons (program, Qnil)); tem = Fexpand_file_name (tem, Qnil); - tem = ENCODE_FILE (tem); - new_argv[0] = SDATA (tem); } else { if (!NILP (Ffile_directory_p (program))) error ("Specified program for new process is a directory"); - - tem = ENCODE_FILE (program); - new_argv[0] = SDATA (tem); + tem = program; } + /* If program file name starts with /: for quoting a magic name, + discard that. */ + if (SBYTES (tem) > 2 && SREF (tem, 0) == '/' + && SREF (tem, 1) == ':') + tem = Fsubstring (tem, make_number (2), Qnil); + + /* Encode the file name and put it in NEW_ARGV. + That's where the child will use it to execute the program. */ + tem = ENCODE_FILE (tem); + new_argv[0] = SDATA (tem); + /* Here we encode arguments by the coding system used for sending data to the process. We don't support using different coding systems for encoding arguments and for encoding data sent to the