Permalink
Fetching contributors…
Cannot retrieve contributors at this time
99 lines (81 sloc) 3.54 KB
(********************************************************************************)
(* Ocsigen_test.ml
Copyright (c) 2009-2016 Dario Teixeira <dario.teixeira@nleyten.com>
This software is distributed under the terms of the GNU GPL version 2.
See LICENSE file for full license text.
*)
(********************************************************************************)
(** Part 9 of the Lambdoc+Ocsigen tutorial.
This instalment illustrates how the {!Lambdoc_document_foldmap} module can be used
to perform deep transformations of documents. The {!revisionist} postprocessor
replaces all occurrences of "Eastasia" by "Eurasia" and vice-versa.
*)
open Eliom_content
open Html.F
open Lambdoc_prelude
open Lambdoc_document
open Lambdoc_reader
open Valid
(********************************************************************************)
(** {1 Modules} *)
(********************************************************************************)
module Eliom_backend =
struct
include Eliom_content.Html.F.Raw
module Svg = Eliom_content.Svg.F.Raw
end
module Lambdoc_writer = Lambdoc_whtml_writer.Make (Eliom_backend)
(********************************************************************************)
(** {1 Functions and values} *)
(********************************************************************************)
let revisionist =
{
Lambdoc_rlambtex_reader.Trivial.Ext.Foldmapper.identity with
plain = (fun fm acc attr txt ->
let aux = Printf.sprintf "%016Lx" (Random.int64 Int64.max_int) in
let txt = Re.replace_string ~all:true ~by:aux (Re.compile @@ Re.str "Eurasia") txt in
let txt = Re.replace_string ~all:true ~by:"Eurasia" (Re.compile @@ Re.str "Eastasia") txt in
let txt = Re.replace_string ~all:true ~by:"Eastasia" (Re.compile @@ Re.str aux) txt in
(acc, Inline.plain ~attr txt));
}
let sample =
let ch = Pervasives.open_in "sample.lambtex" in
let sample = Pervasives.input_all ch in
Pervasives.close_in ch;
sample
let make_page content =
let css_uri = make_uri (Eliom_service.static_dir ()) ["css"; "lambdoc.css"] in
(html
(head
(title (pcdata "Lambdoc + Ocsigen : Basic example"))
[css_link ~a:[(a_media [`All]); (a_title "Default")] ~uri:css_uri ()])
(body content))
let main_service = Eliom_service.create
~meth:(Get Eliom_parameter.unit)
~id:(Path [])
()
let rec step1_handler () () =
let step2_service = Eliom_registration.Html.create
~scope:Eliom_common.default_session_scope
~meth:(Post (Eliom_parameter.unit, Eliom_parameter.string "source"))
~id:(Fallback main_service)
step2_handler in
let step2_form e_source =
[
label [pcdata "Source:"];
Form.textarea ~a:[a_rows 8; a_cols 80] ~name:e_source ~value:sample ();
br ();
Form.button_no_value ~button_type:`Submit [pcdata "Submit"];
] in
Lwt.return (make_page [Form.post_form step2_service step2_form ()])
and step2_handler () source =
let doc = Lambdoc_rlambtex_reader.Trivial.ambivalent_from_string ~postprocessor:revisionist source in
let xdoc = Lambdoc_writer.write_ambivalent doc in
let contents =
[
(xdoc : [ Html_types.div ] Html.F.elt :> [> Html_types.div ] Html.F.elt);
p [a main_service [pcdata "Start again"] ()];
] in
Lwt.return (make_page contents)
let () =
Eliom_registration.Html.register main_service step1_handler