2010-07-27 Paolo Carlini <paolo.carlini@oracle.com>
[official-gcc/alias-decl.git] / gcc / ada / g-cgideb.adb
blob863599b16be15b4893501bd8dc15be55da9c50ea
1 ------------------------------------------------------------------------------
2 -- --
3 -- GNAT COMPILER COMPONENTS --
4 -- --
5 -- G N A T . C G I . D E B U G --
6 -- --
7 -- B o d y --
8 -- --
9 -- Copyright (C) 2000-2008, AdaCore --
10 -- --
11 -- GNAT is free software; you can redistribute it and/or modify it under --
12 -- terms of the GNU General Public License as published by the Free Soft- --
13 -- ware Foundation; either version 2, or (at your option) any later ver- --
14 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
15 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
16 -- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License --
17 -- for more details. You should have received a copy of the GNU General --
18 -- Public License distributed with GNAT; see file COPYING. If not, write --
19 -- to the Free Software Foundation, 51 Franklin Street, Fifth Floor, --
20 -- Boston, MA 02110-1301, USA. --
21 -- --
22 -- As a special exception, if other files instantiate generics from this --
23 -- unit, or you link this unit with other files to produce an executable, --
24 -- this unit does not by itself cause the resulting executable to be --
25 -- covered by the GNU General Public License. This exception does not --
26 -- however invalidate any other reasons why the executable file might be --
27 -- covered by the GNU Public License. --
28 -- --
29 -- GNAT was originally developed by the GNAT team at New York University. --
30 -- Extensive contributions were provided by Ada Core Technologies Inc. --
31 -- --
32 ------------------------------------------------------------------------------
34 with Ada.Strings.Unbounded;
36 package body GNAT.CGI.Debug is
38 use Ada.Strings.Unbounded;
40 -- Define the abstract type which act as a template for all debug IO modes.
41 -- To create a new IO mode you must:
42 -- 1. create a new package spec
43 -- 2. create a new type derived from IO.Format
44 -- 3. implement all the abstract routines in IO
46 package IO is
48 type Format is abstract tagged null record;
50 function Output (Mode : Format'Class) return String;
52 function Variable
53 (Mode : Format;
54 Name : String;
55 Value : String) return String is abstract;
56 -- Returns variable Name and its associated value
58 function New_Line (Mode : Format) return String is abstract;
59 -- Returns a new line such as this concatenated between two strings
60 -- will display the strings on two lines.
62 function Title (Mode : Format; Str : String) return String is abstract;
63 -- Returns Str as a Title. A title must be alone and centered on a
64 -- line. Next output will be on the following line.
66 function Header
67 (Mode : Format;
68 Str : String) return String is abstract;
69 -- Returns Str as an Header. An header must be alone on its line. Next
70 -- output will be on the following line.
72 end IO;
74 ----------------------
75 -- IO for HTML Mode --
76 ----------------------
78 package HTML_IO is
80 -- See IO for comments about these routines
82 type Format is new IO.Format with null record;
84 function Variable
85 (IO : Format;
86 Name : String;
87 Value : String) return String;
89 function New_Line (IO : Format) return String;
91 function Title (IO : Format; Str : String) return String;
93 function Header (IO : Format; Str : String) return String;
95 end HTML_IO;
97 ----------------------------
98 -- IO for Plain Text Mode --
99 ----------------------------
101 package Text_IO is
103 -- See IO for comments about these routines
105 type Format is new IO.Format with null record;
107 function Variable
108 (IO : Format;
109 Name : String;
110 Value : String) return String;
112 function New_Line (IO : Format) return String;
114 function Title (IO : Format; Str : String) return String;
116 function Header (IO : Format; Str : String) return String;
118 end Text_IO;
120 --------------
121 -- Debug_IO --
122 --------------
124 package body IO is
126 ------------
127 -- Output --
128 ------------
130 function Output (Mode : Format'Class) return String is
131 Result : Unbounded_String;
133 begin
134 Result :=
135 To_Unbounded_String
136 (Title (Mode, "CGI complete runtime environment")
137 & Header (Mode, "CGI parameters:")
138 & New_Line (Mode));
140 for K in 1 .. Argument_Count loop
141 Result := Result
142 & Variable (Mode, Key (K), Value (K))
143 & New_Line (Mode);
144 end loop;
146 Result := Result
147 & New_Line (Mode)
148 & Header (Mode, "CGI environment variables (Metavariables):")
149 & New_Line (Mode);
151 for P in Metavariable_Name'Range loop
152 if Metavariable_Exists (P) then
153 Result := Result
154 & Variable (Mode,
155 Metavariable_Name'Image (P),
156 Metavariable (P))
157 & New_Line (Mode);
158 end if;
159 end loop;
161 return To_String (Result);
162 end Output;
164 end IO;
166 -------------
167 -- HTML_IO --
168 -------------
170 package body HTML_IO is
172 NL : constant String := (1 => ASCII.LF);
174 function Bold (S : String) return String;
175 -- Returns S as an HTML bold string
177 function Italic (S : String) return String;
178 -- Returns S as an HTML italic string
180 ----------
181 -- Bold --
182 ----------
184 function Bold (S : String) return String is
185 begin
186 return "<b>" & S & "</b>";
187 end Bold;
189 ------------
190 -- Header --
191 ------------
193 function Header (IO : Format; Str : String) return String is
194 pragma Unreferenced (IO);
195 begin
196 return "<h2>" & Str & "</h2>" & NL;
197 end Header;
199 ------------
200 -- Italic --
201 ------------
203 function Italic (S : String) return String is
204 begin
205 return "<i>" & S & "</i>";
206 end Italic;
208 --------------
209 -- New_Line --
210 --------------
212 function New_Line (IO : Format) return String is
213 pragma Unreferenced (IO);
214 begin
215 return "<br>" & NL;
216 end New_Line;
218 -----------
219 -- Title --
220 -----------
222 function Title (IO : Format; Str : String) return String is
223 pragma Unreferenced (IO);
224 begin
225 return "<p align=center><font size=+2>" & Str & "</font></p>" & NL;
226 end Title;
228 --------------
229 -- Variable --
230 --------------
232 function Variable
233 (IO : Format;
234 Name : String;
235 Value : String) return String
237 pragma Unreferenced (IO);
238 begin
239 return Bold (Name) & " = " & Italic (Value);
240 end Variable;
242 end HTML_IO;
244 -------------
245 -- Text_IO --
246 -------------
248 package body Text_IO is
250 ------------
251 -- Header --
252 ------------
254 function Header (IO : Format; Str : String) return String is
255 begin
256 return "*** " & Str & New_Line (IO);
257 end Header;
259 --------------
260 -- New_Line --
261 --------------
263 function New_Line (IO : Format) return String is
264 pragma Unreferenced (IO);
265 begin
266 return String'(1 => ASCII.LF);
267 end New_Line;
269 -----------
270 -- Title --
271 -----------
273 function Title (IO : Format; Str : String) return String is
274 Spaces : constant Natural := (80 - Str'Length) / 2;
275 Indent : constant String (1 .. Spaces) := (others => ' ');
276 begin
277 return Indent & Str & New_Line (IO);
278 end Title;
280 --------------
281 -- Variable --
282 --------------
284 function Variable
285 (IO : Format;
286 Name : String;
287 Value : String) return String
289 pragma Unreferenced (IO);
290 begin
291 return " " & Name & " = " & Value;
292 end Variable;
294 end Text_IO;
296 -----------------
297 -- HTML_Output --
298 -----------------
300 function HTML_Output return String is
301 HTML : HTML_IO.Format;
302 begin
303 return IO.Output (Mode => HTML);
304 end HTML_Output;
306 -----------------
307 -- Text_Output --
308 -----------------
310 function Text_Output return String is
311 Text : Text_IO.Format;
312 begin
313 return IO.Output (Mode => Text);
314 end Text_Output;
316 end GNAT.CGI.Debug;