From: Kai Großjohann Date: Sun, 24 Oct 2004 13:25:21 +0000 (+0000) Subject: (Synchronous Processes): Document process-file. X-Git-Tag: ttn-vms-21-2-B4~4424 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=bb5d6d34377a2bcf28877ee572f44091ac0d31c5;p=emacs.git (Synchronous Processes): Document process-file. --- diff --git a/lispref/ChangeLog b/lispref/ChangeLog index e12fb7d3014..c9332777d69 100644 --- a/lispref/ChangeLog +++ b/lispref/ChangeLog @@ -1,3 +1,7 @@ +2004-10-24 Kai Grossjohann + + * processes.texi (Synchronous Processes): Document process-file. + 2004-10-22 Kenichi Handa * text.texi (translate-region): Document that it accepts also a diff --git a/lispref/processes.texi b/lispref/processes.texi index ccf8f76d87e..35041677b80 100644 --- a/lispref/processes.texi +++ b/lispref/processes.texi @@ -317,6 +317,47 @@ be found in the definition of @code{insert-directory}: @end smallexample @end defun +@defun process-file program &optional infile buffer display &rest args +This function processes files synchronously in a separate process. It +is similar to @code{call-process} but may invoke a file handler based +on the value of the variable @code{default-directory}. The current +working directory of the subprocess is @code{default-directory}. + +The arguments are handled in almost the same way as for +@code{call-process}, with the following differences: + +Some file handlers may not support all combinations and forms of the +arguments @var{infile}, @var{buffer}, and @var{display}. For example, +some file handlers might behave as if @var{display} was nil, +regardless of the value actually passed. As another example, some +file handlers might not support separating standard output and error +output by way of the @var{buffer} argument. + +If a file handler is invoked, it determines the program to run based +on the first argument @var{program}. For instance, consider that a +handler for remote files is invoked. Then the path that is used for +searching the program might be different than @code{exec-path}. + +The second argument @var{infile} may invoke a file handler. The file +handler could be different from the handler chosen for the +@code{process-file} function itself. (For example, +@code{default-directory} could be on a remote host, whereas +@var{infile} is on another remote host. Or @code{default-directory} +could be non-special, whereas @var{infile} is on a remote host.) + +If @var{buffer} has the form @code{(@var{real-destination} +@var{error-destination})}, and @var{error-destination} names a file, +then the same remarks as for @var{infile} apply. + +The remaining arguments (@var{args}) will be passed to the process +verbatim. Emacs is not involved in processing file names that are +present in @var{args}. To avoid confusion, it may be best to avoid +absolute file names in @var{args}, but rather to specify all file +names as relative to @code{default-directory}. The function +@code{file-relative-name} is useful for constructing such relative +file names. +@end defun + @defun call-process-region start end program &optional delete destination display &rest args This function sends the text from @var{start} to @var{end} as standard input to a process running @var{program}. It deletes the text