(*********************************************************************************)

(*                Cameleon                                                       *)
(*                                                                               *)
(*    Copyright (C) 2005,2006 Institut National de Recherche en Informatique     *)
(*    et en Automatique. All rights reserved.                                    *)
(*                                                                               *)
(*    This program is free software; you can redistribute it and/or modify       *)
(*    it under the terms of the GNU Library General Public License as            *)
(*    published by the Free Software Foundation; either version 2 of the         *)
(*    License, or  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 Library General Public License for more details.                       *)
(*                                                                               *)
(*    You should have received a copy of the GNU Library General Public          *)
(*    License along with this program; if not, write to the Free Software        *)
(*    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA                   *)
(*    02111-1307  USA                                                            *)
(*                                                                               *)
(*    Contact: Maxence.Guesdon@inria.fr                                          *)
(*                                                                               *)
(*********************************************************************************)


type 'a report_ele = 'Rep_types.report_ele =
  | Leaf of (unit -> string)
  | Tag of 'a tag
  | List of 'a liste
  | Cond of 'a cond
  | Sub of 'a sub

and 'a tag = 'Rep_types.tag = {
    mutable tag : string ;
    mutable atts : (string * (unit -> string)) list ;
    mutable tag_subs : 'a report_ele list
  } 
    
and 'a liste = 'Rep_types.liste =
    { mutable list_subs : ('-> 'a report_ele list) ;
      mutable f : (unit -> 'a list) ;
    }

and 'a cond = 'Rep_types.cond = 
    { mutable cond : unit -> bool ;
      mutable subs_then : 'a report_ele list ;
      mutable subs_else : 'a report_ele list ;
    } 

and 'a sub = 'Rep_types.sub = 
    {
      mutable sub_rep : unit -> 'a report ;
    } 

and 'a report = 'Rep_types.report =
    {
      mutable rep_eles : 'a report_ele list ;
    } 

let coerce = Rep_gen.coerce

let compute ?(html=false) fmt report =
  Rep_gen.print_fmt ~html: html fmt report

let compute_file ?(html=false) file report = 
  Rep_gen.print_file ~html: html file report

(*

(**********************************)

let liste = ref []
let _ = for i = 0 to 100 do liste := i :: !liste done

let (report : int report_ele)= 
  Tag { tag = "html" ; atts = [] ; tag_subs =
        [Tag { tag = "body" ; atts = [("bgcolor", "white")] ; tag_subs =
               [
                 Tag { tag = "table" ; atts = [("border", "1")] ; tag_subs =
                       let rec n = { f = (fun () -> !liste) ; current = 0 ; sub_subs =
                                     [
                                       Tag { tag = "tr" ; atts = [] ; tag_subs = 
                                             [
                                               Tag { tag = "td" ; atts = [] ; tag_subs =
                                                     [
                                                       Leaf (fun () -> string_of_int n.current)
                                                     ] 
                                                   } 
                                             ] 
                                           } 
                                     ]
                                   }
                       in
                       [ Sub (mag n) ]
                     } 
               ] 
             } 
        ]
      }         

let _ = print Format.std_formatter report
*)