| 1 |
---------------------------------------------------------------- |
| 2 |
-- ZLib for Ada thick binding. -- |
| 3 |
-- -- |
| 4 |
-- Copyright (C) 2002-2003 Dmitriy Anisimkov -- |
| 5 |
-- -- |
| 6 |
-- Open source license information is in the zlib.ads file. -- |
| 7 |
---------------------------------------------------------------- |
| 8 |
|
| 9 |
-- $Id: zlib-streams.ads,v 1.12 2004/05/31 10:53:40 vagul Exp $ |
| 10 |
|
| 11 |
package ZLib.Streams is |
| 12 |
|
| 13 |
type Stream_Mode is (In_Stream, Out_Stream, Duplex); |
| 14 |
|
| 15 |
type Stream_Access is access all Ada.Streams.Root_Stream_Type'Class; |
| 16 |
|
| 17 |
type Stream_Type is |
| 18 |
new Ada.Streams.Root_Stream_Type with private; |
| 19 |
|
| 20 |
procedure Read |
| 21 |
(Stream : in out Stream_Type; |
| 22 |
Item : out Ada.Streams.Stream_Element_Array; |
| 23 |
Last : out Ada.Streams.Stream_Element_Offset); |
| 24 |
|
| 25 |
procedure Write |
| 26 |
(Stream : in out Stream_Type; |
| 27 |
Item : in Ada.Streams.Stream_Element_Array); |
| 28 |
|
| 29 |
procedure Flush |
| 30 |
(Stream : in out Stream_Type; |
| 31 |
Mode : in Flush_Mode := Sync_Flush); |
| 32 |
-- Flush the written data to the back stream, |
| 33 |
-- all data placed to the compressor is flushing to the Back stream. |
| 34 |
-- Should not be used untill necessary, becouse it is decreasing |
| 35 |
-- compression. |
| 36 |
|
| 37 |
function Read_Total_In (Stream : in Stream_Type) return Count; |
| 38 |
pragma Inline (Read_Total_In); |
| 39 |
-- Return total number of bytes read from back stream so far. |
| 40 |
|
| 41 |
function Read_Total_Out (Stream : in Stream_Type) return Count; |
| 42 |
pragma Inline (Read_Total_Out); |
| 43 |
-- Return total number of bytes read so far. |
| 44 |
|
| 45 |
function Write_Total_In (Stream : in Stream_Type) return Count; |
| 46 |
pragma Inline (Write_Total_In); |
| 47 |
-- Return total number of bytes written so far. |
| 48 |
|
| 49 |
function Write_Total_Out (Stream : in Stream_Type) return Count; |
| 50 |
pragma Inline (Write_Total_Out); |
| 51 |
-- Return total number of bytes written to the back stream. |
| 52 |
|
| 53 |
procedure Create |
| 54 |
(Stream : out Stream_Type; |
| 55 |
Mode : in Stream_Mode; |
| 56 |
Back : in Stream_Access; |
| 57 |
Back_Compressed : in Boolean; |
| 58 |
Level : in Compression_Level := Default_Compression; |
| 59 |
Strategy : in Strategy_Type := Default_Strategy; |
| 60 |
Header : in Header_Type := Default; |
| 61 |
Read_Buffer_Size : in Ada.Streams.Stream_Element_Offset |
| 62 |
:= Default_Buffer_Size; |
| 63 |
Write_Buffer_Size : in Ada.Streams.Stream_Element_Offset |
| 64 |
:= Default_Buffer_Size); |
| 65 |
-- Create the Comression/Decompression stream. |
| 66 |
-- If mode is In_Stream then Write operation is disabled. |
| 67 |
-- If mode is Out_Stream then Read operation is disabled. |
| 68 |
|
| 69 |
-- If Back_Compressed is true then |
| 70 |
-- Data written to the Stream is compressing to the Back stream |
| 71 |
-- and data read from the Stream is decompressed data from the Back stream. |
| 72 |
|
| 73 |
-- If Back_Compressed is false then |
| 74 |
-- Data written to the Stream is decompressing to the Back stream |
| 75 |
-- and data read from the Stream is compressed data from the Back stream. |
| 76 |
|
| 77 |
-- !!! When the Need_Header is False ZLib-Ada is using undocumented |
| 78 |
-- ZLib 1.1.4 functionality to do not create/wait for ZLib headers. |
| 79 |
|
| 80 |
function Is_Open (Stream : Stream_Type) return Boolean; |
| 81 |
|
| 82 |
procedure Close (Stream : in out Stream_Type); |
| 83 |
|
| 84 |
private |
| 85 |
|
| 86 |
use Ada.Streams; |
| 87 |
|
| 88 |
type Buffer_Access is access all Stream_Element_Array; |
| 89 |
|
| 90 |
type Stream_Type |
| 91 |
is new Root_Stream_Type with |
| 92 |
record |
| 93 |
Mode : Stream_Mode; |
| 94 |
|
| 95 |
Buffer : Buffer_Access; |
| 96 |
Rest_First : Stream_Element_Offset; |
| 97 |
Rest_Last : Stream_Element_Offset; |
| 98 |
-- Buffer for Read operation. |
| 99 |
-- We need to have this buffer in the record |
| 100 |
-- becouse not all read data from back stream |
| 101 |
-- could be processed during the read operation. |
| 102 |
|
| 103 |
Buffer_Size : Stream_Element_Offset; |
| 104 |
-- Buffer size for write operation. |
| 105 |
-- We do not need to have this buffer |
| 106 |
-- in the record becouse all data could be |
| 107 |
-- processed in the write operation. |
| 108 |
|
| 109 |
Back : Stream_Access; |
| 110 |
Reader : Filter_Type; |
| 111 |
Writer : Filter_Type; |
| 112 |
end record; |
| 113 |
|
| 114 |
end ZLib.Streams; |