Skip to content

FpExecv

Execute process

Declaration

Source position: bunxh.inc line 65

  function FpExecv(path: pChar; argv: ppChar) : cint;
  function FpExecv(const path: RawByteString; argv: ppchar) : cint;

Description

Replaces the currently running program with the program, specified in path. It gives the program the options in argvp. This is a pointer to an array of pointers to null-terminated strings. The last pointer in this array should be nil. The current environment is passed to the program. On success, execv does not return.

Errors

On error, -1 is returned. Extended error information can be retrieved with fpGetErrNo

sys_eacces
File is not a regular file, or has no execute permission. A component of the path has no search permission.
sys_eperm
The file system is mounted ****.
sys_e2big
Argument list too big.
sys_enoexec
The magic number in the file is incorrect.
sys_enoent
The file does not exist.
sys_enomem
Not enough memory for kernel.
sys_enotdir
A component of the path is not a directory.
sys_eloop
The path contains a circular reference (via symlinks).

See also

Name Description
fpExecve Execute process using environment
fpFork Create child process

Example

Program Example8;
{ Program to demonstrate the Execv function. }
Uses Unix, strings;
Const Arg0 : PChar = '/bin/ls';
      Arg1 : Pchar = '-l';
Var PP : PPchar;
begin
  GetMem (PP,3*SizeOf(Pchar));
  PP[0]:=Arg0;
  PP[1]:=Arg1;
  PP[3]:=Nil;
  { Execute '/bin/ls -l', with current environment }
  fpExecv ('/bin/ls',pp);
end.