beta-0.89.2
[luatex.git] / source / libs / zlib / zlib-src / contrib / ada / mtest.adb
blobc4dfd080f0c0a4ea5ee3a0204a89ac91e83d859f
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 -- Continuous test for ZLib multithreading. If the test would fail
9 -- we should provide thread safe allocation routines for the Z_Stream.
11 -- $Id: mtest.adb,v 1.4 2004/07/23 07:49:54 vagul Exp $
13 with ZLib;
14 with Ada.Streams;
15 with Ada.Numerics.Discrete_Random;
16 with Ada.Text_IO;
17 with Ada.Exceptions;
18 with Ada.Task_Identification;
20 procedure MTest is
21 use Ada.Streams;
22 use ZLib;
24 Stop : Boolean := False;
26 pragma Atomic (Stop);
28 subtype Visible_Symbols is Stream_Element range 16#20# .. 16#7E#;
30 package Random_Elements is
31 new Ada.Numerics.Discrete_Random (Visible_Symbols);
33 task type Test_Task;
35 task body Test_Task is
36 Buffer : Stream_Element_Array (1 .. 100_000);
37 Gen : Random_Elements.Generator;
39 Buffer_First : Stream_Element_Offset;
40 Compare_First : Stream_Element_Offset;
42 Deflate : Filter_Type;
43 Inflate : Filter_Type;
45 procedure Further (Item : in Stream_Element_Array);
47 procedure Read_Buffer
48 (Item : out Ada.Streams.Stream_Element_Array;
49 Last : out Ada.Streams.Stream_Element_Offset);
51 -------------
52 -- Further --
53 -------------
55 procedure Further (Item : in Stream_Element_Array) is
57 procedure Compare (Item : in Stream_Element_Array);
59 -------------
60 -- Compare --
61 -------------
63 procedure Compare (Item : in Stream_Element_Array) is
64 Next_First : Stream_Element_Offset := Compare_First + Item'Length;
65 begin
66 if Buffer (Compare_First .. Next_First - 1) /= Item then
67 raise Program_Error;
68 end if;
70 Compare_First := Next_First;
71 end Compare;
73 procedure Compare_Write is new ZLib.Write (Write => Compare);
74 begin
75 Compare_Write (Inflate, Item, No_Flush);
76 end Further;
78 -----------------
79 -- Read_Buffer --
80 -----------------
82 procedure Read_Buffer
83 (Item : out Ada.Streams.Stream_Element_Array;
84 Last : out Ada.Streams.Stream_Element_Offset)
86 Buff_Diff : Stream_Element_Offset := Buffer'Last - Buffer_First;
87 Next_First : Stream_Element_Offset;
88 begin
89 if Item'Length <= Buff_Diff then
90 Last := Item'Last;
92 Next_First := Buffer_First + Item'Length;
94 Item := Buffer (Buffer_First .. Next_First - 1);
96 Buffer_First := Next_First;
97 else
98 Last := Item'First + Buff_Diff;
99 Item (Item'First .. Last) := Buffer (Buffer_First .. Buffer'Last);
100 Buffer_First := Buffer'Last + 1;
101 end if;
102 end Read_Buffer;
104 procedure Translate is new Generic_Translate
105 (Data_In => Read_Buffer,
106 Data_Out => Further);
108 begin
109 Random_Elements.Reset (Gen);
111 Buffer := (others => 20);
113 Main : loop
114 for J in Buffer'Range loop
115 Buffer (J) := Random_Elements.Random (Gen);
117 Deflate_Init (Deflate);
118 Inflate_Init (Inflate);
120 Buffer_First := Buffer'First;
121 Compare_First := Buffer'First;
123 Translate (Deflate);
125 if Compare_First /= Buffer'Last + 1 then
126 raise Program_Error;
127 end if;
129 Ada.Text_IO.Put_Line
130 (Ada.Task_Identification.Image
131 (Ada.Task_Identification.Current_Task)
132 & Stream_Element_Offset'Image (J)
133 & ZLib.Count'Image (Total_Out (Deflate)));
135 Close (Deflate);
136 Close (Inflate);
138 exit Main when Stop;
139 end loop;
140 end loop Main;
141 exception
142 when E : others =>
143 Ada.Text_IO.Put_Line (Ada.Exceptions.Exception_Information (E));
144 Stop := True;
145 end Test_Task;
147 Test : array (1 .. 4) of Test_Task;
149 pragma Unreferenced (Test);
151 Dummy : Character;
153 begin
154 Ada.Text_IO.Get_Immediate (Dummy);
155 Stop := True;
156 end MTest;