mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-21 13:09:32 +02:00
* fixed zipper unit for big endian systems (patch by Bent Normann Olsen,
mantis #12562) git-svn-id: trunk@12624 -
This commit is contained in:
parent
4ae434ce2e
commit
e055b87dea
@ -23,15 +23,9 @@ Uses
|
||||
|
||||
Const
|
||||
{ Signatures }
|
||||
{$ifdef FPC_BIG_ENDIAN}
|
||||
END_OF_CENTRAL_DIR_SIGNATURE = $504B0506;
|
||||
LOCAL_FILE_HEADER_SIGNATURE = $504B0304;
|
||||
CENTRAL_FILE_HEADER_SIGNATURE = $504B0102;
|
||||
{$else FPC_BIG_ENDIAN}
|
||||
END_OF_CENTRAL_DIR_SIGNATURE = $06054B50;
|
||||
LOCAL_FILE_HEADER_SIGNATURE = $04034B50;
|
||||
CENTRAL_FILE_HEADER_SIGNATURE = $02014B50;
|
||||
{$endif FPC_BIG_ENDIAN}
|
||||
|
||||
Type
|
||||
Local_File_Header_Type = Packed Record
|
||||
@ -415,6 +409,65 @@ ResourceString
|
||||
Auxiliary
|
||||
---------------------------------------------------------------------}
|
||||
|
||||
{$IFDEF FPC_BIG_ENDIAN}
|
||||
function SwapLFH(const Values: Local_File_Header_Type): Local_File_Header_Type;
|
||||
begin
|
||||
with Values do
|
||||
begin
|
||||
Result.Signature := SwapEndian(Signature);
|
||||
Result.Extract_Version_Reqd := SwapEndian(Extract_Version_Reqd);
|
||||
Result.Bit_Flag := SwapEndian(Bit_Flag);
|
||||
Result.Compress_Method := SwapEndian(Compress_Method);
|
||||
Result.Last_Mod_Time := SwapEndian(Last_Mod_Time);
|
||||
Result.Last_Mod_Date := SwapEndian(Last_Mod_Date);
|
||||
Result.Crc32 := SwapEndian(Crc32);
|
||||
Result.Compressed_Size := SwapEndian(Compressed_Size);
|
||||
Result.Uncompressed_Size := SwapEndian(Uncompressed_Size);
|
||||
Result.Filename_Length := SwapEndian(Filename_Length);
|
||||
Result.Extra_Field_Length := SwapEndian(Extra_Field_Length);
|
||||
end;
|
||||
end;
|
||||
|
||||
function SwapCFH(const Values: Central_File_Header_Type): Central_File_Header_Type;
|
||||
begin
|
||||
with Values do
|
||||
begin
|
||||
Result.Signature := SwapEndian(Signature);
|
||||
Result.MadeBy_Version := SwapEndian(MadeBy_Version);
|
||||
Result.Extract_Version_Reqd := SwapEndian(Extract_Version_Reqd);
|
||||
Result.Bit_Flag := SwapEndian(Bit_Flag);
|
||||
Result.Compress_Method := SwapEndian(Compress_Method);
|
||||
Result.Last_Mod_Time := SwapEndian(Last_Mod_Time);
|
||||
Result.Last_Mod_Date := SwapEndian(Last_Mod_Date);
|
||||
Result.Crc32 := SwapEndian(Crc32);
|
||||
Result.Compressed_Size := SwapEndian(Compressed_Size);
|
||||
Result.Uncompressed_Size := SwapEndian(Uncompressed_Size);
|
||||
Result.Filename_Length := SwapEndian(Filename_Length);
|
||||
Result.Extra_Field_Length := SwapEndian(Extra_Field_Length);
|
||||
Result.File_Comment_Length := SwapEndian(File_Comment_Length);
|
||||
Result.Starting_Disk_Num := SwapEndian(Starting_Disk_Num);
|
||||
Result.Internal_Attributes := SwapEndian(Internal_Attributes);
|
||||
Result.External_Attributes := SwapEndian(External_Attributes);
|
||||
Result.Local_Header_Offset := SwapEndian(Local_Header_Offset);
|
||||
end;
|
||||
end;
|
||||
|
||||
function SwapECD(const Values: End_of_Central_Dir_Type): End_of_Central_Dir_Type;
|
||||
begin
|
||||
with Values do
|
||||
begin
|
||||
Result.Signature := SwapEndian(Signature);
|
||||
Result.Disk_Number := SwapEndian(Disk_Number);
|
||||
Result.Central_Dir_Start_Disk := SwapEndian(Central_Dir_Start_Disk);
|
||||
Result.Entries_This_Disk := SwapEndian(Entries_This_Disk);
|
||||
Result.Total_Entries := SwapEndian(Total_Entries);
|
||||
Result.Central_Dir_Size := SwapEndian(Central_Dir_Size);
|
||||
Result.Start_Disk_Offset := SwapEndian(Start_Disk_Offset);
|
||||
Result.ZipFile_Comment_Length := SwapEndian(ZipFile_Comment_Length);
|
||||
end;
|
||||
end;
|
||||
{$ENDIF FPC_BIG_ENDIAN}
|
||||
|
||||
Procedure DateTimeToZipDateTime(DT : TDateTime; out ZD,ZT : Word);
|
||||
|
||||
Var
|
||||
@ -1058,7 +1111,7 @@ Begin
|
||||
Compressed_Size := Uncompressed_Size; { ...update compressed size }
|
||||
end;
|
||||
end;
|
||||
FOutFile.WriteBuffer(LocalHdr,SizeOf(LocalHdr));
|
||||
FOutFile.WriteBuffer({$IFDEF ENDIAN_BIG}SwapLFH{$ENDIF}(LocalHdr),SizeOf(LocalHdr));
|
||||
FOutFile.WriteBuffer(ZFileName[1],Length(ZFileName));
|
||||
End;
|
||||
|
||||
@ -1078,6 +1131,9 @@ Begin
|
||||
FOutFile.Seek(0,soFrombeginning); { Rewind output file }
|
||||
HdrPos := FOutFile.Position;
|
||||
FOutFile.ReadBuffer(LocalHdr, SizeOf(LocalHdr));
|
||||
{$IFDEF FPC_BIG_ENDIAN}
|
||||
LocalHdr := SwapLFH(LocalHdr);
|
||||
{$ENDIF}
|
||||
Repeat
|
||||
SetLength(ZFileName,LocalHdr.FileName_Length);
|
||||
FOutFile.ReadBuffer(ZFileName[1], LocalHdr.FileName_Length);
|
||||
@ -1097,12 +1153,15 @@ Begin
|
||||
Local_Header_Offset := HdrPos;
|
||||
end;
|
||||
FOutFile.Seek(0,soFromEnd);
|
||||
FOutFile.WriteBuffer(CentralHdr,SizeOf(CentralHdr));
|
||||
FOutFile.WriteBuffer({$IFDEF FPC_BIG_ENDIAN}SwapCFH{$ENDIF}(CentralHdr),SizeOf(CentralHdr));
|
||||
FOutFile.WriteBuffer(ZFileName[1],Length(ZFileName));
|
||||
Inc(ACount);
|
||||
FOutFile.Seek(SavePos + LocalHdr.Compressed_Size,soFromBeginning);
|
||||
HdrPos:=FOutFile.Position;
|
||||
FOutFile.ReadBuffer(LocalHdr, SizeOf(LocalHdr));
|
||||
{$IFDEF FPC_BIG_ENDIAN}
|
||||
LocalHdr := SwapLFH(LocalHdr);
|
||||
{$ENDIF}
|
||||
Until LocalHdr.Signature = CENTRAL_FILE_HEADER_SIGNATURE;
|
||||
FOutFile.Seek(0,soFromEnd);
|
||||
FillChar(EndHdr,SizeOf(EndHdr),0);
|
||||
@ -1116,7 +1175,7 @@ Begin
|
||||
Central_Dir_Size := FOutFile.Size-CenDirPos;
|
||||
Start_Disk_Offset := CenDirPos;
|
||||
ZipFile_Comment_Length := 0;
|
||||
FOutFile.WriteBuffer(EndHdr, SizeOf(EndHdr));
|
||||
FOutFile.WriteBuffer({$IFDEF FPC_BIG_ENDIAN}SwapECD{$ENDIF}(EndHdr), SizeOf(EndHdr));
|
||||
end;
|
||||
end;
|
||||
|
||||
@ -1341,6 +1400,9 @@ Var
|
||||
Begin
|
||||
FZipFile.Seek(Item.HdrPos,soFromBeginning);
|
||||
FZipFile.ReadBuffer(LocalHdr,SizeOf(LocalHdr));
|
||||
{$IFDEF FPC_BIG_ENDIAN}
|
||||
LocalHdr := SwapLFH(LocalHdr);
|
||||
{$ENDIF}
|
||||
With LocalHdr do
|
||||
begin
|
||||
SetLength(S,Filename_Length);
|
||||
@ -1372,6 +1434,9 @@ Begin
|
||||
raise EZipError.CreateFmt(SErrCorruptZIP,[FZipFile.FileName]);
|
||||
FZipFile.Seek(EndHdrPos,soFromBeginning);
|
||||
FZipFile.ReadBuffer(EndHdr, SizeOf(EndHdr));
|
||||
{$IFDEF FPC_BIG_ENDIAN}
|
||||
EndHdr := SwapECD(EndHdr);
|
||||
{$ENDIF}
|
||||
With EndHdr do
|
||||
begin
|
||||
if Signature <> END_OF_CENTRAL_DIR_SIGNATURE then
|
||||
@ -1382,6 +1447,9 @@ Begin
|
||||
for i:=0 to EndHdr.Entries_This_Disk-1 do
|
||||
begin
|
||||
FZipFile.ReadBuffer(CentralHdr, SizeOf(CentralHdr));
|
||||
{$IFDEF FPC_BIG_ENDIAN}
|
||||
CentralHdr := SwapCFH(CentralHdr);
|
||||
{$ENDIF}
|
||||
With CentralHdr do
|
||||
begin
|
||||
if Signature<>CENTRAL_FILE_HEADER_SIGNATURE then
|
||||
|
Loading…
Reference in New Issue
Block a user