diff --git a/src/sfs/sfsPlainFS.pas b/src/sfs/sfsPlainFS.pas
index e43f367e994916171437e500548c679231ba6623..5666ad23a8e1f7e8dbbc162877c63f1adee7c752 100644 (file)
--- a/src/sfs/sfsPlainFS.pas
+++ b/src/sfs/sfsPlainFS.pas
begin
if (fType <> sfspvPAK) and (fType <> sfspvSIN) then raise ESFSError.Create('invalid archive');
fFileStream.Seek(4, soCurrent); // skip signature
- fFileStream.ReadBuffer(dofs, 4);
- fFileStream.ReadBuffer(dsize, 4);
+ dofs := readLongWord(fFileStream);
+ dsize := readLongWord(fFileStream);
fFileStream.Position := dofs;
if fType = sfspvPAK then esz := 64 else esz := 128;
while dsize >= esz do
FillChar(name[0], length(name), 0);
fFileStream.ReadBuffer(name[0], esz-8);
fi.fName := PChar(@name[0]);
- fFileStream.ReadBuffer(fi.fOfs, 4);
- fFileStream.ReadBuffer(fi.fSize, 4);
+ fi.fOfs := readLongWord(fFileStream);
+ fi.fSize := readLongWord(fFileStream);
Dec(dsize, esz);
end;
end;
vt := sfspvNone;
st.ReadBuffer(sign[0], 4);
- st.ReadBuffer(dofs, 4);
- st.ReadBuffer(dsize, 4);
+ dofs := readLongWord(st);
+ dsize := readLongWord(st);
st.Seek(-12, soCurrent);
if sign = 'PACK' then
begin