mirror of
				https://gitlab.com/freepascal.org/fpc/source.git
				synced 2025-10-25 11:42:10 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			2558 lines
		
	
	
		
			77 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
			
		
		
	
	
			2558 lines
		
	
	
		
			77 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
| %
 | |
| %   $Id$
 | |
| %   This file is part of the FPC documentation.
 | |
| %   Copyright (C) 1997, by Michael Van Canneyt
 | |
| %
 | |
| %   The FPC documentation is free text; you can redistribute it and/or
 | |
| %   modify it under the terms of the GNU Library General Public License as
 | |
| %   published by the Free Software Foundation; either version 2 of the
 | |
| %   License, or (at your option) any later version.
 | |
| %
 | |
| %   The FPC Documentation is distributed in the hope that it will be useful,
 | |
| %   but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| %   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
| %   Library General Public License for more details.
 | |
| %
 | |
| %   You should have received a copy of the GNU Library General Public
 | |
| %   License along with the FPC documentation; see the file COPYING.LIB.  If not,
 | |
| %   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 | |
| %   Boston, MA 02111-1307, USA. 
 | |
| %
 | |
| \chapter{The LINUX unit.}
 | |
| This chapter describes the LINUX unit for Free Pascal. The unit was written
 | |
| by Micha\"el van Canneyt. It works only on the Linux operating system.
 | |
| This chapter is divided in 2 sections:
 | |
| \begin{itemize}
 | |
| \item The first section lists all constants, types and variables, as listed
 | |
| in the interface section of the LINUX unit.
 | |
| \item The second section describes all procedures and functions in the LINUX
 | |
| unit.
 | |
| \end{itemize}
 | |
| \section{Type, Variable and Constant declarations}
 | |
| \subsection{Types}
 | |
| \label{sec:types}
 | |
| PGlob and TGlob are 2 types used in the \seef{Glob} function:
 | |
| \begin{verbatim}
 | |
| PGlob = ^TGlob;
 | |
| TGlob = record
 | |
|   Name : PChar;
 | |
|   Next : PGlob;
 | |
|   end;
 | |
| \end{verbatim}
 | |
| The following types are used in the signal-processing procedures.
 | |
| \begin{verbatim}
 | |
| {$Packrecords 1}
 | |
| SignalHandler   = Procedure ( Sig : Integer);cdecl;
 | |
| PSignalHandler  = SignalHandler;
 | |
| SignalRestorer  = Procedure;cdecl;
 | |
| PSignalrestorer = SignalRestorer;
 | |
| SigActionRec = Record
 | |
|   Sa_Handler  : Signalhandler;
 | |
|   Sa_Mask     : Longint;
 | |
|   Sa_flags    : Integer;
 | |
|   Sa_Restorer : SignalRestorer;
 | |
| end;
 | |
| PSigActionRec = ^SigActionRec;
 | |
| \end{verbatim}
 | |
| Stat is used to store information about a file. It is defined in the
 | |
| syscalls unit.
 | |
| \begin{verbatim}
 | |
|   stat = record
 | |
|      dev    : word;
 | |
|      pad1   : word;
 | |
|      ino    : longint;
 | |
|      mode   : word;
 | |
|      nlink  : word;
 | |
|      uid    : word;
 | |
|      gid    : word;
 | |
|      rdev   : word;
 | |
|      pad2   : word;
 | |
|      size   : longint;
 | |
|      blksze : Longint;
 | |
|      blocks : Longint;
 | |
|      atime  : Longint;
 | |
|      unused1 : longint;
 | |
|      mtime   : Longint;
 | |
|      unused2 : longint;
 | |
|      ctime   : Longint;
 | |
|      unused3 : longint;
 | |
|      unused4 : longint;
 | |
|      unused5 : longint;
 | |
|      end;
 | |
|  \end{verbatim}
 | |
| Statfs is used to store information about a filesystem. It is defined in
 | |
| the syscalls unit.
 | |
| \begin{verbatim}
 | |
|    statfs = record
 | |
|      fstype   : longint;
 | |
|      bsize    : longint;
 | |
|      blocks   : longint;
 | |
|      bfree    : longint;
 | |
|      bavail   : longint;
 | |
|      files    : longint;
 | |
|      ffree    : longint;
 | |
|      fsid     : longint;
 | |
|      namelen  : longint; 
 | |
|      spare    : array [0..6] of longint;
 | |
|      end
 | |
| \end{verbatim}
 | |
| \var{Dir and PDir} are used in the \seef{OpenDir} and \seef{ReadDir}
 | |
| functions. 
 | |
| \begin{verbatim}
 | |
|   TDir =record
 | |
|     fd     : integer;
 | |
|     loc    : longint;
 | |
|     size   : integer;
 | |
|     buf    : pdirent;
 | |
|     nextoff: longint;
 | |
|     dd_max : integer; 
 | |
|     lock   : pointer;
 | |
|   end;
 | |
|   PDir =^TDir;
 | |
| \end{verbatim}
 | |
| \var{Dirent, PDirent} are used in the \seef{ReadDir} function to return files in a directory.
 | |
| \begin{verbatim}
 | |
|  PDirent = ^Dirent;
 | |
|  Dirent = Record  
 | |
|    ino,
 | |
|    off    : longint;
 | |
|    reclen : word;
 | |
|    name   : string[255]
 | |
|  end; 
 | |
| \end{verbatim}
 | |
| Termio and Termios are used with iotcl() calls for terminal handling.
 | |
| \begin{verbatim}
 | |
| Const  NCCS = 19;
 | |
|        NCC = 8;
 | |
|          
 | |
| Type termio = record
 | |
| 	c_iflag,		{ input mode flags }
 | |
| 	c_oflag,		{ output mode flags }
 | |
| 	c_cflag,		{ control mode flags }
 | |
| 	c_lflag : Word;		{ local mode flags }
 | |
| 	c_line : Word;		{ line discipline - careful, only High byte in use}
 | |
| 	c_cc : array [0..NCC-1] of char;	{ control characters }
 | |
| end;
 | |
| termios = record
 | |
|   c_iflag,              { input mode flags }
 | |
|   c_oflag,              { output mode flags }
 | |
|   c_cflag,              { control mode flags }
 | |
|   c_lflag : Cardinal;	{ local mode flags }
 | |
|   c_line : char;          { line discipline }
 | |
|   c_cc : array [0..NCCS-1] of char;      { control characters }
 | |
| end;
 | |
| \end{verbatim}
 | |
| \var{Utimbuf} is used in the \seef{Utime} call to set access and modificaton time
 | |
| of a file.
 | |
| \begin{verbatim}
 | |
| utimbuf = record
 | |
|   actime,modtime : Longint;
 | |
|   end;
 | |
| \end{verbatim}
 | |
| For the \seef{Select} call, the following 4 types are needed:
 | |
| \begin{verbatim}
 | |
| FDSet = Array [0..31] of longint;
 | |
| PFDSet = ^FDSet;
 | |
| TimeVal = Record
 | |
|    sec,usec : Longint;
 | |
| end;
 | |
| PTimeVal = ^TimeVal;
 | |
| \end{verbatim}
 | |
| The \seep{Uname} function uses the \var{utsname} to return information about
 | |
| the current kernel :
 | |
| \begin{verbatim}
 | |
| utsname =record
 | |
|   sysname,nodename,release,
 | |
|   version,machine,domainname : Array[0..64] of char;
 | |
| end;
 | |
| \end{verbatim}
 | |
| Its elements are null-terminated C style strings, you cannot access them
 | |
| directly !
 | |
| \subsection{Variables}
 | |
| \var{Linuxerror} is the variable in which the procedures in the linux unit
 | |
| report errors.
 | |
| \begin{verbatim}
 | |
| LinuxError : Longint;
 | |
| \end{verbatim}
 | |
| \var{StdErr} Is a \var{Text} variable, corresponding to Standard Error or
 | |
| diagnostic output. It is connected to file descriptor 2. It can be freely
 | |
| used, and will be closed on exit.
 | |
| \begin{verbatim}
 | |
| StdErr : Text;
 | |
| \end{verbatim}
 | |
| \subsection{Constants}
 | |
| Constants for setting/getting process priorities :
 | |
| \begin{verbatim}
 | |
|       Prio_Process = 0;
 | |
|       Prio_PGrp    = 1;
 | |
|       Prio_User    = 2;
 | |
| \end{verbatim}
 | |
| For testing  access rights:
 | |
| \begin{verbatim}
 | |
|       R_OK = 4; 
 | |
|       W_OK = 2;
 | |
|       X_OK = 1;
 | |
|       F_OK = 0;
 | |
| \end{verbatim}
 | |
| For signal handling functions :
 | |
| \begin{verbatim}
 | |
|       SA_NOCLDSTOP = 1;
 | |
|       SA_SHIRQ	   = $04000000;
 | |
|       SA_STACK	   = $08000000;      
 | |
|       SA_RESTART   = $10000000;
 | |
|       SA_INTERRUPT = $20000000;
 | |
|       SA_NOMASK	   = $40000000;
 | |
|       SA_ONESHOT   = $80000000;
 | |
|       
 | |
|       SIG_BLOCK	  = 0;
 | |
|       SIG_UNBLOCK = 1;
 | |
|       SIG_SETMASK = 2;
 | |
|       SIG_DFL = 0 ;
 | |
|       SIG_IGN = 1 ;
 | |
|       SIG_ERR = -1;
 | |
|       
 | |
|       SIGHUP		= 1;
 | |
|       SIGINT		= 2;
 | |
|       SIGQUIT		= 3;
 | |
|       SIGILL		= 4;
 | |
|       SIGTRAP		= 5;
 | |
|       SIGABRT		= 6;
 | |
|       SIGIOT		= 6;
 | |
|       SIGBUS		= 7;
 | |
|       SIGFPE		= 8;
 | |
|       SIGKILL		= 9;
 | |
|       SIGUSR1		= 10;
 | |
|       SIGSEGV		= 11;
 | |
|       SIGUSR2		= 12;
 | |
|       SIGPIPE		= 13;
 | |
|       SIGALRM		= 14;
 | |
|       SIGTERM		= 15;
 | |
|       SIGSTKFLT		= 16;
 | |
|       SIGCHLD		= 17;
 | |
|       SIGCONT		= 18;
 | |
|       SIGSTOP		= 19;
 | |
|       SIGTSTP		= 20;
 | |
|       SIGTTIN		= 21;
 | |
|       SIGTTOU		= 22;
 | |
|       SIGURG		= 23;
 | |
|       SIGXCPU		= 24;
 | |
|       SIGXFSZ		= 25;
 | |
|       SIGVTALRM		= 26;
 | |
|       SIGPROF		= 27;
 | |
|       SIGWINCH		= 28;
 | |
|       SIGIO		= 29;
 | |
|       SIGPOLL		= SIGIO;
 | |
|       SIGPWR		= 30;
 | |
|       SIGUNUSED		= 31;
 | |
| \end{verbatim}
 | |
| For file control mechanism :
 | |
| \begin{verbatim}
 | |
|       F_GetFd  = 1;
 | |
|       F_SetFd  = 2;
 | |
|       F_GetFl  = 3;
 | |
|       F_SetFl  = 4;
 | |
|       F_GetLk  = 5;
 | |
|       F_SetLk  = 6;
 | |
|       F_SetLkW = 7;
 | |
|       F_GetOwn = 8;
 | |
|       F_SetOwn = 9;
 | |
| \end{verbatim}
 | |
| For Terminal handling :
 | |
| \begin{verbatim}
 | |
|    TCGETS	= $5401 ;
 | |
|    TCSETS	= $5402 ;
 | |
|    TCSETSW	= $5403 ;
 | |
|    TCSETSF	= $5404 ;
 | |
|    TCGETA	= $5405 ;
 | |
|    TCSETA	= $5406 ;
 | |
|    TCSETAW	= $5407 ;
 | |
|    TCSETAF	= $5408 ;
 | |
|    TCSBRK	= $5409 ;
 | |
|    TCXONC	= $540A ;
 | |
|    TCFLSH	= $540B ;
 | |
|    TIOCEXCL	= $540C ;
 | |
|    TIOCNXCL	= $540D ;
 | |
|    TIOCSCTTY	= $540E ;
 | |
|    TIOCGPGRP	= $540F ;
 | |
|    TIOCSPGRP	= $5410 ;
 | |
|    TIOCOUTQ	= $5411 ;
 | |
|    TIOCSTI	= $5412 ;
 | |
|    TIOCGWINSZ	= $5413 ;
 | |
|    TIOCSWINSZ	= $5414 ;
 | |
|    TIOCMGET	= $5415 ;
 | |
|    TIOCMBIS	= $5416 ;
 | |
|    TIOCMBIC	= $5417 ;
 | |
|    TIOCMSET	= $5418 ;
 | |
|    TIOCGSOFTCAR	= $5419 ;
 | |
|    TIOCSSOFTCAR	= $541A ;
 | |
|    FIONREAD	= $541B ;
 | |
|    TIOCINQ	= FIONREAD;
 | |
|    TIOCLINUX	= $541C ;
 | |
|    TIOCCONS	= $541D ;
 | |
|    TIOCGSERIAL	= $541E ;
 | |
|    TIOCSSERIAL	= $541F ;
 | |
|    TIOCPKT	= $5420 ;
 | |
|    FIONBIO	= $5421 ;
 | |
|    TIOCNOTTY	= $5422 ;
 | |
|    TIOCSETD	= $5423 ;
 | |
|    TIOCGETD	= $5424 ;
 | |
|    TCSBRKP		= $5425	 ;
 | |
|    TIOCTTYGSTRUCT	= $5426  ;
 | |
|    FIONCLEX	= $5450  ;
 | |
|    FIOCLEX		= $5451 ;
 | |
|    FIOASYNC	= $5452 ;
 | |
|    TIOCSERCONFIG	= $5453 ;
 | |
|    TIOCSERGWILD	= $5454 ;
 | |
|    TIOCSERSWILD	= $5455 ;
 | |
|    TIOCGLCKTRMIOS	= $5456 ;
 | |
|    TIOCSLCKTRMIOS	= $5457 ;
 | |
|    TIOCSERGSTRUCT	= $5458  ;
 | |
|    TIOCSERGETLSR   = $5459  ;
 | |
|    TIOCSERGETMULTI = $545A  ;
 | |
|    TIOCSERSETMULTI = $545B  ;
 | |
|    TIOCMIWAIT	= $545C	;
 | |
|    TIOCGICOUNT	= $545D	;
 | |
|    TIOCPKT_DATA		= 0;
 | |
|    TIOCPKT_FLUSHREAD	= 1;
 | |
|    TIOCPKT_FLUSHWRITE	= 2;
 | |
|    TIOCPKT_STOP		= 4;
 | |
|    TIOCPKT_START	= 8;
 | |
|    TIOCPKT_NOSTOP	= 16;
 | |
|    TIOCPKT_DOSTOP	= 32;
 | |
| \end{verbatim}
 | |
| Other than that, all constants for setting the speed and control flags of a
 | |
| terminal line, as described in the \seem{termios}{2} man
 | |
| page, are defined in the linux unit. It would take too much place to list
 | |
| them here. 
 | |
| To check the \var{mode} field of a \var{stat} record, you ca use the
 | |
| following constants :
 | |
| \begin{verbatim}
 | |
|   { Constants to check stat.mode }
 | |
|   STAT_IFMT   = $f000; {00170000}
 | |
|   STAT_IFSOCK = $c000; {0140000}
 | |
|   STAT_IFLNK  = $a000; {0120000}
 | |
|   STAT_IFREG  = $8000; {0100000}
 | |
|   STAT_IFBLK  = $6000; {0060000}
 | |
|   STAT_IFDIR  = $4000; {0040000}
 | |
|   STAT_IFCHR  = $2000; {0020000}
 | |
|   STAT_IFIFO  = $1000; {0010000}
 | |
|   STAT_ISUID  = $0800; {0004000}
 | |
|   STAT_ISGID  = $0400; {0002000}
 | |
|   STAT_ISVTX  = $0200; {0001000}
 | |
|   { Constants to check permissions }
 | |
|   STAT_IRWXO = $7;
 | |
|   STAT_IROTH = $4;
 | |
|   STAT_IWOTH = $2;
 | |
|   STAT_IXOTH = $1;
 | |
|   STAT_IRWXG = STAT_IRWXO shl 3;
 | |
|   STAT_IRGRP = STAT_IROTH shl 3;
 | |
|   STAT_IWGRP = STAT_IWOTH shl 3;
 | |
|   STAT_IXGRP = STAT_IXOTH shl 3;
 | |
|   STAT_IRWXU = STAT_IRWXO shl 6;
 | |
|   STAT_IRUSR = STAT_IROTH shl 6;
 | |
|   STAT_IWUSR = STAT_IWOTH shl 6;
 | |
|   STAT_IXUSR = STAT_IXOTH shl 6;
 | |
| \end{verbatim}
 | |
| You can test the type of a filesystem returned by a \seef{FSStat} call with
 | |
| the following constants:
 | |
| \begin{verbatim}
 | |
|   fs_old_ext2 = $ef51;
 | |
|   fs_ext2     = $ef53;
 | |
|   fs_ext      = $137d;
 | |
|   fs_iso      = $9660;
 | |
|   fs_minix    = $137f;
 | |
|   fs_minix_30 = $138f;
 | |
|   fs_minux_V2 = $2468;
 | |
|   fs_msdos    = $4d44;
 | |
|   fs_nfs      = $6969;
 | |
|   fs_proc     = $9fa0;
 | |
|   fs_xia      = $012FD16D;
 | |
| \end{verbatim}
 | |
| the \seep{FLock} call uses the following mode constants :
 | |
| \begin{verbatim}
 | |
|   LOCK_SH = 1;
 | |
|   LOCK_EX = 2;
 | |
|   LOCK_UN = 8;
 | |
|   LOCK_NB = 4;
 | |
| \end{verbatim}
 | |
| \section{Functions and procedures}
 | |
| \begin{function}{Access}
 | |
| \Declaration
 | |
| Function Access (Path : Pathstr; Mode : integer) : Boolean;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Tests user's access rights on the specified file. Mode is a mask existing of
 | |
| one or more of
 | |
| \begin{description}
 | |
| \item[R\_OK] User has read rights.
 | |
| \item[W\_OK] User has write rights.
 | |
| \item[X\_OK] User has execute rights.
 | |
| \item[F\_OK] User has search rights in the directory where the file is.
 | |
| \end{description}
 | |
| The test is done with the real user ID, instead of the effective user ID.
 | |
| If access is denied, or an error occurred, false is returned.
 | |
| 
 | |
| \Errors
 | |
|  \var{LinuxError} is used to report errors:
 | |
| \begin{description}
 | |
| \item[sys\_eaccess] The requested access is denied, either to the file or one
 | |
| of the directories in its path.
 | |
| \item[sys\_einval] \var{Mode} was incorrect.
 | |
| \item[sys\_enoent] A directory component in \var{Path} doesn't exist or is a
 | |
| dangling symbolic link.
 | |
| \item[sys\_enotdir] A directory component in \var{Path} is not a directory.
 | |
| \item[sys\_enomem] Insufficient kernel memory.
 | |
| \item[sys\_eloop] \var{Path} has a circular symbolic link.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{Chown}, \seef{Chmod}, \seem{Access}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex26.pp}}
 | |
| \html{\input{linuxex/ex26.tex}}
 | |
| \begin{procedure}{AssignPipe}
 | |
| \Declaration
 | |
| Procedure AssignPipe (Pipe\_in, Pipe\_out : Text);
 | |
| 
 | |
| \Description
 | |
| \var{AssignePipe} creates a pipe, i.e. two file objects, one for input, one for output.
 | |
| What is written to \var{Pipe\_out}, can be read from \var{Pipe\_in}.
 | |
| Reading and writing happens through the usual \var{Readln(Pipe\_in,...)} and
 | |
| \var{Writeln (Pipe\_out,...)} procedures.
 | |
| 
 | |
| \Errors
 | |
|  \var{LinuxError} is used to report errors:
 | |
| \begin{description}
 | |
| \item[sys\_emfile] Too many file descriptors for this process.
 | |
| \item[sys\_enfile] The system file table is full.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{POpen}, \seef{MkFifo}, \seem{pipe}{2}
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex36.pp}}
 | |
| \html{\input{linuxex/ex36.tex}}
 | |
| \begin{procedure}{AssignStream}
 | |
| \Declaration
 | |
| Procedure AssignStream (StreamIn,StreamOut : Text; Const prog : String);
 | |
| 
 | |
| \Description
 | |
| \var{AssignStream} creates a 2 pipes, i.e. two file objects, one for input, one for
 | |
| output, the other ends of these pipes are connected to standard input and and
 | |
| output of \var{Prog}. \var{Prog} is the name of a program (including path)
 | |
| with options, which will be executed.
 | |
| What is written to \var{StreamOut}, will go to the standard input of
 | |
| \var{Prog}. Whatever is written by \var{Prog} to it's standard output be read from
 | |
| \var{StreamIn}.
 | |
| Reading and writing happens through the usual \var{Readln(StreamIn,...)} and
 | |
| \var{Writeln (StreamOut,...)} procedures.
 | |
| 
 | |
| {\em Remark:} You should {\em not} use \var{Reset} or \var{Rewrite} on a 
 | |
| file opened with \var{POpen}. This will close the file before re-opening 
 | |
| it again, thereby closing the connection with the program.
 | |
| 
 | |
| \Errors
 | |
|  \var{LinuxError} is used to report errors:
 | |
| \begin{description}
 | |
| \item[sys\_emfile] Too many file descriptors for this process.
 | |
| \item[sys\_enfile] The system file table is full.
 | |
| \end{description}
 | |
| Other errors include the ones by the fork and exec programs
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{AssignPipe}, \seep{POpen},\seem{pipe}{2}
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex38.pp}}
 | |
| \html{\input{linuxex/ex38.tex}}
 | |
| \begin{function}{BaseName}
 | |
| \Declaration
 | |
| Function BaseName (Const Path;Suf : Pathstr) : Pathstr;
 | |
| 
 | |
| \Description
 | |
| Returns the filename part of \var{Path}, stripping off \var{Suf} if it
 | |
| exists.
 | |
| The filename part is the whole name if \var{Path} contains no slash,
 | |
| or the part of \var{Path} after the last slash.
 | |
| The last character of the result is not a slash, unless the directory is the
 | |
| root directory.
 | |
| 
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{DirName}, \seef{FExpand}, \seem{Basename}{1}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex48.pp}}
 | |
| \html{\input{linuxex/ex48.tex}}
 | |
| \begin{procedure}{CFMakeRaw}
 | |
| \Declaration
 | |
| Procedure CFMakeRaw (var Tios:TermIOS);
 | |
| 
 | |
| \Description
 | |
|  \var{CFMakeRaw}
 | |
|   Sets the flags in the \var{Termios} structure \var{Tios} to a state so that 
 | |
|   the terminal will function in Raw Mode.
 | |
| 
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
|  \seep{CFSetOSpeed}, \seep{CFSetISpeed}, \seem{termios}{2}
 | |
| \end{procedure}
 | |
| For an example, see \seef{TCGetAttr}.
 | |
| \begin{procedure}{CFSetISpeed}
 | |
| \Declaration
 | |
| Procedure CFSetISpeed (var Tios:TermIOS;Speed:Longint);
 | |
| 
 | |
| \Description
 | |
|  \var{CFSetISpeed}
 | |
|   Sets the input baudrate in the \var{TermIOS} structure \var{Tios} to 
 | |
|   \var{Speed}.
 | |
| 
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seep{CFSetOSpeed}, \seep{CFMakeRaw}, \seem{termios}{2}
 | |
| \end{procedure}
 | |
| \begin{procedure}{CFSetOSpeed}
 | |
| \Declaration
 | |
| Procedure CFSetOSpeed (var Tios:TermIOS;Speed:Longint);
 | |
| 
 | |
| \Description
 | |
|  \var{CFSetOSpeed}
 | |
|   Sets the output baudrate in the \var{Termios} structure \var{Tios} to
 | |
|   \var{Speed}.
 | |
| 
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seep{CFSetISpeed}, \seep{CFMakeRaw}, \seem{termios}{2}
 | |
| \end{procedure}
 | |
| \begin{function}{Chown}
 | |
| \Declaration
 | |
| Function Chown (Path : Pathstr;NewUid,NewGid : Longint) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{Chown} sets the User ID and Group ID of the file in \var{Path} to \var{NewUid,
 | |
| NewGid}.
 | |
| The function returns \var{True} if the call was succesfull, \var{False} if the call
 | |
| failed.
 | |
| 
 | |
| \Errors
 | |
| 
 | |
| Errors are returned in \var{LinuxError}.
 | |
| \begin{description}
 | |
| \item[sys\_eperm] The effective UID doesn't match the ownership of the file,
 | |
| and is not zero. Owner or group were not specified correctly.
 | |
| \item[sys\_eaccess] One of the directories in \var{Path} has no
 | |
| search (=execute) permission.
 | |
| \item[sys\_enoent] A directory entry in \var{Path} does
 | |
| not exist or is a symbolic link pointing to a non-existent directory.
 | |
| \item[sys\_enotdir] A directory entry in \var{OldPath} or \var{NewPath} is
 | |
| nor a directory.
 | |
| \item[sys\_enomem] Insufficient kernel memory.
 | |
| \item[sys\_erofs] The file is on a read-only filesystem.
 | |
| \item[sys\_eloop] \var{Path} has a reference to a circular
 | |
| symbolic link, i.e. a symbolic link, whose expansion points to itself.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{Chmod}, \seef{Access}, \seem{Chown}(2)
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex24.pp}}
 | |
| \html{\input{linuxex/ex24.tex}}
 | |
| \begin{function}{Chmod}
 | |
| \Declaration
 | |
| Function Chmod (Path : Pathstr;NewMode : Longint) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{Chmod}
 | |
| Sets the Mode bits of the file in \var{Path} to \var{NewMode}. Newmode can be
 | |
| specified by 'or'-ing the following:
 | |
| \begin{description}
 | |
| \item[S\_ISUID] Set user ID on execution.
 | |
| \item[S\_ISGID] Set Group ID on execution.
 | |
| \item[S\_ISVTX] Set sticky bit.
 | |
| \item[S\_IRUSR] Read by owner.
 | |
| \item[S\_IWUSR] Write by owner.
 | |
| \item[S\_IXUSR] Execute by owner.
 | |
| \item[S\_IRGRP] Read by group.
 | |
| \item[S\_IWGRP] Write by group.
 | |
| \item[S\_IXGRP] Execute by group.
 | |
| \item[S\_IROTH] Read by others.
 | |
| \item[S\_IWOTH] Write by others.
 | |
| \item[S\_IXOTH] Execute by others.
 | |
| \item[S\_IRWXO] Read, write, execute by others.
 | |
| \item[S\_IRWXG] Read, write, execute by groups.
 | |
| \item[S\_IRWXU] Read, write, execute by user.
 | |
| \end{description}
 | |
| 
 | |
| \Errors
 | |
| 
 | |
| Errors are returned in \var{LinuxError}.
 | |
| \begin{description}
 | |
| \item[sys\_eperm] The effective UID doesn't match the ownership of the file,
 | |
| and is not zero. Owner or group were not specified correctly.
 | |
| \item[sys\_eaccess] One of the directories in \var{Path} has no
 | |
| search (=execute) permission.
 | |
| \item[sys\_enoent] A directory entry in \var{Path} does
 | |
| not exist or is a symbolic link pointing to a non-existent directory.
 | |
| \item[sys\_enotdir] A directory entry in \var{OldPath} or \var{NewPath} is
 | |
| nor a directory.
 | |
| \item[sys\_enomem] Insufficient kernel memory.
 | |
| \item[sys\_erofs] The file is on a read-only filesystem.
 | |
| \item[sys\_eloop] \var{Path} has a reference to a circular
 | |
| symbolic link, i.e. a symbolic link, whose expansion points to itself.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{Chown}, \seef{Access}, \seem{Chmod}(2)
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex23.pp}}
 | |
| \html{\input{linuxex/ex23.tex}}
 | |
| \begin{function}{CloseDir}
 | |
| \Declaration
 | |
| Function CloseDir (p:pdir) : integer;
 | |
| 
 | |
| \Description
 | |
|  \var{CloseDir} closes the directory pointed to by \var{p}.
 | |
| It returns zero if the directory was closed succesfully, -1 otherwise.
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{OpenDir}, \seef{ReadDir}, \seep{SeekDir}, \seef{TellDir},
 | |
| \seem{closedir}{3}
 | |
| \end{function}
 | |
| For an example, see \seef{OpenDir}.
 | |
| \begin{function}{DirName}
 | |
| \Declaration
 | |
| Function DirName (Const Path : Pathstr) : Pathstr;
 | |
| 
 | |
| \Description
 | |
| Returns the directory part of \var{Path}.
 | |
| The directory is the part of \var{Path} before the last slash,
 | |
| or empty if there is no slash.
 | |
| The last character of the result is not a slash, unless the directory is the
 | |
| root directory.
 | |
| 
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{BaseName}, \seef{FExpand}, \seem{Dirname}{1}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex47.pp}}
 | |
| \html{\input{linuxex/ex47.tex}}
 | |
| \begin{procedure}{Dup}
 | |
| \Declaration
 | |
| Procedure Dup (Var OldFile, NewFile : Text);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Makes \var{NewFile} an exact copy of \var{OldFile}, after having flushed the
 | |
| buffer of \var{OldFile}. Due to the buffering mechanism of Pascal, this has not
 | |
| the same functionality as the \seem{dup}{2} call in C. The internal Pascal
 | |
| buffers are not the same after this call, but when the buffers are flushed
 | |
| (e.g. after output), the output is sent to the same file.
 | |
| Doing an lseek will, however, work as in C, i.e. doing a lseek will change the
 | |
| fileposition in both files.
 | |
| 
 | |
| \Errors
 | |
|  \var{Linuxerror} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_ebadf] \var{OldFile} hasn't been assigned.
 | |
| \item[sys\_emfile] Maximum number of open files for the process is reached.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{Dup2}, \seem{Dup}{2} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex31.pp}}
 | |
| \html{\input{linuxex/ex31.tex}}
 | |
| \begin{procedure}{Dup2}
 | |
| \Declaration
 | |
| Procedure Dup2 (Var OldFile, NewFile : Text);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Makes \var{NewFile} an exact copy of \var{OldFile}, after having flushed the
 | |
| buffer of \var{OldFile}. \var{NewFile} can be an assigned file.
 | |
| If \var{newfile} was open, it is closed first.
 | |
| Due to the buffering mechanism of Pascal, this has not
 | |
| the same functionality as the \seem{dup2}{2} call in C. The internal Pascal
 | |
| buffers are not the same after this call, but when the buffers are flushed
 | |
| (e.g. after output), the output is sent to the same file.
 | |
| Doing an lseek will, however, work as in C, i.e. doing a lseek will change the
 | |
| fileposition in both files.
 | |
| 
 | |
| \Errors
 | |
|  \var{Linuxerror} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_ebadf] \var{OldFile} hasn't been assigned.
 | |
| \item[sys\_emfile] Maximum number of open files for the process is reached.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
|  \seep{Dup}, \seem{Dup2}{2} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex32.pp}}
 | |
| \html{\input{linuxex/ex32.tex}}
 | |
| \begin{procedure}{EpochToLocal}
 | |
| \Declaration
 | |
| Procedure EpochToLocal (Epoch : Longint; var Year,Month,Day,Hour,Minute,Second : Word);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Converts the epoch time (=Number of seconds since 00:00:00 , January 1,
 | |
| 1970, corrected for your time zone ) to local date and time.
 | |
| 
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
| \seef{GetEpochTime}, \seef{LocalToEpoch}, \seep{GetTime},\seep{GetDate} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex3.pp}}
 | |
| \html{\input{linuxex/ex3.tex}}
 | |
| \begin{procedure}{Execl}
 | |
| \Declaration
 | |
| Procedure Execl (Path : pathstr);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Replaces the currently running program with the program, specified in
 | |
| \var{path}. Path is split into a command and it's options.
 | |
| The executable in \var{path} is NOT searched in the path.
 | |
| The current environment is passed to the program.
 | |
| On success, \var{execl} does not return.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in \var{LinuxError}:
 | |
| \begin{description}
 | |
| \item[sys\_eacces] File is not a regular file, or has no execute permission.
 | |
| A compononent of the path has no search permission.
 | |
| \item[sys\_eperm] The file system is mounted \textit{noexec}.
 | |
| \item[sys\_e2big] Argument list too big.
 | |
| \item[sys\_enoexec] The magic number in the file is incorrect.
 | |
| \item[sys\_enoent] The file does not exist.
 | |
| \item[sys\_enomem] Not enough memory for kernel, or to split command line.
 | |
| \item[sys\_enotdir] A component of the path is not a directory.
 | |
| \item[sys\_eloop] The path contains a circular reference (via symlinks).
 | |
| \end{description}
 | |
| \SeeAlso
 | |
| \seep{Execve}, \seep{Execv}, \seep{Execvp}, \seep{Execle},
 | |
|  \seep{Execlp}, \seef {Fork}, \seem{execvp}{3} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex10.pp}}
 | |
| \html{\input{linuxex/ex10.tex}}
 | |
| \begin{procedure}{Execle}
 | |
| \Declaration
 | |
| Procedure Execle (Path : pathstr, Ep : ppchar);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Replaces the currently running program with the program, specified in
 | |
| \var{path}. Path is split into a command and it's options.
 | |
| The executable in \var{path} is searched in the path, if it isn't
 | |
| an absolute filename.
 | |
| The environment in \var{ep} is passed to the program.
 | |
| On success, \var{execle} does not return.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in \var{LinuxError}:
 | |
| \begin{description}
 | |
| \item[sys\_eacces] File is not a regular file, or has no execute permission.
 | |
| A compononent of the path has no search permission.
 | |
| \item[sys\_eperm] The file system is mounted \textit{noexec}.
 | |
| \item[sys\_e2big] Argument list too big.
 | |
| \item[sys\_enoexec] The magic number in the file is incorrect.
 | |
| \item[sys\_enoent] The file does not exist.
 | |
| \item[sys\_enomem] Not enough memory for kernel, or to split command line.
 | |
| \item[sys\_enotdir] A component of the path is not a directory.
 | |
| \item[sys\_eloop] The path contains a circular reference (via symlinks).
 | |
| \end{description}
 | |
| \SeeAlso
 | |
| \seep{Execve}, \seep{Execv}, \seep{Execvp},
 | |
| \seep{Execl}, \seep{Execlp}, \seef {Fork}, \seem{execvp}{3} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex11.pp}}
 | |
| \html{\input{linuxex/ex11.tex}}
 | |
| \begin{procedure}{Execlp}
 | |
| \Declaration
 | |
| Procedure Execlp (Path : pathstr);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Replaces the currently running program with the program, specified in
 | |
| \var{path}. Path is split into a command and it's options.
 | |
| The executable in \var{path} is searched in the path, if it isn't
 | |
| an absolute filename.
 | |
| The current environment is passed to the program.
 | |
| On success, \var{execlp} does not return.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in \var{LinuxError}:
 | |
| \begin{description}
 | |
| \item[sys\_eacces] File is not a regular file, or has no execute permission.
 | |
| A compononent of the path has no search permission.
 | |
| \item[sys\_eperm] The file system is mounted \textit{noexec}.
 | |
| \item[sys\_e2big] Argument list too big.
 | |
| \item[sys\_enoexec] The magic number in the file is incorrect.
 | |
| \item[sys\_enoent] The file does not exist.
 | |
| \item[sys\_enomem] Not enough memory for kernel, or to split command line.
 | |
| \item[sys\_enotdir] A component of the path is not a directory.
 | |
| \item[sys\_eloop] The path contains a circular reference (via symlinks).
 | |
| \end{description}
 | |
| \SeeAlso
 | |
| \seep{Execve}, \seep{Execv}, \seep{Execvp}, \seep{Execle},
 | |
| \seep{Execl}, \seef {Fork}, \seem{execvp}{3} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex12.pp}}
 | |
| \html{\input{linuxex/ex12.tex}}
 | |
| \begin{procedure}{Execv}
 | |
| \Declaration
 | |
| Procedure Execv (Path : pathstr; args : ppchar);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Replaces the currently running program with the program, specified in
 | |
| \var{path}.
 | |
| It gives the program the options in \var{args}.
 | |
| 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, \var{execv} does not return.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in \var{LinuxError}:
 | |
| \begin{description}
 | |
| \item[sys\_eacces] File is not a regular file, or has no execute permission.
 | |
| A compononent of the path has no search permission.
 | |
| \item[sys\_eperm] The file system is mounted \textit{noexec}.
 | |
| \item[sys\_e2big] Argument list too big.
 | |
| \item[sys\_enoexec] The magic number in the file is incorrect.
 | |
| \item[sys\_enoent] The file does not exist.
 | |
| \item[sys\_enomem] Not enough memory for kernel.
 | |
| \item[sys\_enotdir] A component of the path is not a directory.
 | |
| \item[sys\_eloop] The path contains a circular reference (via symlinks).
 | |
| \end{description}
 | |
| \SeeAlso
 | |
| \seep{Execve}, \seep{Execvp}, \seep{Execle},
 | |
| \seep{Execl}, \seep{Execlp}, \seef {Fork}, \seem{execv}{3} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex8.pp}}
 | |
| \html{\input{linuxex/ex8.tex}}
 | |
| \begin{procedure}{Execve}
 | |
| \Declaration
 | |
| Procedure Execve (Path : pathstr; args,ep : ppchar);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Replaces the currently running program with the program, specified in
 | |
| \var{path}.
 | |
| It gives the program the options in \var{args}, and the environment in
 | |
| \var{ep}. They are pointers to an array of pointers to null-terminated
 | |
| strings. The last pointer in this array should be nil.
 | |
| On success, \var{execve} does not return.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in \var{LinuxError}:
 | |
| \begin{description}
 | |
| \item[eacces] File is not a regular file, or has no execute permission.
 | |
| A compononent of the path has no search permission.
 | |
| \item[sys\_ eperm] The file system is mounted \textit{noexec}.
 | |
| \item[sys\_ e2big] Argument list too big.
 | |
| \item[sys\_ enoexec] The magic number in the file is incorrect.
 | |
| \item[sys\_ enoent] The file does not exist.
 | |
| \item[sys\_ enomem] Not enough memory for kernel.
 | |
| \item[sys\_ enotdir] A component of the path is not a directory.
 | |
| \item[sys\_ eloop] The path contains a circular reference (via symlinks).
 | |
| \end{description}
 | |
| \SeeAlso
 | |
| \seep{Execve}, \seep{Execv}, \seep{Execvp} \seep{Execle},
 | |
| \seep{Execl}, \seep{Execlp}, \seef {Fork}, \seem{execve}{2} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex7.pp}}
 | |
| \html{\input{linuxex/ex7.tex}}
 | |
| \begin{procedure}{Execvp}
 | |
| \Declaration
 | |
| Procedure Execvp (Path : pathstr; args : ppchar);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Replaces the currently running program with the program, specified in
 | |
| \var{path}. The executable in \var{path} is searched in the path, if it isn't
 | |
| an absolute filename.
 | |
| It gives the program the options in \var{args}. 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, \var{execvp} does not return.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in \var{LinuxError}:
 | |
| \begin{description}
 | |
| \item[sys\_eacces] File is not a regular file, or has no execute permission.
 | |
| A compononent of the path has no search permission.
 | |
| \item[sys\_eperm] The file system is mounted \textit{noexec}.
 | |
| \item[sys\_e2big] Argument list too big.
 | |
| \item[sys\_enoexec] The magic number in the file is incorrect.
 | |
| \item[sys\_enoent] The file does not exist.
 | |
| \item[sys\_enomem] Not enough memory for kernel.
 | |
| \item[sys\_enotdir] A component of the path is not a directory.
 | |
| \item[sys\_eloop] The path contains a circular reference (via symlinks).
 | |
| \end{description}
 | |
| \SeeAlso
 | |
| \seep{Execve}, \seep{Execv}, \seep{Execle},
 | |
| \seep{Execl}, \seep{Execlp}, \seef {Fork}, \seem{execvp}{3} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex9.pp}}
 | |
| \html{\input{linuxex/ex9.tex}}
 | |
| \begin{procedurel}{FD\_Clear}{FDClear}
 | |
| \Declaration
 | |
| Procedure FD\_Clear (var fds:fdSet);
 | |
| 
 | |
| \Description
 | |
| \var{FD\_Clear} clears all the filedescriptors in the file descriptor 
 | |
| set \var{fds}.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{Select}, 
 | |
| \seef{SelectText}, 
 | |
| \seef{GetFS}, 
 | |
| \seepl{FD\_Clr}{FDClr},
 | |
| \seepl{FD\_Set}{FDSet}, 
 | |
| \seefl{FD\_IsSet}{FDIsSet}
 | |
| 
 | |
| \end{procedurel}
 | |
| For an example, see \seef{Select}.
 | |
| \begin{procedurel}{FD\_Clr}{FDClr}
 | |
| \Declaration
 | |
| Procedure FD\_Clr (fd:longint;var fds:fdSet);
 | |
| 
 | |
| \Description
 | |
|  \var{FD\_Clr} clears file descriptor \var{fd} in filedescriptor s
 | |
|   et \var{fds}.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{Select}, 
 | |
| \seef{SelectText}, 
 | |
| \seef{GetFS},
 | |
| \seepl{FD\_Clear}{FDClear}, 
 | |
| \seepl{FD\_Set}{FDSet}, 
 | |
| \seefl{FD\_IsSet}{FDIsSet}
 | |
| \end{procedurel}
 | |
| For an example, see \seef{Select}.
 | |
| \begin{functionl}{FD\_IsSet}{FDIsSet}
 | |
| \Declaration
 | |
| Function FD\_IsSet (fd:longint;var fds:fdSet) : boolean;
 | |
| 
 | |
| \Description
 | |
| \var{FD\_Set} Checks whether file descriptor \var{fd} in filedescriptor set \var{fds}
 | |
| is set.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{Select}, \seef{SelectText}, \seef{GetFS},
 | |
| \seepl{FD\_Clear}{FDClear}, 
 | |
| \seepl{FD\_Clr}{FDClr},
 | |
| \seepl{FD\_Set}{FDSet}
 | |
| \end{functionl}
 | |
| For an example, see \seef{Select}.
 | |
| \begin{procedurel}{FD\_Set}{FDSet}
 | |
| \Declaration
 | |
| Procedure FD\_Set (fd:longint;var fds:fdSet);
 | |
| 
 | |
| \Description
 | |
| \var{FD\_Set} sets file descriptor \var{fd} in filedescriptor set \var{fds}.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{Select}, \seef{SelectText}, \seef{GetFS},\seepl{FD\_Clear}{FDClear}, 
 | |
| \seepl{FD\_Clr}{FDClr}, \seefl{FD\_IsSet}{FDIsSet}
 | |
| \end{procedurel}
 | |
| For an example, see \seef{Select}.
 | |
| \begin{function}{fdClose}
 | |
| \Declaration
 | |
| Function fdClose (fd:longint) : boolean;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| \var{fdClose} closes a file with file descriptor \var{Fd}. The function
 | |
| returns \var{True} if the file was closed successfully, \var{False}
 | |
| otherwise. 
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in LinuxError
 | |
| \SeeAlso
 | |
| \seef{fdOpen}, \seef{fdRead}, \seef{fdWrite},\seef{fdTruncate},
 | |
| \seef{fdFlush}, seef{FdSeek}
 | |
| \end{function}
 | |
| For an example, see \seef{fdOpen}.
 | |
| \begin{function}{fdFlush}
 | |
| \Declaration
 | |
| Function fdFlush (fd:Longint) : boolean;
 | |
| 
 | |
| \Description
 | |
| \var{fdflush} flushes the Linux kernel file buffer, so the file is actually
 | |
| written to disk. This is NOT the same as the internal buffer, maintained by
 | |
| Free Pascal. 
 | |
| The function returns \var{True} if the call was successful, \var{false} if
 | |
| an error occurred.
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{fdOpen}, \seef{fdClose}, \seef{fdRead},\seef{fdWrite},
 | |
| \seef{fdTruncate}, \seef{fdSeek}
 | |
| \end{function}
 | |
| For an example, see \seef{fdRead}.
 | |
| \begin{function}{fdOpen}
 | |
| \Declaration
 | |
| Function fdOpen (Var PathName;flags:longint[; Mode: longint]) : longint;
 | |
| 
 | |
| \Description
 | |
|  \var{fdOpen} opens a file in \var{pathname} with flags \var{flags} a ORed combination of
 | |
|   \var{Open\_Accmode, Open\_RdOnly, Open\_WrOnly, Open\_RdWr, Open\_Creat,
 | |
|   Open\_Excl, Open\_NoCtty, Open\_Trunc, Open\_Append, Open\_NonBlock,
 | |
|   Open\_NDelay, Open\_Sync} \var{PathName} can be of type \var{PChar} or
 | |
| \var{String}
 | |
|   The optional \var{mode} argument specifies the permissions to set when opening
 | |
|   the file. This is modified by the umask setting. The real permissions are
 | |
|   \var{Mode and not umask}.
 | |
|   The return value of the function is the filedescriptor, or a negative 
 | |
|   value if there was an error.
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in LinuxError
 | |
| \SeeAlso
 | |
| \seef{fdClose}, \seef{fdRead}, \seef{fdWrite},\seef{fdTruncate},
 | |
| \seef{fdFlush}, \seef{fdSeek}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex19.pp}}
 | |
| \html{\input{linuxex/ex19.tex}}
 | |
| \begin{function}{fdRead}
 | |
| \Declaration
 | |
| Function fdRead (fd:longint;var buf;size:longint : longint;
 | |
| 
 | |
| \Description
 | |
|  \var{fdRead} reads at most \var{size} bytes from the file descriptor
 | |
| \var{fd}, and stores them in \var{buf}. 
 | |
| The function returns the number of bytes actually read, or -1 if
 | |
| an error occurred.
 | |
| No checking on the length of \var{buf} is done.
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{fdOpen}, \seef{fdClose}, \seef{fdWrite},\seef{fdTruncate},
 | |
| \seef{fdFlush}, \seef{fdSeek}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex20.pp}}
 | |
| \html{\input{linuxex/ex20.tex}}
 | |
| \begin{function}{fdSeek}
 | |
| \Declaration
 | |
| Function fdSeek (fd,Pos,SeekType:longint : longint;
 | |
| 
 | |
| \Description
 | |
| \var{fdSeek} sets the current fileposition of file \var{fd} to
 | |
| \var{Pos}, starting from \var{SeekType}, which can be one of the following:
 | |
| \begin{description}
 | |
| \item [Seek\_Set] \ \var{Pos} is the absolute position in the file.
 | |
| \item [Seek\_Cur] \ \var{Pos} is relative to the current position.
 | |
| \item [Seek\_end] \ \var{Pos} is relative to the end of the file.
 | |
| \end{description}
 | |
| The function returns the new fileposition, or -1 of an error occurred.
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{fdOpen}, \seef{fdWrite}, \seef{fdClose},
 | |
| \seef{fdRead},\seef{fdTruncate},
 | |
|  \seef{fdFlush}
 | |
| \end{function}
 | |
| For an example, see \seef{fdOpen}.
 | |
| \begin{function}{fdTruncate}
 | |
| \Declaration
 | |
| Function fdTruncate (fd,size:longint) : boolean;
 | |
| 
 | |
| \Description
 | |
| \var{fdTruncate} sets the length of a file in \var{fd} on \var{size}
 | |
| bytes, where \var{size} must be less than or equal to the current length of
 | |
| the file in \var{fd}.
 | |
| The function returns \var{True} if the call was successful, \var{false} if
 | |
| an error occurred.
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{fdOpen}, \seef{fdClose}, \seef{fdRead},\seef{fdWrite},\seef{fdFlush},
 | |
| \seef{fdSeek}
 | |
| \end{function}
 | |
| \begin{function}{fdWrite}
 | |
| \Declaration
 | |
| Function fdWrite (fd:longint;var buf;size:longint : longint;
 | |
| 
 | |
| \Description
 | |
| \var{fdWrite} writes at most \var{size} bytes from \var{buf} to
 | |
| file descriptor \var{fd}.
 | |
| The function returns the number of bytes actually written, or -1 if an error
 | |
| occurred.
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{fdOpen}, \seef{fdClose}, \seef{fdRead},\seef{fdTruncate},
 | |
| \seef{fdSeek}, \seef{fdFlush}
 | |
| \end{function}
 | |
| \begin{function}{FExpand}
 | |
| \Declaration
 | |
| Function FExpand (Const Path: Pathstr) : pathstr;
 | |
| 
 | |
| \Description
 | |
|  Expands \var {Path} to a full path, starting from root,
 | |
| eliminating directory references such as . and .. from the result.
 | |
| 
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
| \seef{BaseName},\seef{DirName} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex45.pp}}
 | |
| \html{\input{linuxex/ex45.tex}}
 | |
| \begin{procedure}{FLock}
 | |
| \Declaration
 | |
| Procedure FLock (Var F; Mode : longint);
 | |
| 
 | |
| \Description
 | |
| \var{FLock} implements file locking. it sets or removes a lock on the file
 | |
| \var{F}. F can be of type \var{Text} or \var{File}, or it can be a \linux
 | |
| filedescriptor (a longint)
 | |
| \var{Mode} can be one of the following constants :
 | |
| \begin{description}
 | |
| \item [LOCK\_SH] \ sets a shared lock.
 | |
| \item [LOCK\_EX] \ sets an exclusive lock.
 | |
| \item [LOCK\_UN] \ unlocks the file.
 | |
| \item [LOCK\_NB] \ This can be OR-ed together with the other. If this is done
 | |
| the application doesn't block when locking.
 | |
| \end{description}
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in \var{LinuxError}.
 | |
| \SeeAlso
 | |
| \seef{Fcntl}, \seem{flock}{2}
 | |
| \end{procedure}
 | |
| \begin{function}{FSStat}
 | |
| \Declaration
 | |
| Function FSStat (Path : Pathstr; Var Info : statfs) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  Return in \var{Info} information about the filesystem on which the file
 | |
| \var{Path} resides. Info is of type \var{statfs}.
 | |
| The function returns \var{True} if the call was succesfull, \var{False} if the call
 | |
| failed.
 | |
| 
 | |
| \Errors
 | |
|  \var{LinuxError} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_enotdir] A component of \var{Path} is not a directory.
 | |
| \item[sys\_einval] Invalid character in \var{Path}.
 | |
| \item[sys\_enoent] \var{Path} does not exist.
 | |
| \item[sys\_eaccess] Search permission is denied for  component in
 | |
| \var{Path}.
 | |
| \item[sys\_eloop] A circular symbolic link was encountered in \var{Path}.
 | |
| \item[sys\_eio] An error occurred while reading from the filesystem.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{FStat}, \seef{LStat}, \seem{statfs}{2}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex30.pp}}
 | |
| \html{\input{linuxex/ex30.tex}}
 | |
| \begin{function}{FSearch}
 | |
| \Declaration
 | |
| Function FSearch (Path : pathstr;DirList : string) : Pathstr;
 | |
| 
 | |
| \Description
 | |
|  Searches in \var{DirList}, a colon separated list of directories,
 | |
| for a file named \var{Path}. It then returns a path to the found file.
 | |
| \Errors
 | |
| An empty string if no such file was found.
 | |
| \SeeAlso
 | |
| \seef{BaseName}, \seef{DirName}, \seef{FExpand} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex46.pp}}
 | |
| \html{\input{linuxex/ex46.tex}}
 | |
| \begin{function}{FStat}
 | |
| \Declaration
 | |
| Function FStat (Path : Pathstr; Var Info : stat) : Boolean;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| \var{FStat} gets information about the file specified in \var{Path}, and stores it in 
 | |
| \var{Info}, which is of type \var{stat}.
 | |
| The function returns \var{True} if the call was succesfull, \var{False} if the call
 | |
| failed.
 | |
| 
 | |
| \Errors
 | |
|  \var{LinuxError} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_enoent] \var{Path} does not exist.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{FSStat}, \seef{LStat}, \seem{stat}{2}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex28.pp}}
 | |
| \html{\input{linuxex/ex28.tex}}
 | |
| \begin{function}{Fcntl}
 | |
| \Declaration
 | |
| Function Fcntl (Fd :  text, Cmd : Integer) : Integer;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Read a file's attributes. \var{Fd} is an assigned file.
 | |
| \var{Cmd} speciefies what to do, and is one of the following:
 | |
| \begin{description}
 | |
| \item[F\_GetFd] Read the close\_on\_exec flag. If the low-order bit is 0, then
 | |
| the file will remain open across execve calls.
 | |
| \item[F\_GetFl] Read the descriptor's flags.
 | |
| \item[F\_GetOwn] Get the Process ID of the owner of a socket.
 | |
| \end{description}
 | |
| 
 | |
| \Errors
 | |
| 
 | |
| \var{LinuxError} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_ebadf] \var{Fd} has a bad file descriptor.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{Fcntl}, \seem{Fcntl}{2} 
 | |
| \end{function}
 | |
| \begin{procedure}{Fcntl}
 | |
| \Declaration
 | |
| Procedure Fcntl (Fd :  text, Cmd : Integer; Arg : longint);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Read or Set a file's attributes. \var{Fd} is an assigned file.
 | |
| \var{Cmd} speciefies what to do, and is one of the following:
 | |
| \begin{description}
 | |
| \item[F\_SetFd] Set the close\_on\_exec flag of \var{Fd}. (only the least
 | |
| siginificant bit is used).
 | |
| \item[F\_GetLk] Return the \var{flock} record that prevents this process from
 | |
| obtaining the lock, or set the \var{l\_type} field of the lock of there is no
 | |
| obstruction. Arg is a pointer to a flock record.
 | |
| \item[F\_SetLk] Set the lock or clear it (depending on \var{l\_type} in the
 | |
| \var{flock} structure). if the lock is held by another process, an error
 | |
| occurs.
 | |
| \item[F\_GetLkw] Same as for \textbf{F\_Setlk}, but wait until the lock is
 | |
| released.
 | |
| \item[F\_SetOwn] Set the Process or process group that owns a socket.
 | |
| \end{description}
 | |
| 
 | |
| \Errors
 | |
| 
 | |
| \var{LinuxError} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_ebadf] \var{Fd} has a bad file descriptor.
 | |
| \item[sys\_eagain or sys\_eaccess] For \textbf{F\_SetLk}, if the lock is
 | |
| held by another process.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{Fcntl}, \seem{Fcntl}{2} 
 | |
| \end{procedure}
 | |
| \begin{function}{Fork}
 | |
| \Declaration
 | |
| Function Fork  : Longint;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Fork creates a child process which is a copy of the parent process.
 | |
| Fork returns the process ID in the parent process, and zero in the child's
 | |
| process. (you can get the parent's PID with \seef{GetPPid}).
 | |
| 
 | |
| \Errors
 | |
| On error, -1 is returned to the parent, and no child is created.
 | |
| \begin{description}
 | |
| \item [sys\_eagain] Not enough memory to create child process.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{Execve}, \seem{fork}{2}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex14.pp}}
 | |
| \html{\input{linuxex/ex14.tex}}
 | |
| \begin{procedure}{GetDate}
 | |
| \Declaration
 | |
| Procedure GetDate  (Var Year, Month, Day : Word) ;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Returns the current day.
 | |
| 
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
| \seef{GetEpochTime}, \seep{GetTime}, \seep{EpochToLocal} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex6.pp}}
 | |
| \html{\input{linuxex/ex6.tex}}
 | |
| \begin{function}{GetDomainName}
 | |
| \Declaration
 | |
| Function GetDomainName  : String;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Get the domain name of the machine on which the process is running.
 | |
| An empty string is returned if the domain is not set.
 | |
| 
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
|  \seef{GetHostName},seem{Getdomainname}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex39.pp}}
 | |
| \html{\input{linuxex/ex39.tex}}
 | |
| \begin{function}{GetEGid}
 | |
| \Declaration
 | |
| Function GetEGid  : Longint;
 | |
| 
 | |
| \Description
 | |
|  Get the effective group ID of the currently running process.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{GetGid}, \seem{getegid}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex18.pp}}
 | |
| \html{\input{linuxex/ex18.tex}}
 | |
| \begin{function}{GetEUid}
 | |
| \Declaration
 | |
| Function GetEUid  : Longint;
 | |
| 
 | |
| \Description
 | |
|  Get the effective user ID of the currently running process.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{GetEUid}, \seem{geteuid}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex17.pp}}
 | |
| \html{\input{linuxex/ex17.tex}}
 | |
| \begin{function}{GetEnv}
 | |
| \Declaration
 | |
| Function GetEnv (P : String) : PChar;
 | |
| 
 | |
| \Description
 | |
| Returns the value of the environment variable in \var{P}. If the variable is
 | |
| not defined, nil is returned. The value of the environment variable may be
 | |
| the empty string.
 | |
| A PChar is returned to accomodate for strings longer than 255 bytes,
 | |
| \var{TERMCAP} and \var{LS\_COLORS}, for instance.
 | |
| 
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seem{sh}{1}, \seem{csh}{1} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex41.pp}}
 | |
| \html{\input{linuxex/ex41.tex}}
 | |
| \begin{function}{GetEpochTime}
 | |
| \Declaration
 | |
| Function GetEpochTime  : longint;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| returns the number of seconds since 00:00:00 gmt, january 1, 1970.
 | |
| it is adjusted to the local time zone, but not to DST.
 | |
| 
 | |
| \Errors
 | |
| no errors
 | |
| \SeeAlso
 | |
| \seep{EpochToLocal}, \seep{GetTime}, \seem{time}{2}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex1.pp}}
 | |
| \html{\input{linuxex/ex1.tex}}
 | |
| \begin{function}{GetFS}
 | |
| \Declaration
 | |
| Function GetFS (Var F : Any File Type) : Longint;
 | |
| 
 | |
| \Description
 | |
| \var{GetFS} returns the file selector that the kernel provided for your
 | |
| file. In principle you don' need this file selector. Only for some calls
 | |
| it is needed, such as the \seef{Select} call or so.
 | |
| \Errors
 | |
| In case the file was not opened, then -1 is returned.
 | |
| \SeeAlso
 | |
| \seef{Select}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex34.pp}}
 | |
| \html{\input{linuxex/ex34.tex}}
 | |
| \begin{function}{GetGid}
 | |
| \Declaration
 | |
| Function GetGid  : Longint;
 | |
| 
 | |
| \Description
 | |
|  Get the real group ID of the currently running process.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{GetEGid}, \seem{getgid}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex18.pp}}
 | |
| \html{\input{linuxex/ex18.tex}}
 | |
| \begin{function}{GetHostName}
 | |
| \Declaration
 | |
| Function GetHostName  : String;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Get the hostname of the machine on which the process is running.
 | |
| An empty string is returned if hostname is not set.
 | |
| 
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
|  \seef{GetDomainName},seem{Gethostname}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex40.pp}}
 | |
| \html{\input{linuxex/ex40.tex}}
 | |
| \begin{function}{GetPid}
 | |
| \Declaration
 | |
| Function GetPid  : Longint;
 | |
| 
 | |
| \Description
 | |
|  Get the Process ID of the currently running process.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{GetPPid}, \seem{getpid}{2}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex16.pp}}
 | |
| \html{\input{linuxex/ex16.tex}}
 | |
| \begin{function}{GetPPid}
 | |
| \Declaration
 | |
| Function GetPPid  : Longint;
 | |
| 
 | |
| \Description
 | |
|  Get the Process ID of the parent process.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{GetPid}, \seem{getppid}{2}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex16.pp}}
 | |
| \html{\input{linuxex/ex16.tex}}
 | |
| \begin{function}{GetPriority}
 | |
| \Declaration
 | |
| Function GetPriority (Which,Who : Integer) : Integer;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| GetPriority returns the priority with which a process is running.
 | |
| Which process(es) is determined by the \var{Which} and \var{Who} variables.
 | |
| \var{Which} can be one of the pre-defined \var{Prio\_Process, Prio\_PGrp,
 | |
| Prio\_User}, in which case \var{Who} is the process ID, Process group ID or
 | |
| User ID, respectively.
 | |
| 
 | |
| \Errors
 | |
| 
 | |
|  Error checking must be done on LinuxError, since a priority can be negative.
 | |
|  \begin{description}
 | |
|  \item[sys\_esrch] No process found using \var{which} and \var{who}.
 | |
|  \item[sys\_einval] \var{Which} was not one of \var{Prio\_Process, Prio\_Grp
 | |
| or Prio\_User}.
 | |
|  \end{description}
 | |
|  
 | |
| \SeeAlso
 | |
| \seef{SetPriority}, \seep{Nice}, \seem{Getpriority}{2}
 | |
| \end{function}
 | |
| For an example, see \seep{Nice}.
 | |
| \begin{procedure}{GetTime}
 | |
| \Declaration
 | |
| Procedure GetTime  (Var Hour,Minute, Second : Word) ;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Returns the current time of the day.
 | |
| 
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
| \seef{GetEpochTime}, \seep{GetDate}, \seep{EpochToLocal} 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex5.pp}}
 | |
| \html{\input{linuxex/ex5.tex}}
 | |
| \begin{function}{GetUid}
 | |
| \Declaration
 | |
| Function GetUid  : Longint;
 | |
| 
 | |
| \Description
 | |
|  Get the real user ID of the currently running process.
 | |
| \Errors
 | |
| None.
 | |
| \SeeAlso
 | |
| \seef{GetEUid}, \seem{getuid}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex17.pp}}
 | |
| \html{\input{linuxex/ex17.tex}}
 | |
| \begin{function}{Glob}
 | |
| \Declaration
 | |
| Function Glob (Const Path : Pathstr) : PGlob;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Glob returns a pointer to a glob structure which contains all filenames which
 | |
| exist and match the pattern in \var{Path}.
 | |
| The pattern can contain wildcard characters, which have their
 | |
| usual meaning.
 | |
| 
 | |
| \Errors
 | |
|  Returns nil on error, and \var{LinuxError} is set.
 | |
| \begin{description}
 | |
| \item[sys\_enomem] No memory on heap for glob structure.
 | |
| \item[others] As returned by the opendir call, and sys\_readdir.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{GlobFree}, \seem{Glob}{3} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex49.pp}}
 | |
| \html{\input{linuxex/ex49.tex}}
 | |
| \begin{procedure}{GlobFree}
 | |
| \Declaration
 | |
| Procedure GlobFree (Var P : Pglob);
 | |
| 
 | |
| \Description
 | |
| Releases the memory, occupied by a pglob structure. \var{P} is set to nil.
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
|  \seef{Glob} 
 | |
| \end{procedure}
 | |
| For an example, see \seef{Glob}.
 | |
| \begin{procedure}{IOCtl}
 | |
| \Declaration
 | |
| Procedure IOCtl (Handle,Ndx: Longint; Data: Pointer);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| This is a general interface to the Unix/ \linux ioctl call.
 | |
| It performs various operations on the filedescriptor \var{Handle}.
 | |
| \var{Ndx} describes the operation to perform.
 | |
| \var{Data} points to data needed for the \var{Ndx} function. 
 | |
| The structure of this data is function-dependent, so we don't elaborate on
 | |
| this here. 
 | |
| For more information on this, see various manual pages under linux.
 | |
| 
 | |
| \Errors
 | |
| 
 | |
| Errors are reported in LinuxError. They are very dependent on the used
 | |
| function, that's why we don't list them here
 | |
| 
 | |
| \SeeAlso
 | |
| \seem{ioctl}{2}
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex54.pp}}
 | |
| \html{\input{linuxex/ex54.tex}}
 | |
| \begin{function}{IOperm}
 | |
| \Declaration
 | |
| Function IOperm (From,Num : Cadinal; Value : Longint) : boolean;
 | |
| 
 | |
| \Description
 | |
| \var{IOperm}
 | |
|   sets permissions on \var{Num} ports starting with port \var{From} to 
 | |
|   \var{Value}. The function returns \var{True} if the call was successfull,
 | |
|   \var{False} otherwise.
 | |
| {\em Remark:}
 | |
| \begin{itemize}
 | |
| \item This works ONLY as root.
 | |
| \item Only the first \var{0x03ff} ports can be set.
 | |
| \item When doing a \seef{Fork}, the permissions are reset. When doing a
 | |
| \seep{Execve} they are kept.
 | |
| \end{itemize}
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in \var{LinuxError}
 | |
| \SeeAlso
 | |
| \seem{ioperm}{2}
 | |
| \end{function}
 | |
| \begin{function}{IsATTY}
 | |
| \Declaration
 | |
| Function IsATTY (var f) : Boolean;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Check if the filehandle described by \var{f} is a terminal.
 | |
| f can be of type
 | |
| \begin{enumerate}
 | |
| \item \var{longint} for file handles;
 | |
| \item \var{Text} for \var{text} variables such as \var{input} etc.
 | |
| \end{enumerate}
 | |
| Returns \var{True} if \var{f} is a terminal, \var{False} otherwise.
 | |
| 
 | |
| \Errors
 | |
| No errors are reported
 | |
| \SeeAlso
 | |
| \seep{IOCtl},\seef{TTYName}
 | |
| \end{function}
 | |
| \begin{functionl}{S\_ISBLK}{ISBLK}
 | |
| \Declaration
 | |
| Function S\_ISBLK (m:integer) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{S\_ISBLK} checks the file mode \var{m} to see whether the file is a
 | |
| block device file. If so it returns \var{True}.
 | |
| 
 | |
| \Errors
 | |
| \seef{FStat},
 | |
|  \seefl{S\_ISLNK}{ISLNK}, 
 | |
|  \seefl{S\_ISREG}{ISREG},
 | |
|  \seefl{S\_ISDIR}{ISDIR},
 | |
|  \seefl{S\_ISCHR}{ISCHR},
 | |
|  \seefl{S\_ISFIFO}{ISFIFO},
 | |
|  \seefl{S\_ISSOCK}{ISSOCK}
 | |
| 
 | |
| \SeeAlso
 | |
| ISLNK.
 | |
| \end{functionl}
 | |
| \begin{functionl}{S\_ISCHR}{ISCHR}
 | |
| \Declaration
 | |
| Function S\_ISCHR (m:integer) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{S\_ISCHR} checks the file mode \var{m} to see whether the file is a
 | |
| character device file. If so it returns \var{True}.
 | |
| 
 | |
| \Errors
 | |
| \seef{FStat},
 | |
|  \seefl{S\_ISLNK}{ISLNK}, 
 | |
|  \seefl{S\_ISREG}{ISREG},
 | |
|  \seefl{S\_ISDIR}{ISDIR},
 | |
|  \seefl{S\_ISBLK}{ISBLK},
 | |
|  \seefl{S\_ISFIFO}{ISFIFO},
 | |
|  \seefl{S\_ISSOCK}{ISSOCK}
 | |
| 
 | |
| \SeeAlso
 | |
| ISLNK.
 | |
| \end{functionl}
 | |
| \begin{functionl}{S\_ISDIR}{ISDIR}
 | |
| \Declaration
 | |
| Function S\_ISDIR (m:integer) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{S\_ISDIR} checks the file mode \var{m} to see whether the file is a
 | |
| directory. If so it returns \var{True}
 | |
| 
 | |
| \Errors
 | |
| \seef{FStat},
 | |
|  \seefl{S\_ISLNK}{ISLNK}, 
 | |
|  \seefl{S\_ISREG}{ISREG},
 | |
|  \seefl{S\_ISCHR}{ISCHR},
 | |
|  \seefl{S\_ISBLK}{ISBLK},
 | |
|  \seefl{S\_ISFIFO}{ISFIFO},
 | |
|  \seefl{S\_ISSOCK}{ISSOCK}
 | |
| 
 | |
| \SeeAlso
 | |
| ISLNK.
 | |
| \end{functionl}
 | |
| \begin{functionl}{S\_ISFIFO}{ISFIFO}
 | |
| \Declaration
 | |
| Function S\_ISFIFO (m:integer) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{S\_ISFIFO} checks the file mode \var{m} to see whether the file is a
 | |
| fifo (a named pipe). If so it returns \var{True}.
 | |
| 
 | |
| \Errors
 | |
| \seef{FStat},
 | |
|  \seefl{S\_ISLNK}{ISLNK}, 
 | |
|  \seefl{S\_ISREG}{ISREG},
 | |
|  \seefl{S\_ISDIR}{ISDIR},
 | |
|  \seefl{S\_ISCHR}{ISCHR},
 | |
|  \seefl{S\_ISBLK}{ISBLK},
 | |
|  \seefl{S\_ISSOCK}{ISSOCK}
 | |
| 
 | |
| \SeeAlso
 | |
| ISLNK.
 | |
| \end{functionl}
 | |
| \begin{functionl}{S\_ISLNK}{ISLNK}
 | |
| \Declaration
 | |
| Function S\_ISLNK (m:integer) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{S\_ISLNK} checks the file mode \var{m} to see whether the file is a
 | |
| symbolic link. If so it returns \var{True}
 | |
| 
 | |
| \Errors
 | |
| \seef{FStat},
 | |
|  \seefl{S\_ISREG}{ISREG},
 | |
|  \seefl{S\_ISDIR}{ISDIR},
 | |
|  \seefl{S\_ISCHR}{ISCHR},
 | |
|  \seefl{S\_ISBLK}{ISBLK},
 | |
|  \seefl{S\_ISFIFO}{ISFIFO},
 | |
|  \seefl{S\_ISSOCK}{ISSOCK}
 | |
| 
 | |
| \SeeAlso
 | |
| \inputlisting{linuxex/ex53.pp}
 | |
| \end{functionl}
 | |
| \html{\input{linuxex/ex53.tex}}
 | |
| \begin{functionl}{S\_ISREG}{ISREG}
 | |
| \Declaration
 | |
| Function S\_ISREG (m:integer) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{S\_ISREG} checks the file mode \var{m} to see whether the file is a
 | |
| regular file. If so it returns \var{True}
 | |
| 
 | |
| \Errors
 | |
| \seef{FStat},
 | |
|  \seefl{S\_ISLNK}{ISLNK}, 
 | |
|  \seefl{S\_ISDIR}{ISDIR},
 | |
|  \seefl{S\_ISCHR}{ISCHR},
 | |
|  \seefl{S\_ISBLK}{ISBLK},
 | |
|  \seefl{S\_ISFIFO}{ISFIFO},
 | |
|  \seefl{S\_ISSOCK}{ISSOCK}
 | |
| 
 | |
| \SeeAlso
 | |
| ISLNK.
 | |
| \end{functionl}
 | |
| \begin{functionl}{S\_ISSOCK}{ISSOCK}
 | |
| \Declaration
 | |
| Function S\_ISSOCK (m:integer) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{S\_ISSOCK} checks the file mode \var{m} to see whether the file is a
 | |
| socket. If so it returns \var{True}.
 | |
| 
 | |
| \Errors
 | |
| \seef{FStat},
 | |
|  \seefl{S\_ISLNK}{ISLNK}, 
 | |
|  \seefl{S\_ISREG}{ISREG},
 | |
|  \seefl{S\_ISDIR}{ISDIR},
 | |
|  \seefl{S\_ISCHR}{ISCHR},
 | |
|  \seefl{S\_ISBLK}{ISBLK},
 | |
|  \seefl{S\_ISFIFO}{ISFIFO}
 | |
| 
 | |
| \SeeAlso
 | |
| ISLNK.
 | |
| \end{functionl}
 | |
| \begin{function}{Kill}
 | |
| \Declaration
 | |
| Function Kill Pid : Longint; Sig : Integer) : Integer;
 | |
| 
 | |
| \Description
 | |
|  Send a signal \var{Sig} to a process or process group. If \var{Pid}>0 then
 | |
| the signal is sent to \var{Pid}, if it equals -1, then the signal is sent to
 | |
| all processes except process 1. If \var{Pid}<-1 then the signal is sent to
 | |
| process group -Pid.
 | |
| The return value is zero, except in case three, where the return value is the
 | |
| number of processes to which the signal was sent.
 | |
| 
 | |
| \Errors
 | |
| \var{LinuxError} is used to report errors:
 | |
| \begin{description}
 | |
| \item[sys\_einval] An invalid signal is sent.
 | |
| \item[sys\_esrch] The \var{Pid} or process group don't exist.
 | |
| \item[sys\_eperm] The effective userid of the current process doesn't math
 | |
| the one of process \var{Pid}.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{SigAction}, \seef{Signal}, \seem{Kill}{2} 
 | |
| \end{function}
 | |
| \begin{function}{LStat}
 | |
| \Declaration
 | |
| Function LStat (Path : Pathstr; Var Info : stat) : Boolean;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| \var{LStat} gets information about the link specified in \var{Path}, and stores it in 
 | |
| \var{Info}, which is of type \var{stat}. Contrary to \var{FStat}, it stores
 | |
| information about the link, not about the file the link points to.
 | |
| The function returns \var{True} if the call was succesfull, \var{False} if the call
 | |
| failed.
 | |
| 
 | |
| \Errors
 | |
|  \var{LinuxError} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_enoent] \var{Path} does not exist.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{FStat}, \seef{FSStat}, \seem{stat}{2}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex29.pp}}
 | |
| \html{\input{linuxex/ex29.tex}}
 | |
| \begin{function}{Link}
 | |
| \Declaration
 | |
| Function Link (OldPath,NewPath : pathstr) : Boolean;
 | |
| 
 | |
| \Description
 | |
| \var{Link} makes \var{NewPath} point to the same file als \var{OldPath}. The two files
 | |
| then have the same inode number. This is known as a 'hard' link.
 | |
| The function returns \var{True} if the call was succesfull, \var{False} if the call
 | |
| failed.
 | |
| 
 | |
| \Errors
 | |
|  Errors are returned in \var{LinuxError}.
 | |
| \begin{description}
 | |
| \item[sys\_exdev] \var {OldPath} and \var {NewPath} are not on the same
 | |
| filesystem.
 | |
| \item[sys\_eperm] The filesystem containing oldpath and newpath doesn't
 | |
| support linking files.
 | |
| \item[sys\_eaccess] Write access for the directory containing \var{Newpath}
 | |
| is disallowed, or one of the directories in \var{OldPath} or {NewPath} has no
 | |
| search (=execute) permission.
 | |
| \item[sys\_enoent] A directory entry in \var{OldPath} or \var{NewPath} does
 | |
| not exist or is a symbolic link pointing to a non-existent directory.
 | |
| \item[sys\_enotdir] A directory entry in \var{OldPath} or \var{NewPath} is
 | |
| nor a directory.
 | |
| \item[sys\_enomem] Insufficient kernel memory.
 | |
| \item[sys\_erofs] The files are on a read-only filesystem.
 | |
| \item[sys\_eexist] \var{NewPath} already exists.
 | |
| \item[sys\_emlink] \var{OldPath} has reached maximal link count.
 | |
| \item[sys\_eloop] \var{OldPath} or \var{NewPath} has a reference to a circular
 | |
| symbolic link, i.e. a symbolic link, whose expansion points to itself.
 | |
| \item[sys\_enospc] The device containing \var{NewPath} has no room for anothe
 | |
| entry.
 | |
| \item[sys\_eperm] \var{OldPath} points to . or .. of a directory.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{SymLink}, \seef{UnLink}, \seem{Link}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex21.pp}}
 | |
| \html{\input{linuxex/ex21.tex}}
 | |
| \begin{function}{LocalToEpoch}
 | |
| \Declaration
 | |
| Function LocalToEpoch (Year,Month,Day,Hour,Minute,Second : Word) : longint;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Converts the Local time to epoch time (=Number of seconds since 00:00:00 , January 1,
 | |
| 1970 ).
 | |
| 
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
| \seef{GetEpochTime}, \seep{EpochToLocal}, \seep{GetTime},\seep{GetDate} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex4.pp}}
 | |
| \html{\input{linuxex/ex4.tex}}
 | |
| \begin{function}{MkFifo}
 | |
| \Declaration
 | |
| Function MkFifo (PathName: String; Mode : Longint) : Boolean;
 | |
| 
 | |
| \Description
 | |
| \var{MkFifo} creates named a named pipe in the filesystem, with name
 | |
| \var{PathName} and mode {Mode}. 
 | |
| 
 | |
| \Errors
 | |
|  \var{LinuxError} is used to report errors:
 | |
| \begin{description}
 | |
| \item[sys\_emfile] Too many file descriptors for this process.
 | |
| \item[sys\_enfile] The system file table is full.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{POpen}, \seef{MkFifo}, \seem{mkfifo}{4}
 | |
| \end{function}
 | |
| \begin{procedure}{Nice}
 | |
| \Declaration
 | |
| Procedure Nice ( N : Integer);
 | |
| 
 | |
| \Description
 | |
| Nice adds \var{-N} to the priority of the running process. The lower the
 | |
| priority numerically, the less the process is favored.
 | |
| Only the superuser can specify a negative \var{N}, i.e. increase the rate at
 | |
| which the process is run.
 | |
| 
 | |
| \Errors
 | |
|  Errors are returned in \var{LinuxError}
 | |
| \begin{description}
 | |
| \item [sys\_eperm] A non-superuser tried to specify a negative \var{N}, i.e.
 | |
| do a priority increase.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{GetPriority}, \seef{SetPriority}, \seem{Nice}{2}
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex15.pp}}
 | |
| \html{\input{linuxex/ex15.tex}}
 | |
| \begin{function}{OpenDir}
 | |
| \Declaration
 | |
| Function OpenDir (f:pchar) : pdir;
 | |
| 
 | |
| \Description
 | |
|  \var{OpenDir} opens the directory  \var{f}, and returns a \var{pdir}
 | |
| pointer to a \var{Dir} record, which can be used to read the directory 
 | |
| structure. If the directory cannot be opened, \var{nil} is returned.
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{CloseDir}, \seef{ReadDir}, \seep{SeekDir}, \seef{TellDir},
 | |
| \seem{opendir}{3}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex35.pp}}
 | |
| \html{\input{linuxex/ex35.tex}}
 | |
| \begin{function}{PClose}
 | |
| \Declaration
 | |
| Function PClose (Var F : FileType) : longint;
 | |
| 
 | |
| \Description
 | |
|  \var{PClose} closes a file opened with \var{POpen}. It waits for the
 | |
| command to complete, and then returns the exit status of the command. 
 | |
| 
 | |
| \Errors
 | |
| \var{LinuxError} is used to report errors. If it is different from zero,
 | |
| the exit status is not valid.
 | |
| \SeeAlso
 | |
| \seep{POpen}
 | |
| \end{function}
 | |
| For an example, see \seep{POpen}
 | |
| \begin{procedure}{POpen}
 | |
| \Declaration
 | |
| Procedure POpen (Var F : FileType; Cmd : pathstr; rw : char);
 | |
| 
 | |
| \Description
 | |
|  Popen runs the command specified in \var{Cmd},
 | |
|  and redirects the standard in or output of the
 | |
| command to the other end of the pipe \var{F}. The parameter \var{rw}
 | |
| indicates the direction of the pipe. If it is set to \var{'W'}, then F can
 | |
| be used to write data, which will then be read by the command from stdinput.
 | |
| If it is set to \var{'R'}, then the standard output of the command can be 
 | |
| read from \var{F}. \var{F} should be reset or rewritten prior to using it.
 | |
| \var{F} can be of type \var{Text} or \var{File}.
 | |
| A file opened with \var {POpen} can be closed with \var{Close}, but also
 | |
| with \seef{PClose}. The result is the same, but \var{PClose} returns the
 | |
| exit status of the command \var{Cmd}.
 | |
| \Errors
 | |
| Errors are reported in \var{LinuxError} and are essentially those of the
 | |
| Execve, Dup and AssignPipe commands.
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{AssignPipe}, \seem{popen}{3}, \seef{PClose}
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex37.pp}}
 | |
| \html{\input{linuxex/ex37.tex}}
 | |
| \begin{function}{ReadDir}
 | |
| \Declaration
 | |
| Function ReadDir (p:pdir) : pdirent;
 | |
| 
 | |
| \Description
 | |
| \var{ReadDir} reads the next entry in the directory pointed to by \var{p}.
 | |
| It returns a \var{pdirent} pointer to a structure describing the entry.
 | |
| If the next entry can't be read, \var{Nil} is returned.
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{CloseDir}, \seef{OpenDir}, \seep{SeekDir}, \seef{TellDir},
 | |
| \seem{readdir}{3}
 | |
| \end{function}
 | |
| For an example, see \seef{OpenDir}.
 | |
| \begin{procedure}{SeekDir}
 | |
| \Declaration
 | |
| Procedure SeekDir (p:pdir;off:longint);
 | |
| 
 | |
| \Description
 | |
|  \var{SeekDir} sets the directory pointer to the \var{off}-th entry in the
 | |
| directory structure pointed to by \var{p}.
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{CloseDir}, \seef{ReadDir}, \seef{OpenDir}, \seef{TellDir},
 | |
| \seem{seekdir}{3}
 | |
| \end{procedure}
 | |
| For an example, see \seef{OpenDir}.
 | |
| \begin{function}{Select}
 | |
| \Declaration
 | |
| Function Select (N : Longint; \\ var readfds,writefds,exceptfds : PFDset;
 | |
| Var Timeout) : Longint;
 | |
| 
 | |
| \Description
 | |
| \var{Select} checks one of the file descriptors in the \var{FDSets} to see if its
 | |
| status changed.
 | |
| \var{readfds, writefds} and \var{exceptfds} are pointers to arrays of 256
 | |
| bits. If you want a file descriptor to be checked, you set the
 | |
| corresponding element in the array to 1. The other elements in the array
 | |
| must be set to zero. Three arrays are passed : The entries in \var{readfds}
 | |
| are checked to see if characters become available for reading. The entries
 | |
| in \var{writefds} are checked to see if it is OK to write to them, while
 | |
| entries in \var{exceptfds} are cheked to see if an exception occorred on
 | |
| them.
 | |
| You can use the functions \seepl{FD\_Clear}{FDClear}, \seepl{FD\_Clr}{FDClr}, 
 | |
| \seepl{FD\_Set}{FDSet}, \seefl{FD\_IsSet}{FDIsSet} to manipulate the individual elements of a set.
 | |
| The pointers can be nil.
 | |
| \var{N} is the largest index of a nonzero entry plus 1. (= the largest
 | |
| file-descriptor + 1).
 | |
| \var{TimeOut} can be used to set a time limit. 
 | |
| If \var{TimeOut} can be two types :
 | |
| \begin{enumerate}
 | |
| \item \var{TimeOut} is of type \var{PTime} and contains a
 | |
| zero time, the call returns immediately. If \var{TimeOut} is \var{Nil}, the
 | |
| kernel will wait forever, or until a status changed.    
 | |
| \item \var{TimeOut} is of type \var{Longint}. If it is -1, this has the same
 | |
| effect as a \var{Timeout} of type  \var{PTime} which is \var{Nil}.
 | |
| Otherwise, \var{TimeOut} contains a time in milliseconds.
 | |
| \end{enumerate}
 | |
|  
 | |
| When the TimeOut is reached, or one of the file descriptors has changed,
 | |
| the \var{Select} call returns. On return, it will have modified the entries
 | |
| in the array which have actually changed, and it returns the number of
 | |
| entries that have been changed. If the timout was reached, and no decsriptor
 | |
| changed, zero is returned; The arrays of indexes are undefined after that.
 | |
| On error, -1 is returned.
 | |
| \Errors
 | |
| On error, the function returns -1, and Errors are reported in LinuxError :
 | |
| \begin{description}
 | |
| \item[SYS\_EBADF\ ] An invalid descriptot was specified in one of the sets.
 | |
| \item[SYS\_EINTR\ ] A non blocked signal was caught.
 | |
| \item[SYS\_EINVAL\ ]  \var{N} is negative or too big.
 | |
| \item[SYS\_ENOMEM\ ] \var{Select} was unable to allocate memory for its 
 | |
|  internal tables.
 | |
| \end{description}
 | |
| \SeeAlso
 | |
| \seef{SelectText}, \seef{GetFS}, 
 | |
| \seepl{FD\_Clear}{FDClear},
 | |
| \seepl{FD\_Clr}{FDClr},
 | |
| \seepl{FD\_Set}{FDSet}, 
 | |
| \seefl{FD\_IsSet}{FDIsSet}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex33.pp}}
 | |
| \html{\input{linuxex/ex33.tex}}
 | |
| \begin{function}{SelectText}
 | |
| \Declaration
 | |
| Function SelectText ( var T : Text; TimeOut :PTime) : Longint;
 | |
| 
 | |
| \Description
 | |
| \var{SelectText} executes the \seef{Select} call on a file of type
 | |
| \var{Text}. You can specify a timeout in \var{TimeOut}. The SelectText call
 | |
| determines itself whether it should check for read or write, depending on
 | |
| how the file was opened : With \var{Reset} it is checked for reading, with
 | |
| \var{Rewrite} and \var{Append} it is checked for writing.
 | |
| \Errors
 | |
| See \seef{Select}. \var{SYS\_EBADF} can also mean that the file wasn't
 | |
| opened.
 | |
| \SeeAlso
 | |
| \seef{Select}, \seef{GetFS}
 | |
| \end{function}
 | |
| \begin{function}{SetPriority}
 | |
| \Declaration
 | |
| Function SetPriority (Which,Who,Prio : Integer) : Integer;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| SetPriority sets the priority with which a process is running.
 | |
| Which process(es) is determined by the \var{Which} and \var{Who} variables.
 | |
| \var{Which} can be one of the pre-defined \var{Prio\_Process, Prio\_PGrp,
 | |
| Prio\_User}, in which case \var{Who} is the process ID, Process group ID or
 | |
| User ID, respectively.
 | |
| \var{Prio} is a value in the range -20 to 20.
 | |
| 
 | |
| \Errors
 | |
| 
 | |
|  Error checking must be done on LinuxError, since a priority can be negative.
 | |
|  \begin{description}
 | |
|  \item[sys\_esrch] No process found using \var{which} and \var{who}.
 | |
|  \item[sys\_einval] \var{Which} was not one of \var{Prio\_Process, Prio\_Grp
 | |
| or Prio\_User}.
 | |
|  \item[sys\_eperm] A process was found, but neither its effective or real
 | |
|  user ID match the effective user ID of the caller.
 | |
|  \item [sys\_eacces] A non-superuser tried to a priority increase.
 | |
|  \end{description}
 | |
|  
 | |
| \SeeAlso
 | |
| \seef{GetPriority}, \seep{Nice}, \seem{Setpriority}{2}
 | |
| \end{function}
 | |
| For an example, see \seep{Nice}.
 | |
| \begin{function}{Shell}
 | |
| \Declaration
 | |
| Function Shell (Command : String) : Longint;
 | |
| 
 | |
| \Description
 | |
| \var{Shell} invokes the bash shell (\file{/bin/sh}), and feeds it the
 | |
| command \var{Command} (using the \var{-c} option). The function then waits
 | |
| for the command to complete, and then returns the exit
 | |
| status of the command, or 127 if it could not complete the \seef{Fork} 
 | |
| or \seep{Execve} calls.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in LinuxError.
 | |
| \SeeAlso
 | |
| \seep{POpen}, \seef{Fork}, \seep{Execve}, \seem{system}{3}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex56.pp}}
 | |
| \html{\input{linuxex/ex56.tex}}
 | |
| \begin{procedure}{SigAction}
 | |
| \Declaration
 | |
| Procedure SigAction (Signum : Integer; Var Act,OldAct : PSigActionRec);
 | |
| 
 | |
| \Description
 | |
|  Changes the action to take upon receipt of a signal. \var{Act} and
 | |
| \var{Oldact} are pointers to a \var{SigActionRec} record.
 | |
| \var{SigNum} specifies the signal, and can be any signal except
 | |
| \textbf{SIGKILL} or \textbf{SIGSTOP}.
 | |
| If \var{Act} is non-nil, then the new action for signal \var{SigNum} is taken
 | |
| from it. If \var{OldAct} is non-nil, the old action is stored there.
 | |
| \var{Sa\_Handler} may be \var{SIG\_DFL} for the default action or
 | |
| \var{SIG\_IGN} to ignore the signal.
 | |
| \var{Sa\_Mask} Specifies which signals should be ignord during the execution
 | |
| of the signal handler.
 | |
| \var{Sa\_Flags} Speciefies a series of flags which modify the behaviour of
 | |
| the signal handler. You can 'or' none or more of the following :
 | |
| \begin{description}
 | |
| \item[SA\_NOCLDSTOP] If signum is \textbf{SIGCHLD} do not receive
 | |
| notification when child processes stop.
 | |
| \item[SA\_ONESHOT or SA\_RESETHAND] Restore the signal action to the default
 | |
| state once the signal handler has been called.
 | |
| \item[SA\_RESTART] For compatibility with BSD signals.
 | |
| \item[SA\_NOMASK or SA\_NODEFER] Do not prevent the signal from being received
 | |
| from within its own signal handler.
 | |
| \end{description}
 | |
| 
 | |
| \Errors
 | |
| \var{LinuxError} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_einval] an invalid signal was specified, or it was
 | |
| \textbf{SIGKILL} or \textbf{SIGSTOP}.
 | |
| \item[sys\_efault] \var{Act,OldAct} point outside this process address space
 | |
| \item[sys\_eintr] System call was interrupted.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| 
 | |
| \seep{SigProcMask}, \seef{SigPending}, \seep{SigSuspend}, \seef{Kill},
 | |
| \seem{Sigaction}{2}
 | |
| 
 | |
| \end{procedure}
 | |
| \latex{\inputlisting{linuxex/ex57.pp}}
 | |
| \html{\input{linuxex/ex57.tex}}
 | |
| \begin{function}{SigPending}
 | |
| \Declaration
 | |
| Function SigPending  : SigSet;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Sigpending allows the examination of pending signals (which have been raised
 | |
| while blocked.) The signal mask of pending signals is returned.
 | |
| 
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
| \seep{SigAction}, \seep{SigProcMask}, \seep{SigSuspend}, \seef{Signal},
 | |
| \seef{Kill}, \seem{Sigpending}{2} 
 | |
| \end{function}
 | |
| \begin{procedure}{SigProcMask}
 | |
| \Declaration
 | |
| Procedure SigProcMask (How : Integer; SSet,OldSSet : PSigSet);
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Changes the list of currently blocked signals. The behaviour of the call
 | |
| depends on \var{How} :
 | |
| \begin{description}
 | |
| \item[SIG\_BLOCK] The set of blocked signals is the union of the current set
 | |
| and the \var{SSet} argument.
 | |
| \item[SIG\_UNBLOCK] The signals in \var{SSet} are removed from the set of
 | |
| currently blocked signals.
 | |
| \item[SIG\_SETMASK] The list of blocked signals is set so \var{SSet}.
 | |
| \end{description}
 | |
| If \var{OldSSet} is non-nil, then the old set is stored in it.
 | |
| 
 | |
| \Errors
 | |
| \var{LinuxError} is used to report errors.
 | |
| \begin{description}
 | |
| \item[sys\_efault] \var{SSet} or \var{OldSSet} point to an adress outside
 | |
| the range of the process.
 | |
| \item[sys\_eintr] System call was interrupted.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{SigAction}, \seef{SigPending}, \seep{SigSuspend}, \seef{Kill},
 | |
| \seem{Sigprocmask}{2} 
 | |
| \end{procedure}
 | |
| \begin{procedure}{SigSuspend}
 | |
| \Declaration
 | |
| Procedure SigSuspend (Mask : SigSet);
 | |
| 
 | |
| \Description
 | |
| SigSuspend temporarily replaces the signal mask for the process with the one
 | |
| given in \var{Mask}, and then suspends the process until a signal is received.
 | |
| 
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
| \seep{SigAction}, \seep{SigProcMask}, \seef{SigPending}, \seef{Signal},
 | |
| \seef{Kill}, \seem{SigSuspend}{2} 
 | |
| \end{procedure}
 | |
| \begin{function}{Signal}
 | |
| \Declaration
 | |
| Function Signal (SigNum : Integer; Handler : SignalHandler) : SignalHandler;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Signal installs a new signal handler for signal \var{SigNum}. This call has
 | |
| the same functionality as the \textbf{SigAction} call.
 | |
| The return value for Signal is the old signal handler, or nil on error.
 | |
| 
 | |
| \Errors
 | |
| \var {LinuxError} is used to report errors :
 | |
| \begin{description}
 | |
| \item[SIG\_ERR] An error occurred.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seep{SigAction},\seef{Kill}, \seem{Signal}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex58.pp}}
 | |
| \html{\input{linuxex/ex58.tex}}
 | |
| \begin{function}{SymLink}
 | |
| \Declaration
 | |
| Function SymLink (OldPath,NewPath : pathstr) : Boolean;
 | |
| 
 | |
| \Description
 | |
| \var{SymLink} makes \var{Newpath} point to the file in \var{OldPath}, which doesn't
 | |
| necessarily exist. The two files DO NOT have the same inode number.
 | |
| This is known as a 'soft' link.
 | |
| The permissions of the link are irrelevant, as they are not used when
 | |
| following the link. Ownership of the file is only checked in case of removal
 | |
| or renaming of the link.
 | |
| The function returns \var{True} if the call was succesfull, \var{False} if the call
 | |
| failed.
 | |
| 
 | |
| \Errors
 | |
|  Errors are returned in \var{LinuxError}.
 | |
| \begin{description}
 | |
| \item[sys\_eperm] The filesystem containing oldpath and newpath doesn't
 | |
| support linking files.
 | |
| \item[sys\_eaccess] Write access for the directory containing \var{Newpath}
 | |
| is disallowed, or one of the directories in \var{OldPath} or {NewPath} has no
 | |
| search (=execute) permission.
 | |
| \item[sys\_enoent] A directory entry in \var{OldPath} or \var{NewPath} does
 | |
| not exist or is a symbolic link pointing to a non-existent directory.
 | |
| \item[sys\_enotdir] A directory entry in \var{OldPath} or \var{NewPath} is
 | |
| nor a directory.
 | |
| \item[sys\_enomem] Insufficient kernel memory.
 | |
| \item[sys\_erofs] The files are on a read-only filesystem.
 | |
| \item[sys\_eexist] \var{NewPath} already exists.
 | |
| \item[sys\_eloop] \var{OldPath} or \var{NewPath} has a reference to a circular
 | |
| symbolic link, i.e. a symbolic link, whose expansion points to itself.
 | |
| \item[sys\_enospc] The device containing \var{NewPath} has no room for anothe
 | |
| entry.
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{Link}, \seef{UnLink}, \seem{Symlink}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex22.pp}}
 | |
| \html{\input{linuxex/ex22.tex}}
 | |
| \begin{function}{TCDrain}
 | |
| \Declaration
 | |
| Function TCDrain (Fd:longint) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{TCDrain}
 | |
|   waits until all data to file descriptor \var{Fd} is transmitted.
 | |
|   
 | |
|   The function returns \var{True} if the call was succesfull, \var{False}
 | |
|   otherwise.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in LinuxError
 | |
| \SeeAlso
 | |
| \seem{termios}{2}
 | |
| \end{function}
 | |
| \begin{function}{TCFlow}
 | |
| \Declaration
 | |
| Function TCFlow (Fd,Act:longint) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{TCFlow}
 | |
|   suspends/resumes transmission or reception of data to or from the file
 | |
| descriptor \var{Fd}, depending
 | |
|   on the action \var {Act}. This can be one of the following pre-defined
 | |
| values: 
 | |
| \begin{description}
 | |
| \item [TCOOFF\ ] suspend reception/transmission,
 | |
| \item [TCOON\ ] resume  reception/transmission,
 | |
| \item [TCIOFF\ ] transmit a stop character to stop input from the terminal, 
 | |
| \item [TCION\ ] transmit start to resume input from the terminal.
 | |
| \end{description}
 | |
| The function returns \var{True} if the call was succesfull, \var{False}
 | |
| otherwise.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in LinuxError.
 | |
| \SeeAlso
 | |
| \seem{termios}{2}
 | |
| \end{function}
 | |
| \begin{function}{TCFlush}
 | |
| \Declaration
 | |
| Function TCFlush (Fd,QSel:longint) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{TCFlush}
 | |
|   discards all data sent or received to/from file descriptor \var{fd}. 
 | |
|  \var{QSel} indicates which queue
 | |
|   should be discard. It can be one of the following pre-defined values :
 | |
| \begin{description}
 | |
| \item [TCIFLUSH\ ] input,
 | |
| \item [TCOFLUSH\ ] output,
 | |
| \item [TCIOFLUSH\ ] both input and output.
 | |
| \end{description}
 | |
| The function returns \var{True} if the call was succesfull, \var{False}
 | |
| otherwise.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in LinuxError.
 | |
| \SeeAlso
 | |
| \seem{termios}{2}
 | |
| \end{function}
 | |
| \begin{function}{TCGetAttr}
 | |
| \Declaration
 | |
| Function TCGetAttr (fd:longint;var tios:TermIOS) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{TCGetAttr}
 | |
|   gets the terminal parameters from the terminal referred to by the file
 | |
|   descriptor \var{fd} and returns them in a \var{TermIOS} structure \var{tios}. 
 | |
| The function returns \var{True} if the call was succesfull, \var{False}
 | |
| otherwise.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in LinuxError
 | |
| \SeeAlso
 | |
| \seef{TCSetAttr}, \seem{termios}{2} 
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex55.pp}}
 | |
| \html{\input{linuxex/ex55.tex}}
 | |
| \begin{function}{TCGetPGrp}
 | |
| \Declaration
 | |
| Function TCGetPGrp (Fd:longint;var Id:longint) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{TCGetPGrp}
 | |
|   returns the process group ID of a foreground process group in \var{Id} 
 | |
|   The function returns \var{True} if the call was succesfull, \var{False}
 | |
|   otherwise
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in LinuxError
 | |
| \SeeAlso
 | |
| \seem{termios}{2}
 | |
| \end{function}
 | |
| \begin{function}{TCSendBreak}
 | |
| \Declaration
 | |
| Function TCSendBreak (Fd,Duration:longint) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{TCSendBreak} 
 | |
|   Sends zero-valued bits on an asynchrone serial connection decsribed by
 | |
|   file-descriptor \var{Fd}, for duration \var{Duration}.
 | |
|   The function returns \var{True} if the action was performed successfully,
 | |
| \var{False} otherwise.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in LinuxError.
 | |
| \SeeAlso
 | |
| \seem{termios}{2}
 | |
| \end{function}
 | |
| \begin{function}{TCSetAttr}
 | |
| \Declaration
 | |
| Function TCSetAttr (Fd:longint;OptAct:longint;var Tios:TermIOS) : Boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{TCSetAttr}
 | |
|   Sets the terminal parameters you specify in a \var{TermIOS} structure
 | |
| \var{Tios} for the terminal
 | |
|   referred to by the file descriptor \var{Fd}. \var{OptAct} specifies an 
 | |
|   optional action when the set need to be done,
 | |
|   this could be one of the following pre-defined values:
 | |
|  \begin{description}
 | |
| \item [TCSANOW\ ] set immediately.
 | |
| \item [TCSADRAIN\ ] wait for output.
 | |
| \item [TCSAFLUSH\ ] wait for output and discard all input not yet read. 
 | |
| \end{description}
 | |
| The function Returns \var{True} if the call was succesfull, \var{False} 
 | |
| otherwise.
 | |
| 
 | |
| \Errors
 | |
| Errors are reported in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{TCGetAttr}, \seem{termios}{2}
 | |
| \end{function}
 | |
| For an example, see \seef{TCGetAttr}.
 | |
| \begin{function}{TCSetPGrp}
 | |
| \Declaration
 | |
| Function TCSetPGrp (Fd,Id:longint) : boolean;
 | |
| 
 | |
| \Description
 | |
|  \var{TCSetPGrp} Sets the Process Group Id to \var{Id}. 
 | |
| The function returns \var{True} if the call was successful, \var{False}
 | |
| otherwise.
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{TCGetPGrp}, \seem{termios}{2}
 | |
| \end{function}
 | |
| For an example, see \seef{TCGetPGrp}.
 | |
| \begin{function}{TTYName}
 | |
| \Declaration
 | |
| Function TTYName (var f) : String;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Returns the name of the terminal pointed to by \var{f}. \var{f}
 | |
| must be a terminal. \var{f} can be of type:
 | |
| \begin{enumerate}
 | |
| \item \var{longint} for file handles;
 | |
| \item \var{Text} for \var{text} variables such as \var{input} etc.
 | |
| \end{enumerate}
 | |
| 
 | |
| \Errors
 | |
|  Returns an empty string in case of an error. \var{Linuxerror} may be set
 | |
|  to indicate what error occurred, but this is uncertain.
 | |
| \SeeAlso
 | |
| \seef{IsATTY},\seep{IOCtl}
 | |
| \end{function}
 | |
| \begin{function}{TellDir}
 | |
| \Declaration
 | |
| Function TellDir (p:pdir) : longint;
 | |
| 
 | |
| \Description
 | |
|  \var{TellDir} returns the current location in the directory structure
 | |
| pointed to by \var{p}. It returns -1 on failure.
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{CloseDir}, \seef{ReadDir}, \seep{SeekDir}, \seef{OpenDir},
 | |
| \seem{telldir}{3}
 | |
| \end{function}
 | |
| For an example, see \seef{OpenDir}.
 | |
| \begin{function}{Umask}
 | |
| \Declaration
 | |
| Function Umask (Mask : Integer) : Integer;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| Change the file creation mask for the current user to \var{Mask}. The
 | |
| current mask is returned.
 | |
| 
 | |
| \Errors
 | |
| None
 | |
| \SeeAlso
 | |
| \seef{Chmod}, \seem{Umask}{2}
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex27.pp}}
 | |
| \html{\input{linuxex/ex27.tex}}
 | |
| \begin{procedure}{Uname}
 | |
| \Declaration
 | |
| Procedure Uname (var unamerec:utsname);
 | |
| 
 | |
| \Description
 | |
| \var{Uname} gets the name and configuration of the current \linux kernel,
 | |
| and returns it in \var{unamerec}.
 | |
| 
 | |
| \Errors
 | |
| \var{LinuxError} is used to report errors.
 | |
| \SeeAlso
 | |
| \seef{GetHostName}, \seef{GetDomainName}, \seem{uname}{2}
 | |
| \end{procedure}
 | |
| \begin{function}{UnLink}
 | |
| \Declaration
 | |
| Function UnLink (Var Path) : Boolean;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| \var{UnLink} decreases the link count on file \var{Path}. \var{Path} can be
 | |
| of type \var{PathStr} or \var{PChar}. If the link count is zero, the
 | |
| file is removed from the disk.
 | |
| The function returns \var{True} if the call was succesfull, \var{False} if the call
 | |
| failed.
 | |
| 
 | |
| \Errors
 | |
|  Errors are returned in \var{LinuxError}.
 | |
| \begin{description}
 | |
| \item[sys\_eaccess] You have no write access right in the directory
 | |
| containing \var{Path}, or you have no search permission in one of the
 | |
| directory components of \var{Path}.
 | |
| \item[sys\_eperm] The  directory containing pathname has the sticky-bit 
 | |
| set and the process's effective  uid is neither the uid of the 
 | |
| file to be deleted nor that of the directory containing it.
 | |
| \item[sys\_enoent] A component of the path doesn't exist.
 | |
| \item[sys\_enotdir] A directory component of the path is not a directory.
 | |
| \item[sys\_eisdir] \var{Path} refers to a directory.
 | |
| \item[sys\_enomem] Insufficient kernel memory.
 | |
| \item[sys\_erofs] \var{Path} is on a read-only filesystem. 
 | |
| \end{description}
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{Link}, \seef{SymLink}, \seem{Unlink}{2} 
 | |
| \end{function}
 | |
| For an example, see \seef{Link}.
 | |
| \begin{function}{Utime}
 | |
| \Declaration
 | |
| Function Utime (path : pathstr; utim : utimbuf) : Boolean;
 | |
| 
 | |
| \Description
 | |
| 
 | |
| \var{Utime} sets the access and modification times of a file.
 | |
| the \var{utimbuf} record contains 2 fields, \var{actime}, and \var{modtime},
 | |
| both of type Longint. They should be filled with an epoch-like time,
 | |
| specifying, respectively, the last access time, and the last modification
 | |
| time. 
 | |
| For some filesystem (most notably, FAT), these times are the same. 
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in \var{LinuxError}.
 | |
| \begin{description}
 | |
| \item[sys\_eaccess] One of the directories in \var{Path} has no
 | |
| search (=execute) permission.
 | |
| \item[sys\_enoent] A directory entry in \var{Path} does
 | |
| not exist or is a symbolic link pointing to a non-existent directory.
 | |
| \end{description}
 | |
| Other errors may occur, but aren't documented.
 | |
| 
 | |
| \SeeAlso
 | |
| \seef{GetEpochTime}, \seef{Chown}, \seef{Access}, \seem{utime}(2)
 | |
| \end{function}
 | |
| \latex{\inputlisting{linuxex/ex25.pp}}
 | |
| \html{\input{linuxex/ex25.tex}}
 | |
| \begin{function}{WaitPid}
 | |
| \Declaration
 | |
| Function WaitPid (Pid : longint; Status : pointer; Options : Integer) : Longint;
 | |
| 
 | |
| \Description
 | |
|  \var{WaitPid} waits for a child process with process ID \var{Pid} to exit. The
 | |
| value of \var{Pid} can be one of the following:
 | |
| \begin{description}
 | |
| \item[Pid < -1] Causes \var{WaitPid} to wait for  any  child  process  whose
 | |
|               process group ID equals the absolute value of \var{pid}.
 | |
| \item[Pid = -1] Causes \var{WaitPid} to wait for any child process.
 | |
| \item[Pid = 0] Causes \var{WaitPid} to wait for  any  child  process  whose
 | |
|               process  group  ID  equals the one of the calling
 | |
|               process.
 | |
| \item[Pid > 0] Causes \var{WaitPid} to wait for the child whose process  ID
 | |
| equals the value of \var{Pid}.
 | |
| \end{description}
 | |
| The \var{Options} parameter can be used to specify further how \var{WaitPid}
 | |
| behaves:
 | |
| \begin{description}
 | |
| \item [WNOHANG] Causes \var{Waitpid} to return immediately if no child  has
 | |
| exited.
 | |
| \item [WUNTRACED] Causes \var{WaitPid} to return also for children which are
 | |
| stopped, but whose status has not yet been reported.
 | |
| \end{description} 
 | |
| Upon return, it returns the exit status of the process, or -1 in case of
 | |
| failure. 
 | |
| 
 | |
| \Errors
 | |
| Errors are returned in LinuxError.
 | |
| \SeeAlso
 | |
| \seef{Fork}, \seep{Execve}, \seem{waitpid}{2}
 | |
| \end{function}
 | |
| for an example, see \seef{Fork}.
 | |
| 
 | 
