FpRead
Read data from file descriptor
Declaration
Source position: bunxh.inc line 85
function FpRead(fd: cint; buf: pChar; nbytes: TSize) : TsSize;
function FpRead(fd: cint; var buf; nbytes: TSize) : TsSize;
Description
FpdRead reads at most nbytes bytes from the file descriptor fd, and stores them in buf.
The function returns the number of bytes actually read, or -1 if an error occurred. No checking on the length of buf is done.
Errors
Extended error information can be retrieved using fpGetErrno .
See also
Name | Description |
---|---|
FpClose | Close file descriptor |
FpFTruncate | Truncate file on certain size. |
FpLSeek | Set file pointer position. |
FpOpen | Open file and return file descriptor |
FpWrite | Write data to file descriptor |
Example
Program Example20;
{ Program to demonstrate the fdRead and fdTruncate functions. }
Uses BaseUnix;
Const Data : string[10] = '1234567890';
Var FD : cint;
l : longint;
begin
FD:=fpOpen('test.dat',o_wronly or o_creat,&666);
if fd>0 then
begin
{ Fill file with data }
for l:=1 to 10 do
if fpWrite (FD,Data[1],10)<>10 then
begin
writeln ('Error when writing !');
halt(1);
end;
fpClose(FD);
FD:=fpOpen('test.dat',o_rdonly);
{ Read data again }
If FD>0 then
begin
For l:=1 to 5 do
if fpRead (FD,Data[1],10)<>10 then
begin
Writeln ('Error when Reading !');
Halt(2);
end;
fpClose(FD);
{ Truncating file at 60 bytes }
{ For truncating, file must be open or write }
FD:=fpOpen('test.dat',o_wronly,&666);
if FD>0 then
begin
if fpfTruncate(FD,60)<>0 then
Writeln('Error when truncating !');
fpClose (FD);
end;
end;
end;
end.