Home > lang > exec 
 en fr de es it nl pl pt pt_BR mk sq ca hu cs tr ar fa id vi ko ja zh zh_TW eo
Previous  Next  Edit  Rename  Undo  Search  Administration  
Documentation  
Warning! This page is not translated.  See english version 
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 passed to EXEC must be specified as either a list of comma delimited string constants or as an array. The first element in the list/array is the name of the command, and the other elements are the commands parameters (if any).

If WAIT is specified, then the interpreter waits for the command to complete, otherwise the command is run in background and your program will continue executing.

If FOR is specified, then the command input-outputs are redirected so that your program intercepts them:

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

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 form of the syntax,

EXEC Command TO Variable

the interpreter waits for the command to complete, and then places the complete command output in the specified string.

During execution of the command you have no control over the process being executed.

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

SHELL, Process Management, Process, Lof, Differences Between Shell And Exec