Page
Library
Module
Module type
Parameter
Class
Class type
Source
OCaml parser for HUML (Human Markup Language).
This parser has been compiled with Js_of_ocaml and deployed here: kaustubh.page/huml.
Install the huml-cli package to use the command-line interface.
# Parse HUML file and output JSON to stdout
huml input.huml
# Parse HUML file and save JSON to file
huml input.huml -o output.json
huml input.huml --output output.json
# Show help
huml -h
huml --help
# Show version
huml -v
huml --versionInstall the huml package to use just the library (without the CLI).
open Huml
let parse_huml_string content =
  let lexbuf = Lexing.from_string content in
  match parse lexbuf with
  | Ok ast -> ast
  | Error msg -> failwith msg
(* Example *)
let huml_content = {|
name: "John Doe"
age: 30
active: true
|} in
let ast = parse_huml_string huml_content in
(* ast is of type Types.Ast.t, compatible with Yojson.Safe.t *)The parsed AST is compatible with Yojson.Safe.t.
First build the huml_js.bc.js target using dune:
dune build bin/huml_js.bc.jsThen use the generated JavaScript file from _build/default/bin/huml_js.bc.js. This file can be used as a browser <script src="..."> or in another runtime like Node.js.
It exports a huml object with a single parse method that takes a string and returns an object of type { "error": string, "output": string }. If "error" is an empty string, then the parsing was successful and "output" contains the JSON string.
const result = huml.parse(...);
if (result.error) {
    console.error("Error parsing HUML:", result.error);
} else {
    console.log("Parsed JSON:", result.output);
}Look at examples/playground.html for a working example.
Setup opam, dune, clone this repository, and run:
# Just the library
dune build -p huml @install
# CLI
dune build -p huml-cli @installMIT.