ezxmlm

Author Anil Madhavapeddy
License ISC
Tags { org:mirage, org:ocamllabs }
Maintainer anil@recoil.org
Dependencies
& ocamlbuild
ocamlfind
xmlm >= 1.1.0
Available ocaml-version >= "4.01.0"
Published Jun 3, 2014
Source [http] http://github.com/avsm/ezxmlm/archive/v1.0.1.tar.gz
62beb40ede8d29a21adfff7c3bbe5de1
Statistics Installed 1008 times in last month.
Edit https://github.com/ocaml/opam-repository/tree/master/packages/ezxmlm/ezxmlm.1.0.1/opam

Combinators to use with XMLM for parsing and selection

An "easy" interface on top of the Xmlm [1] library. This version provides more convenient (but far less flexible) input and output functions that go to and from [string] values. This avoids the need to write signal code, which is useful for quick scripts that manipulate XML.

More advanced users should go straight to the Xmlm library and use it directly, rather than be saddled with the Ezxmlm interface. Since the types in this library are more specific than Xmlm, it should interoperate just fine with it if you decide to switch over.

Example

In the toplevel, here's an example of how some XHTML can be selected out quickly using the Ezxmlm combinators. Note that this particular HTML has been post-processed into valid XML using xmllint --html --xmlout.

# #require "ezxmlm" ;;
# open Ezxmlm ;;
# let (_,xml) = from_channel (open_in "html/variants.html") ;;
# member "html" x |> member "head" |> member_with_attr "meta" ;;
- : Xmlm.attribute list * nodes = ([(("", "name"), "generator"); (("", "content"), "DocBook XSL Stylesheets V1.78.1")], [])
# member "html" x |> member "head" |> member "title" |> data_to_string;;
- : string = "Chapter 6. Variants"                                                                                                                                                                                                                                                                                          

Ez peezy lemon squeezy!

[1] https://github.com/dbuenzli/xmlm

Necessary for
aws
>= 1.0.0
jitsu
podge
>= 0.4