123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553 |
- %
- % $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.
- \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}.
|