Blob Blame History Raw
module Xendconfsxp =
    autoload xfm

let spc1 = /[ \t\n]+/
let ws = del spc1 " "

let lbrack = del /[ \t]*\([ \t\n]*/ "("
let rbrack = del /[ \t\n]*\)/ ")"

let empty_line = [ del /[ \t]*\n/ "\n" ]

let no_ws_comment =
    [ label "#comment" . del /#[ \t]*/ "# " . store /[^ \t]+[^\n]*/ . del /\n/ "\n" ]

let standalone_comment = [ label "#scomment" . del /#/ "#" . store /.*/ . del /\n/ "\n" ]
(* Minor bug: The initial whitespace is stored, not deleted. *)

let ws_and_comment = ws . no_ws_comment

(* Either a word or a quoted string *)
let str_store = store /[A-Za-z0-9_.\/-]+|\"([^\"\\\\]|(\\\\.))*\"|'([^'\\\\]|(\\\\.))*'/

let str = [ label "string" . str_store ]

let var_name = key Rx.word

let rec thing =
    let array = [ label "array" . lbrack . Build.opt_list thing ws . ws_and_comment? . rbrack ] in
    let str = [ label "item" . str_store ] in
    str | array

let sexpr = [ lbrack . var_name . ws . no_ws_comment? . thing . ws_and_comment? . rbrack ]

let lns = ( empty_line | standalone_comment | sexpr ) *

let filter = incl "xend-config.sxp"
let xfm = transform lns filter