1 (* Wrapper around Perl HTML::Element class.
2 * Copyright (C) 2003 Merjis Ltd.
3 * $Id: pl_HTML_Element.ml,v 1.1 2003-10-12 17:33:15 rich Exp $
8 type 'a content_t = Element of 'a | String of string
10 class html_element sv =
12 let rec assocs_of_svlist = function
14 | [x] -> failwith "HTML::Element all_attr returned odd-length list!"
15 | svname :: svvalue :: xs ->
16 (string_of_sv svname, string_of_sv svvalue) :: assocs_of_svlist xs
19 let rec list_of_svlist = function
22 string_of_sv sv :: list_of_svlist xs
30 string_of_sv (call_method sv "attr" [sv_of_string name])
31 method set_attr name value =
32 call_method_void sv "attr" [sv_of_string name; sv_of_string value]
34 string_of_sv (call_method sv "tag" [])
36 call_method_void sv "tag" [sv_of_string tag]
38 let sv = call_method sv "parent" [] in
40 method set_parent (parent : html_element) =
41 call_method_void sv "parent" [parent#sv]
43 let svlist = call_method_array sv "content_list" [] in
47 SVt_PV -> String (string_of_sv c)
48 | SVt_RV -> Element (new html_element (deref c))
49 | _ -> failwith "HTML::Element content_type: unknown type"
52 let svlist = call_method_array sv "all_attr" [] in
53 assocs_of_svlist svlist
54 method all_attr_names =
55 let svlist = call_method_array sv "all_attr_names" [] in
57 method all_external_attr =
58 let svlist = call_method_array sv "all_external_attr" [] in
59 assocs_of_svlist svlist
60 method all_external_attr_names =
61 let svlist = call_method_array sv "all_external_attr_names" [] in
66 (* Note that "new" is a reserved word, so I've appended an _ character. *)
68 let rec loop = function
70 | (name, value) :: xs -> sv_of_string name :: sv_of_string value :: loop xs
72 let sv = call_class_method "HTML::Element" "new"
73 (sv_of_string tag :: loop attrs) in