====== exec ======
===== Default Keybindings =====
None.
===== Syntax =====
* ''**exec** %%[[%%//fdpat//] //newcommand// [//args// //...//]]''
===== Description =====
Run a unix subprocess (specified by an executable path //newcommand// and
its optional arguments) in the current window. The flow of data between
//newcommand//'s stdin/stdout/stderr, the process originally started in
the window (let us call it "application-process") and ''screen'' itself
(window) is controlled by the file descriptor pattern //fdpat//. This
pattern is basically a three character sequence representing stdin, stdout
and stderr of newcommand. A dot (''.'') connects the file descriptor to
''screen''. An exclamation mark (''!'') causes the file descriptor to be
connected to the application-process. A colon ('':'') combines both.
User input will go to //newcommand// unless //newcommand// receives the
application-process' output (//fdpat//'s first character is ''!'' or
'':'') or a pipe symbol (''|'') is added (as a fourth character) to the
end of //fdpat//.
Invoking ''exec'' without arguments shows name and arguments of the
currently running subprocess in this window. Only one subprocess a time
can be running in each window. When a subprocess is running the
''[[kill]]'' command will affect it instead of the window's process.
Refer to the postscript file {{:commands:fdpat.ps}} for a confusing illustration
of all 21 possible combinations. Each drawing shows the digits 2,1,0
representing the three file descriptors of newcommand. The box marked "W"
is the usual pty that has the application-process on its slave side. The
box marked "P" is the secondary pty that now has ''screen'' at its master
side.
=== Abbreviations ===
Whitespace between the word ''exec'' and //fdpat// and the command can be
omitted. Trailing dots and a //fdpat// consisting only of dots can be
omitted. A simple "''|''" is synonymous for the pattern "''!..|''"; the
word ''exec'' can be omitted here and can always be replaced by "''!''".
===== Examples =====
exec ... /bin/sh
exec /bin/sh
!/bin/sh
Creates another shell in the same window, while the original shell is
still running. Output of both shells is displayed and user input is sent
to the new ''/bin/sh''.
exec !.. stty 19200
exec ! stty 19200
!!stty 19200
Set the speed of the window's tty. If your ''stty'' command operates on
stdout, then add another "''!''".
exec !..| less
|less
This adds a pager to the window output. The special character ''|'' is
needed to give the user control over the pager although it gets its input
from the window's process. This works, because ''less'' listens on stderr
(a behavior that ''screen'' would not expect without the ''|'') when its
stdin is not a tty. Less versions newer than 177 fail miserably here;
good old ''pg'' still works.
!:sed -n s/.*Error.*/\007/p
Sends window output to both the user and the ''sed'' command. The ''sed''
inserts an additional bell character (oct. 007) to the window output seen
by ''screen''. This will cause "Bell in window //x//" messages, whenever
the string "Error" appears in the window.
===== See Also =====
* [[:Misc]]