Home > lang > exec 
 fr de es it nl pl pt pt_BR mk sq ca hu tr ar fa vi ko ja ru zh zh_TW eo
Previous  Next  Edit  Rename  Undo  Refresh  Search  Administration  
Documentation
History
 
EXEC
[ Process = ] EXEC Command [ WAIT ] [ FOR { { READ | INPUT } | { WRITE | OUTPUT } } ] [ AS Name ]
EXEC Command TO Variable

Executes a command. An internal Process object is created to manage the command.

Standard syntax

The command must be specified as an array of strings containing at least one element. The first element of this array is the name of the command, and the others are optional parameters.

If you use the INPUT and OUTPUT keywords instead of READ and WRITE, then the process is executed inside a virtual terminal. It means that the process will think running inside a true terminal.

Name is the event name used by the Process object. By default, it is "Process".

 3.0 
In Gambas 3, there is no default event name anymore.

In other words, you must add

AS "Process"

to get the same behaviour as Gambas 2.

You can get a reference to the internal Process object created by using an assignment.

Quick syntax

If you use the second syntax, the command is executed, the interpreter waiting for its end, and the complete command output is put in the specified string.

You have no control on the executed process.

 3.0 

Environment

You can specify new environment variables for the running process by using the WITH keyword just after the command argument:

[ Process = ] EXEC Command WITH Environment ...

Environment is an array of strings, each string having the following form: "NAME=VALUE". NAME is the name of the environment variable, VALUE is its value.

If you want to erase an environment variable, just use the string "NAME=".

Running Inside A Virtual Terminal

If the process is run inside a virtual terminal, i.e. if you use the FOR INPUT / OUTPUT syntax, then you can send control characters to the process standard input to get the same effect as if you enter them inside a real terminal. ^C stops the process, ^Z suspends it, and so on.

Example

' Get the contents of a directory
EXEC [ "ls", "-la", "/tmp" ] WAIT

' Get the contents of a directory into a string
DIM sOutput AS String
EXEC [ "ls", "-la", "/tmp" ] TO sOutput

' Get the contents of a directory into a string, but in background
DIM sOutput AS String

' A specific event name is used
EXEC [ "ls", "-la", "/tmp" ] FOR READ AS "Contents"

...

PUBLIC SUB Contents_Read()

  DIM sLine AS String

  READ #LAST, sLine, -256

  sOutput &= sLine

END

PUBLIC SUB Contents_Kill()

  PRINT sOutput

END

If you want to know how many bytes you can read in a Process_Read event handler, use the Lof function.

As arguments are sent directly to the process, you do not have to quote them, as you must do in a shell.

' perl -e 'print while <>;' becomes

EXEC [ "perl", "-e", "print while <>;" ] FOR READ WRITE

See also

Process Management  Process  Lof  Differences Between Shell And Exec