[Lazarus] Changes to TProcess
zeljko
zeljko at holobit.hr
Wed Jan 3 14:57:24 CET 2024
On 03. 01. 2024. 14:28, Michael Van Canneyt via lazarus wrote:
>
> Hello,
>
> I merged a significant evolution of the TProcess component to FPC trunk.
>
> Until recently, there were 2 options for TProcess when starting a new
> process:
>
> - use the parent process standard input/output/error
> - use pipes to make the standard input/output/error available as streams
> in the parent process.
>
> This has been enhanced with the following new possibilities:
>
> - For the new process, the standard input/output/error can be configured
> separately.
>
> - You can specify a filename as input/output/error.
> (additionally, you can rewrite or append to the file in case of output)
>
> - You can specify a custom I/O handle as input/output/error
> (e;g. at least on unix, you can pass a socket handle)
>
> - You can specify the null file (/dev/null on unixes or NULL on windows)
>
> - You can specify another TProcess instance.
>
> The last option means that you can now chain processes, just as the
> command shell does.
>
> So the equivalent of the following chain of commands:
>
> command <input.txt | sed s/delphi/FPC/g > file.txt
>
> would then be
>
> Proc.Executable:='command';
> Proc.InputDescriptor.FileName:='input.txt';
> Proc2.Executable:='sed';
> Proc2.Parameters.Add('s/delphi/FPC/g');
> Proc2.OutputDescriptor.FileName:='file.txt';
> Proc.OutputDescriptor.Process:=Proc2;
> Proc2.Execute;
> Proc.execute;
>
> Needless to say, the component remains backwards compatible.
>
> There is now a testsuite for the TProcess command, so everything was
> tested.
> but nothing beats testing in the wild, so I would appreciate it if people
> could test it and provide feedback.
Great feature :)
Thanks Michael
zeljko
More information about the lazarus
mailing list