Plasma GitLab Archive
Projects Blog Knowledge

(*
 * <COPYRIGHT>
 * Copyright 2002 Joachim Schrod Network and Publication Consultance GmbH, Gerd Stolpmann
 *
 * <GPL>
 * This file is part of WDialog.
 *
 * WDialog 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.
 *
 * WDialog 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 WDialog; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 * </>
 *)

(* $Id: wd_template.ml,v 3.2 2002-02-14 16:15:21 stolpmann Exp $
 * ----------------------------------------------------------------------
 *
 *)

open Wd_types
open Wd_transform
open Pxp_document
open Pxp_types

module D = Wd_dictionary

exception Template_not_found of string

type template = template_type

type tree = syntax_tree


let get (app:application_type) n =
  try
    app # template n
  with
      Not_found ->
	raise (Template_not_found n)

let apply dialog tt params =
  let params = D.of_alist params in
  Wd_transform.instantiate
    ~context:( dialog#declaration#default_context )
    ~params
    dialog
    tt


let apply_byname ?(localized=true) dialog n params =
  let t =
    try
      if not localized then raise (Template_not_found "");
      match dialog # declaration # language_variable with
	  None -> raise (Template_not_found "");
	| Some v ->
	    let lang = dialog # string_variable v in
	    get dialog#application (n ^ "#" ^ lang)
    with
	Template_not_found _ ->
	  get dialog#application n
  in
  apply dialog t params


let apply_lazily (dialog:dialog_type) n params =
  ignore(get dialog#application n);  (* only check whether template n exists *)
  Wd_transform.mk_use_param_node
    (dialog#application#dtd)
    n
    params
;;


let text app s =
  Wd_transform.mk_text_node
    app#dtd
    s
;;


let html app s =
  Wd_transform.mk_html_node
    app#dtd
    s
;;


let empty app = text app ""


let concat app sep l =
  Wd_transform.concat
    ~sep: sep
    app#dtd
    l

let to_string obj t =
  let buffer = Buffer.create 1024 in
  let outch = new Netchannels.output_buffer buffer in
  let app_decl = obj#application in
  let obj_decl = obj#declaration in
  let vars = { within_popup = false;
	       current_page = obj # page_name;
	       popup_env_initialized = false;
	       condition_code = false;
	       serialize_session = (fun () ->
				      raise(Runtime_error("Wd_template.to_string [deferred exception]: Cannot serialize session data")));
	     } in
    (* [vars] works only outside popup windows *)

  Wd_transform.to_html
    ~vars
    obj
    outch
    t;
  Buffer.contents buffer


(* ======================================================================
 * History:
 *
 * $Log: wd_template.ml,v $
 * Revision 3.2  2002-02-14 16:15:21  stolpmann
 * 	Added copyright notice.
 *
 * Revision 3.1  2002/02/12 20:29:20  stolpmann
 * 	Initial release at sourceforge.
 *
 * Revision 1.13  2002/02/05 18:47:21  gerd
 * 	Minor follow-up change
 *
 * Revision 1.12  2002/01/31 23:06:39  gerd
 * 	Revised conditional expansion (ui:if, ui:ifvar, ui:iflang,
 * ui:cond).
 * 	Added some support for internationalization (xml:lang).
 *
 * Revision 1.11  2002/01/26 22:38:26  gerd
 * 	Changed the type for passing parameters to templates. It is
 * now syntax_tree dict instead of a simple list. Furthermore, the
 * method [instantiate] no longer returns the new context. The new element
 * ui:context creates the new contexts now.
 *
 * Revision 1.10  2002/01/14 15:03:24  gerd
 * 	Major change: Typing has been completely revised, and almost
 * every tiny thing has now a new type. Also renamed a lot.
 *
 * Revision 1.9  2000/12/06 15:28:20  gerd
 * 	to_string: (Still buggy) support for the ~self_url parameter.
 * 	html: Implemented for the first time
 *
 * Revision 1.8  2000/11/30 18:39:49  gerd
 * 	Changed for new interface of Parse.
 *
 * Revision 1.7  2000/09/25 13:22:13  gerd
 * 	New ui:popup element
 *
 * Revision 1.6  2000/09/21 15:12:34  gerd
 * 	Updated for O'Caml 3 and PXP
 *
 * Revision 1.5  2000/05/10 13:54:05  gerd
 * 	Bugfix.
 *
 * Revision 1.4  2000/05/08 15:30:38  gerd
 * 	The default context of the object is passed when a template
 * is instantiated.
 *
 * Revision 1.3  2000/05/08 10:35:26  gerd
 * 	When calling "to_html", an empty context is passed. (Perhaps
 * this should be changed to a "default context".)
 *
 * Revision 1.2  2000/04/17 10:10:52  gerd
 * 	New Cgi module.
 * 	File upload strongly improved.
 *
 * Revision 1.1  2000/04/13 17:42:58  gerd
 * 	Initial revision.
 *
 *
 *)

This web site is published by Informatikbüro Gerd Stolpmann
Powered by Caml