File : adagio-statistics-tpl.adb
------------------------------------------------------------------------------
-- ADAGIO - ADALID - AENEA. --
-- --
-- Copyright (C) 2003 --
-- A. Mosteo. --
-- --
-- Authors: A. Mosteo. (adagio@mosteo.com) --
-- --
-- If you have any questions in regard to this software, please address --
-- them to the above email. --
-- --
-- This program is free software; you can redistribute it and/or modify --
-- it under the terms of the GNU General Public License as published by --
-- the Free Software Foundation; either version 2 of the License, or (at --
-- your option) any later version. --
-- --
-- This program is distributed in the hope that it will be useful, but --
-- WITHOUT ANY WARRANTY; without even the implied warranty of --
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU --
-- General Public License for more details. --
-- --
-- You should have received a copy of the GNU General Public License --
-- along with this library; if not, write to the Free Software Foundation, --
-- Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. --
-- --
-- You are not allowed to use any part of this code to develop a program --
-- whose output would be used to harass or prosecute other users of the --
-- networks Adagio connects with. All data collected with Adagio or a tool --
-- containing Adagio code about other network users must remain --
-- confidential and cannot be made public by any mean, nor be used to --
-- harass or legally prosecute these users. --
------------------------------------------------------------------------------
-- $Id: adagio-statistics.adb,v 1.6 2004/01/29 21:47:09 Jano Exp $
-- DEFINED TAGS:
-- DOWNLOADACTIVE : Says if search/download capabilities are enabled.
with Ada.Exceptions;
package body Adagio.Statistics.Tpl is
use Stat_list;
------------------------------------------------------------------------
-- Object --
------------------------------------------------------------------------
protected body Object_Type is
procedure Set (Key : in String; Value : in Values'Class) is
New_value : Value_access;
begin
if Is_in (Key, Data) then
Element (Find (Data, Key)).all := Value;
else
New_value := new Values'Class'(Value);
Insert (Data, Key, New_value);
end if;
end;
function Get (Key : in String) return Values'Class is
begin
if not Is_in (Key, Data) then
raise Value_not_defined;
else
return Element (Find (Data, Key)).all;
end if;
end Get;
procedure Update (
Key : in String;
Process : in Process_function;
Extra : in Values'Class) is
Result : Values'Class := Process (Get (Key), Extra);
begin
Set (Key, Result);
end Update;
function Report return Stat_array is
Result : Stat_array (1 .. Length (Data));
I : Iterator_type := First (Data);
begin
for N in Result'Range loop
begin
Result (N) := (
Key => U (Key (I)),
Value => U (Image (Element (I))));
exception
when E : others =>
Result (N) := (
Key => U (Key (I)),
Value => U (Ada.Exceptions.Exception_Information (E)));
end;
I := Succ (I);
end loop;
return Result;
end;
function Translator return Templates_Parser.Translate_Table is
use Templates_Parser;
Result : Translate_Table (1 .. Length (Data));
I : Iterator_type := First (Data);
begin
for N in Result'Range loop
begin
Result (N) := Assoc (Key (I), Image (Element (I)));
exception
when E : others =>
Result (N) := Assoc (Key (I), Ada.Exceptions.Exception_Information (E));
end;
I := Succ (I);
end loop;
return Result;
end Translator;
end Object_Type;
------------------------------------------------------------------------
-- Http_report --
------------------------------------------------------------------------
procedure Http_report (
Data : out Agpl.Http.Server.Sort_handler.Data_set;
This : access Object_Type := Object'Access)
is
Stats : Stat_array := This.Report;
begin
for N in Stats'Range loop
declare
use Agpl.Http.Server.Sort_handler;
Row : Data_row;
begin
Append (Row, (Stats (N).Key, Stats (N).Key));
Append (Row, (Stats (N).Value, Stats (N).Value));
Append (Data, Row);
end;
end loop;
end Http_report;
------------------------------------------------------------------------
-- Translator --
------------------------------------------------------------------------
function Translator (This : access Object_Type := Object'Access)
return Templates_Parser.Translate_Table
is
begin
return This.Translator;
end Translator;
function Translator_Default return Templates_Parser.Translate_Table is
begin
return Translator (Object'Access);
end Translator_Default;
end Adagio.Statistics.Tpl;