 
 
 
Templates
Description
argument_counter(Counter) succeeds if Counter is the number of arguments of the command-line. Since the first argument is always the name of the running program, Counter is always ≥ 1. See (section 4.2) for more information about command-line arguments retrieved under the top_level.
Errors
| Counter is neither a variable nor an integer | type_error(integer, Counter) | |
Portability
GNU Prolog predicate.
Templates
Description
argument_value(N, Arg) succeeds if the Nth argument on the command-line unifies with Arg. The first argument is always the name of the running program and its number is 0. The number of arguments on the command-line can be obtained using argument_counter/1 (section 8.27.1).
Errors
| N is a variable | instantiation_error | |
| N is neither a variable nor an integer | type_error(integer, N) | |
| N is an integer < 0 | domain_error(not_less_than_zero, N) | |
| Arg is neither a variable nor an atom | type_error(atom, Arg) | |
Portability
GNU Prolog predicate.
Templates
Description
argument_list(Args) succeeds if Args unifies with the list of atoms associated with each argument on the command-line other than the first argument (the name of the running program).
Errors
| Args is neither a partial list nor a list | type_error(list, Args) | |
Portability
GNU Prolog predicate.
Templates
Description
environ(Name, Value) succeeds if Name is the name of an environment variable whose value is Value. This predicate is re-executable on backtracking.
Errors
| Name is neither a variable nor an atom | type_error(atom, Name) | |
| Value is neither a variable nor an atom | type_error(atom, Value) | |
Portability
GNU Prolog predicate.
Templates
Description
make_directory(PathName) creates the directory whose pathname is PathName.
delete_directory(PathName) removes the directory whose pathname is PathName.
change_directory(PathName) sets the current directory to the directory whose pathname is PathName.
See absolute_file_name/2 for information about the syntax of PathName (section 8.26.1).
Errors
| PathName is a variable | instantiation_error | |
| PathName is neither a variable nor an atom | type_error(atom, PathName) | |
| PathName is an atom but not a valid pathname | domain_error(os_path, PathName) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicates.
Templates
Description
working_directory(PathName) succeeds if PathName is the pathname of the current directory.
Errors
| PathName is neither a variable nor an atom | type_error(atom, PathName) | |
Portability
GNU Prolog predicate.
Templates
Description
directory_files(PathName, Files) succeeds if Files is the list of all entries (files, sub-directories,…) in the directory whose pathname is PathName. See absolute_file_name/2 for information about the syntax of PathName (section 8.26.1).
Errors
| PathName is a variable | instantiation_error | |
| PathName is neither a variable nor an atom | type_error(atom, PathName) | |
| PathName is an atom but not a valid pathname | domain_error(os_path, PathName) | |
| Files is neither a partial list nor a list | type_error(list, Files) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
rename_file(PathName1, PathName2) renames the file or directory whose pathname is PathName1 to PathName2. See absolute_file_name/2 for information about the syntax of PathName1 and PathName2 (section 8.26.1).
Errors
| PathName1 is a variable | instantiation_error | |
| PathName1 is neither a variable nor an atom | type_error(atom, PathName1) | |
| PathName1 is an atom but not a valid pathname | domain_error(os_path, PathName1) | |
| PathName2 is a variable | instantiation_error | |
| PathName2 is neither a variable nor an atom | type_error(atom, PathName2) | |
| PathName2 is an atom but not a valid pathname | domain_error(os_path, PathName2) | |
| an operating system error occurs and value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
delete_file(PathName) removes the existing file whose pathname is PathName.
unlink/1 is similar to delete_file/1 except that it never causes a system_error (e.g. if PathName does not refer to an existing file).
See absolute_file_name/2 for information about the syntax of PathName (section 8.26.1).
Errors
| PathName is a variable | instantiation_error | |
| PathName is neither a variable nor an atom | type_error(atom, PathName) | |
| PathName is an atom but not a valid pathname | domain_error(os_path, PathName) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicates.
Templates
Description
file_permission(PathName, Permission) succeeds if PathName is the pathname of an existing file (or directory) whose permissions include Permission.
File permissions: Permission can be a single permission or a list of permissions. A permission is an atom among:
If PathName does not exists or if its permissions do not include Permission this predicate fails.
file_exists(PathName) is equivalent to file_permission(PathName, []), i.e. it succeeds if PathName is the pathname of an existing file (or directory).
See absolute_file_name/2 for information about the syntax of PathName (section 8.26.1).
Errors
| PathName is a variable | instantiation_error | |
| PathName is neither a variable nor an atom | type_error(atom, PathName) | |
| PathName is an atom but not a valid pathname | domain_error(os_path, PathName) | |
| Permission is a partial list or a list with an element which is a variable | instantiation_error | |
| Permission is neither an atom nor partial list or a list | type_error(list, Permission) | |
| an element E of the Permission list is neither a variable nor an atom | type_error(atom, E) | |
| an element E of the Permission is an atom but not a valid permission | domain_error(os_file_permission, Permission) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicates.
Templates
Description
file_property(PathName, Property) succeeds if PathName is the pathname of an existing file (or directory) and if Property unifies with one of the properties of the file. This predicate is re-executable on backtracking.
File properties:
See absolute_file_name/2 for information about the syntax of PathName (section 8.26.1).
Errors
| PathName is a variable | instantiation_error | |
| PathName is neither a variable nor an atom | type_error(atom, PathName) | |
| PathName is an atom but not a valid pathname | domain_error(os_path, PathName) | |
| Property is neither a variable nor a file property term | domain_error(os_file_property, Property) | |
| Property = absolute_file_name(E), real_file_name(E), type(E) or permission(E) and E is neither a variable nor an atom | type_error(atom, E) | |
| Property = last_modification(DateTime) and DateTime is neither a variable nor a compound term | type_error(compound, DateTime) | |
| Property = last_modification(DateTime) and DateTime is a compound term but not a structure dt/6 | domain_error(date_time, DateTime) | |
| Property = size(E) or last_modification(DateTime) and DateTime is a structure dt/6 but an element E is neither a variable nor an integer | type_error(integer, E) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
temporary_name(Template, PathName) creates a unique file name PathName whose pathname begins by Template. Template should contain a pathname with six trailing Xs. PathName is Template with the six Xs replaced with a letter and the process identifier. This predicate is an interface to the C Unix function mktemp(3).
See absolute_file_name/2 for information about the syntax of Template (section 8.26.1).
Errors
| Template is a variable | instantiation_error | |
| Template is neither a variable nor an atom | type_error(atom, Template) | |
| Template is an atom but not a valid pathname | domain_error(os_path, Template) | |
| PathName is neither a variable nor an atom | type_error(atom, PathName) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
temporary_file(Directory, Prefix, PathName) creates a unique file name PathName whose pathname begins by Directory/Prefix. If Directory is the empty atom ’’ a standard temporary directory will be used (e.g. /tmp). Prefix can be the empty atom ’’. This predicate is an interface to the C Unix function tempnam(3).
See absolute_file_name/2 for information about the syntax of Directory (section 8.26.1).
Errors
| Directory is a variable | instantiation_error | |
| Directory is neither a variable nor an atom | type_error(atom, Directory) | |
| Directory is an atom but not a valid pathname | domain_error(os_path, Directory) | |
| Prefix is a variable | instantiation_error | |
| Prefix is neither a variable nor an atom | type_error(atom, Prefix) | |
| PathName is neither a variable nor an atom | type_error(atom, PathName) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
date_time(DateTime) unifies DateTime with a compound term containing the current date and time. DateTime is a structure dt(Year, Month, Day, Hour, Minute, Second). Each sub-argument of the term dt/6 is an integer.
Errors
| DateTime is neither a variable nor a compound term | type_error(compound, DateTime) | |
| DateTime is a compound term but not a structure dt/6 | domain_error(date_time, DateTime) | |
| DateTime is a structure dt/6 and an element E is neither a variable nor an integer | type_error(integer, E) | |
Portability
GNU Prolog predicate.
Templates
Description
host_name(HostName) unifies HostName with the name of the host machine executing the current GNU Prolog process. If the sockets are available (section 8.28.1), the name returned will be fully qualified. In that case, host_name/1 will also succeed if HostName is instantiated to the unqualified name (or an alias) of the machine.
Errors
| HostName is neither a variable nor an atom | type_error(atom, HostName) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
os_version(OSVersion) unifies OSVersion with the operating system version of the machine executing the current GNU Prolog process.
Errors
| OSVersion is neither a variable nor an atom | type_error(atom, OSVersion) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
architecture(Architecture) unifies Architecture with the name of the machine executing the current GNU Prolog process.
Errors
| Architecture is neither a variable nor an atom | type_error(atom, Architecture) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
shell(Command, Status) invokes a new shell (named by the SHELL environment variable) passing Command for execution and unifies Status with the result of the execution. If Command is the empty atom ’’ a new interactive shell is executed. The control is returned to Prolog upon termination of the called process.
shell(Command) is equivalent to shell(Command, 0).
shell is equivalent to shell(’’, 0).
Errors
| Command is a variable | instantiation_error | |
| Command is neither a variable nor an atom | type_error(atom, Command) | |
| Status is neither a variable nor an integer | type_error(integer, Status) | |
Portability
GNU Prolog predicates.
Templates
Description
system(Command, Status) invokes a new default shell passing Command for execution and unifies Status with the result of the execution. The control is returned to Prolog upon termination of the shell process. This predicate is an interface to the C Unix function system(3).
system(Command) is equivalent to system(Command, 0).
Errors
| Command is a variable | instantiation_error | |
| Command is neither a variable nor an atom | type_error(atom, Command) | |
| Status is neither a variable nor an integer | type_error(integer, Status) | |
Portability
GNU Prolog predicates.
Templates
Description
spawn(Command, Arguments, Status) executes Command passing as arguments of the command-line each element of the list Arguments and unifies Status with the result of the execution. The control is returned to Prolog upon termination of the command.
spawn(Command, Arguments) is equivalent to spawn(Command, Arguments, 0).
Errors
| Command is a variable | instantiation_error | |
| Command is neither a variable nor an atom | type_error(atom, Command) | |
| Arguments is a partial list or a list with an element which is a variable | instantiation_error | |
| Arguments is neither a partial list nor a list | type_error(list, Arguments) | |
| an element E of the Arguments list is neither a variable nor an atom | type_error(atom, E) | |
| Status is neither a variable nor an integer | type_error(integer, Status) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicates.
Templates
Description
popen(Command, Mode, Stream) invokes a new default shell (by creating a pipe) passing Command for execution and associates a stream either to the standard input or the standard output of the created process. if Mode is read (resp. write) an input (resp. output) stream is created and Stream is unified with the stream-term associated. Writing to the stream writes to the standard input of the command while reading from the stream reads the command’s standard output. The stream must be closed using close/2 (section 8.10.7). This predicate is an interface to the C Unix function popen(3).
Errors
| Command is a variable | instantiation_error | |
| Command is neither a variable nor an atom | type_error(atom, Command) | |
| Mode is a variable | instantiation_error | |
| Mode is neither a variable nor an atom | type_error(atom, Mode) | |
| Mode is an atom but neither read nor write. | domain_error(io_mode, Mode) | |
| Stream is not a variable | type_error(variable, Stream) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
exec(Command, StreamIn, StreamOut, StreamErr, Pid) invokes a new default shell passing Command for execution and associates streams to standard streams of the created process. StreamIn is unified with the stream-term associated with the standard input stream of Command (it is an output stream). StreamOut is unified with the stream-term associated with the standard output stream of Command (it is an input stream). StreamErr is unified with the stream-term associated with the standard error stream of Command (it is an input stream). Pid is unified with the process identifier of the new process. This information is only useful if it is necessary to obtain the status of the execution using wait/2 (section 8.27.25). Until a call to wait/2 is done the process remains in the system processes table (as a zombie process if terminated). For this reason, if the status is not needed it is preferable to use exec/4.
exec/4 is similar to exec/5 but the process is removed from system processes as soon as it is terminated.
Errors
| Command is a variable | instantiation_error | |
| Command is neither a variable nor an atom | type_error(atom, Command) | |
| StreamIn is not a variable | uninstantiation_error(StreamIn) | |
| StreamOut is not a variable | uninstantiation_error(StreamOut) | |
| StreamErr is not a variable | uninstantiation_error(StreamErr) | |
| Pid is not a variable | uninstantiation_error(Pid) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicates.
Templates
Description
fork_prolog(Pid) creates a child process that differs from the parent process only in its PID. In the parent process Pid is unified with the PID of the child while in the child process Pid is unified with 0. In the parent process, the status of the child process can be obtained using wait/2 (section 8.27.25). Until a call to wait/2 is done the child process remains in the system processes table (as a zombie process if terminated). This predicate is an interface to the C Unix function fork(2).
Errors
| Pid is not a variable | uninstantiation_error(Pid) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
create_pipe(StreamIn, StreamOut) creates a pair of streams pointing to a pipe inode. StreamIn is unified with the stream-term associated with the input side of the pipe and StreamOut is unified with the stream-term associated with output side. This predicate is an interface to the C Unix function pipe(2).
Errors
| StreamIn is not a variable | uninstantiation_error(StreamIn) | |
| StreamOut is not a variable | uninstantiation_error(StreamOut) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
wait(Pid, Status) waits for the child process whose identifier is Pid to terminate. Status is then unified with the exit status. This predicate is an interface to the C Unix function waitpid(2).
Errors
| Pid is a variable | instantiation_error | |
| Pid is neither a variable nor an integer | type_error(integer, Pid) | |
| Status is neither a variable nor an integer | type_error(integer, Status) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
prolog_pid(Pid) unifies Pid with the process identifier of the current GNU Prolog process.
Errors
| Pid is neither a variable nor an integer | type_error(integer, Pid) | |
Portability
GNU Prolog predicate.
Templates
Description
send_signal(Pid, Signal) sends Signal to the process whose identifier is Pid. Signal can be specified directly as an integer or symbolically as an atom. Allowed atoms depend on the machine (e.g. ’SIGINT’, ’SIGQUIT’, ’SIGKILL’, ’SIGUSR1’, ’SIGUSR2’, ’SIGALRM’,…). This predicate is an interface to the C Unix function kill(2).
Errors
| Pid is a variable | instantiation_error | |
| Pid is neither a variable nor an integer | type_error(integer, Pid) | |
| Signal is a variable | instantiation_error | |
| Signal is neither a variable nor an integer or an atom | type_error(integer, Signal) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
Templates
Description
sleep(Seconds) puts the GNU Prolog process to sleep for Seconds seconds. Seconds can be an integer or a floating point number (in which case it can be < 1). This predicate is an interface to the C Unix function usleep(3).
Errors
| Seconds is a variable | instantiation_error | |
| Seconds is neither a variable nor a number | type_error(number, Seconds) | |
| Seconds is a number < 0 | domain_error(not_less_than_zero, Seconds) | |
Portability
GNU Prolog predicate.
Templates
Description
select(Reads, ReadyReads, Writes, ReadyWrites, TimeOut) waits for a number of streams (or file descriptors) to change status. ReadyReads is unified with the list of elements listed in Reads that have characters available for reading. Similarly ReadyWrites is unified with the list of elements of Writes that are ok for immediate writing. The elements of Reads and Writes are either stream-terms or aliases or integers considered as file descriptors, e.g. for sockets (section 8.28). Streams that must be tested with select/5 should not be buffered. This can be done at the opening using open/4 (section 8.10.6) or later using set_stream_buffering/2 (section 8.10.27). TimeOut is an upper bound on the amount of time (in milliseconds) elapsed before select/5 returns. If TimeOut ≤ 0 (no timeout) select/5 waits until something is available (either or reading or for writing) and thus can block indefinitely. This predicate is an interface to the C Unix function select(2).
Errors
| Reads (or Writes) is a partial list or a list with an element E which is a variable | instantiation_error | |
| Reads is neither a partial list nor a list | type_error(list, Reads) | |
| Writes is neither a partial list nor a list | type_error(list, Writes) | |
| ReadyReads is neither a partial list nor a list | type_error(list, ReadyReads) | |
| ReadyWrites is neither a partial list nor a list | type_error(list, ReadyWrites) | |
| an element E of the Reads (or Writes) list is neither a stream-term or alias nor an integer | domain_error(stream_or_alias, E) | |
| an element E of the Reads (or Writes) list is not a selectable item | domain_error(selectable_item, E) | |
| an element E of the Reads (or Writes) list is an integer < 0 | domain_error(not_less_than_zero, E) | |
| an element E of the Reads (or Writes) list is a stream-tern or alias not associated with an open stream | existence_error(stream, E) | |
| an element E of the Reads list is associated with an output stream | permission_error(input, stream, E) | |
| an element E of the Writes list is associated with an input stream | permission_error(output, stream, E) | |
| TimeOut is a variable | instantiation_error | |
| TimeOut is neither a variable nor a number | type_error(number, TimeOut) | |
| an operating system error occurs and the value of the os_error Prolog flag is error (section 8.22.1) | system_error(atom explaining the error) | |
Portability
GNU Prolog predicate.
 
 
