| lh | 9ed821d | 2023-04-07 01:36:19 -0700 | [diff] [blame] | 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 until necessary, because 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 | --  because 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 because 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; |