| [Overview][Constants][Types][Procedures and functions][Variables][Index] | 
Pipe file to standard input/output of program
Source position: line 0
| function POpen( | 
| var F: text; | 
| const Prog: Ansistring; | 
| rw: Char | 
| ):cint; | 
| var F: file; | 
| const Prog: Ansistring; | 
| rw: Char | 
| ):cint; | 
POpen runs the command specified in Prog, and redirects the standard in or output of the command to the other end of the pipe F. The parameter rw indicates the direction of the pipe. If it is set to 'W', then F can be used to write data, which will then be read by the command from stdinput. If it is set to 'R', then the standard output of the command can be read from F. F should be reset or rewritten prior to using it. F can be of type Text or File. A file opened with POpen can be closed with Close, but also with PClose. The result is the same, but PClose returns the exit status of the command Prog.
Extended error information is returned by the FpGetErrno function. Errors are essentially those of the Execve, Dup and AssignPipe commands.
| 
 | Create a set of pipe file handlers | |
| 
 | Close file opened with POpen | 
Program Example37; { Program to demonstrate the Popen function. } uses BaseUnix,Unix; var f : text; i : longint; begin writeln ('Creating a shell script to which echoes its arguments'); writeln ('and input back to stdout'); assign (f,'test21a'); rewrite (f); writeln (f,'#!/bin/sh'); writeln (f,'echo this is the child speaking.... '); writeln (f,'echo got arguments \*"$*"\*'); writeln (f,'cat'); writeln (f,'exit 2'); writeln (f); close (f); fpchmod ('test21a',&755); popen (f,'./test21a arg1 arg2','W'); if fpgeterrno<>0 then writeln ('error from POpen : errno : ', fpgeterrno); for i:=1 to 10 do writeln (f,'This is written to the pipe, and should appear on stdout.'); Flush(f); Writeln ('The script exited with status : ',PClose (f)); writeln; writeln ('Press <return> to remove shell script.'); readln; assign (f,'test21a'); erase (f) end.