*printf()
format strings are now safer (#379).SIGPIPE
when writing to a file descriptor, on unix. This avoid possible freezes when a callr::r_session
subprocess is trying to report its result after the main process was terminated. In particular, this happened with parallel testthat: https://github.com/r-lib/testthat/issues/1819SIGTERM
cleanup handler that cleans up the temporary directory before shutting down. To enable it, set the PROCESSX_R_SIGTERM_CLEANUP
envvar to a non-empty value.processx error stacks are better now. They have ANSI hyperlinks for function calls to their manual pages, and they also print operators better.
processx now does not mark standard streams as close-on-exec on Unix, as this causes problems when calling system()
from an R subprocess (https://github.com/r-lib/callr/issues/236).
conn_create_fifo()
, conn_create_unix_socket()
and vignettes/internals.Rmd
for documentation. These functions are currently experimental.processx now closes file unneeded file descriptors when redirecting the standard output and error, in the client file.
processx errors now do not have rlang_error
and rlang_trace
classes, because they are actually not compatible with rlang errors and traces.
run()
now sets stderr
to NULL
in the result (instead of an empty string), if the standard error was redirected to the standard output. This also fixes an error when interrupting a run()
with a redirected standard error.
processx now does not fail if the current working directory contains a non-ASCII character on Windows, and getwd()
returns a short path for it (#313).
run()
now does not truncate stdout and stderr when the output contains multibyte characters (#298, @infotroph).
processx now compiles with custom compilers that enable OpenMP (#297).
processx now avoids a race condition when the working directory is changed right after starting a process, potentially before the sub-process is initialized (#300).
processx now works with non-ASCII path names on non-UTF-8 Unix platforms (#293).
You can now append environment variables to the ones set in the current process if you include "current"
in the value of env
, in run()
and for process$new()
: env = c("current", NEW = "newvalue")
(#232).
Sub-processes can now inherit the standard input, output and error from the main R process, by setting the corresponding argument to an empty string. E.g. run("ls", stdout = "")
(#72).
run()
is now much faster with large standard output or standard error (#286).
run()
can now discard the standard output and error or redirect them to file(s), instead of collecting them.
processx now optionally uses the cli package to color error messages and stack traces, instead of crayon.
New options in pty_options
to set the initial size of the pseudo terminal.
Reading the standard output or error now does not crash occasionally when a \n
character is at the beginning of the input buffer (#281).
processx now works correctly for non-ASCII commands and arguments passed in the native encoding, on Windows (#261, #262, #263, #264).
Providing multiple environment variables now works on windows (#267).
The supervisor (activated with supervise = TRUE
) does not crash on the Windows Subsystem on Linux (WSL) now (#222).
Fix ABI compatibility for pre and post R 4.0.1 versions. Now CRAN builds (with R 4.0.2 and later 4.0.x) work well on R 4.0.0.
Now processx can run commands on UNC paths specified with forward slashes: //hostname/...
UNC paths with the usual back-slashes were always fine (#249).
The $as_ps_handle()
method works now better; previously it sometimes created an invalid ps::ps_handle
object, if the system clock has changed (#258).
run()
now does a better job with displaying the spinner on terminals that buffer the output (#223).
Error messages are now fully printed after an error. In non-interactive sessions, the stack trace is printed as well.
Further improved error messages. Errors from C code now include the name of the C function, and errors that belong to a process include the system command (#197).
processx does not crash now if the process receives a SIGPIPE signal when trying to write to a pipe, of which the other end has already exited.
processx now to works better with fork clusters from the parallel package. See ‘Mixing processx and the parallel base R package’ in the README file (#236).
processx now does no block SIGCHLD by default in the subprocess, blocking potentially causes zombie sub-subprocesses (#240).
The process$wait()
method now does not leak file descriptors on Unix when interrupted (#141).
run()
does not create an ok
variable in the global environment.Processx has now better error messages, in particular, all errors from C code contain the file name and line number, and the system error code and message (where applicable).
Processx now sets the .Last.error
variable for every un-caught processx error to the error condition, and also sets .Last.error.trace
to its stack trace.
run()
now prints the last 10 lines of the standard error stream on error, if echo = FALSE
, and it also prints the exit status of the process.
run()
now includes the standard error in the condition signalled on interrupt.
process
now supports creating pseudo terminals on Unix systems.
conn_create_pipepair()
gets new argument to set the pipes as blocking or non-blocking.
process
does not set the inherited extra connections as blocking, and it also does not close them after starting the subprocess. This is now the responsibility of the user. Note that this is a breaking change.
run()
now passes extra ...
arguments to process$new()
.
run()
now does not error if the process is killed in a callback.
process
can now redirect the standard error to the standard output, via specifying stderr = "2>&1"
. This works both with files and pipes.
run()
can now redirect the standard error to the standard output, via the new stderr_to_stdout
argument.
The $kill()
and $kill_tree()
methods get a close_connection = TRUE
argument that closes all pipe connections of the process.
run()
now always kills the process (and its process tree if cleanup_tree
is TRUE
) before exiting. This also closes all pipe connections (#149).
New process$kill_tree()
method, and new cleanup_tree
arguments in run()
and process$new()
, to clean up the process tree rooted at a processx process. (#139, #143).
New process$interupt()
method to send an interrupt to a process, SIGINT on Unix, CTRL+C on Windows (#127).
New stdin
argument in process$new()
to support writing to the standard input of a process (#27, #114).
New connections
argument in process$new()
to support passing extra connections to the child process, in addition to the standard streams.
New poll_connection
argument to process$new()
, an extra connection that can be used to poll the process, even if stdout
and stderr
are not pipes (#125).
poll()
now works with connections objects, and they can be mixed with process objects (#121).
New env
argument in run()
and process$new()
, to set the environment of the child process, optionally (#117, #118).
Removed the $restart()
method, because it was less useful than expected, and hard to maintain (#116).
New conn_set_stdout()
and conn_set_stderr()
to set the standard output or error of the calling process.
New conn_disable_inheritance()
to disable stdio inheritance. It is suggested that child processes call this immediately after starting, so the file handles are not inherited further.
Fixed a signal handler bug on Unix that marked the process as finished, even if it has not (d221aa1f).
Fixed a bug that occasionally caused crashes in wait()
, on Unix (#138).
When run()
is interrupted, no error message is printed, just like for interruption of R code in general. The thrown condition now also has the interrupt
class (#148).
Fix interference with the parallel package, and other packages that redefine the SIGCHLD
signal handler on Unix. If the processx signal handler is overwritten, we might miss the exit status of some processes (they are set to NA
).
run()
and process$new()
allow specifying the working directory of the process (#63).
Make the debugme package an optional dependency (#74).
processx is now compatible with R 3.1.x.
Allow polling more than 64 connections on Windows, by using IOCP instead of WaitForMultipleObjects()
(#81, #106).
Fix a race condition on Windows, when creating named pipes for stdout or stderr. The client sometimes didn’t wait for the server, and processx failed with ERROR_PIPE_BUSY (231, All pipe instances are busy).
Fix a crash on windows when trying to run a non-existing command (#90)
Fix a race condition in process$restart()
run()
and process$new()
do not support the commandline
argument any more, because process cleanup is error prone with an intermediate shell. (#88)
processx
process objects no longer use R connection objects, because the R connection API was retroactive made private by R-core processx
uses its own connection class now to manage standard output and error of the process.
The encoding of the standard output and error can be specified now, and processx
re-encodes stdout
and stderr
in UTF-8.
Cloning of process objects is disables now, as it is likely that it causes problems (@wch).
supervise
option to kill child process if R crashes (@wch).
Add get_output_file
and get_error_file
, has_output_connection()
and has_error_connection()
methods (@wch).
stdout
and stderr
default to NULL
now, i.e. they are discarded (@wch).
Fix undefined behavior when stdout/stderr was read out after the process was already finalized, on Unix.
run()
: Better message on interruption, kill process when interrupted.
Unix: better kill count on unloading the package.
Unix: make wait() work when SIGCHLD is not delivered for some reason.
Unix: close inherited file descriptors more conservatively.
Fix a race condition and several memory leaks on Windows.
Fixes when running under job control that does not allow breaking away from the job, on Windows.
This is an unofficial release, created by CRAN, to fix compilation on Solaris.
First public release.