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" . Util.stdexcl let xfm = transform lns filter