TBufStream.Flush
FLush data from buffer, and write it to stream.
Declaration
Source position: objects.pp line 381
default
procedure Flush; Virtual;
Description
When the stream is in write mode, the contents of the buffer are written to disk, and the buffer position is set to zero. When the stream is in read mode, the buffer position is set to zero.
Errors
Write errors may occur if the file was in write mode. see Write for more info on the errors.
See also
Name | Description |
---|---|
TBufStream.Done | Close the file and cleans up the instance. |
TBufStream.Init | Initialize an instance of TBufStream and open the file. |
TStream.Close | Close the stream |
Example
Program ex15;
{ Program to demonstrate the TStream.Flush method }
Uses Objects;
Var L : String;
P : PString;
S : PBufStream; { Only one with Flush implemented. }
begin
L:='Some constant string';
{ Buffer size of 100 }
S:=New(PBufStream,Init('test.dat',stcreate,100));
Writeln ('Writing "',L,'" to stream with handle ',S^.Handle);
S^.WriteStr(@L);
{ At this moment, there is no data on disk yet. }
S^.Flush;
{ Now there is. }
S^.WriteStr(@L);
{ Close calls flush first }
S^.Close;
Writeln ('Closed stream. File handle is ',S^.Handle);
S^.Open (stOpenRead);
P:=S^.ReadStr;
L:=P^;
DisposeStr(P);
Writeln ('Read "',L,'" from stream with handle ',S^.Handle);
S^.Close;
Dispose (S,Done);
end.