Blame lenses/xendconfsxp.aug

Packit Service a2ae7a
module Xendconfsxp =
Packit Service a2ae7a
    autoload xfm
Packit Service a2ae7a
Packit Service a2ae7a
let spc1 = /[ \t\n]+/
Packit Service a2ae7a
let ws = del spc1 " "
Packit Service a2ae7a
Packit Service a2ae7a
let lbrack = del /[ \t]*\([ \t\n]*/ "("
Packit Service a2ae7a
let rbrack = del /[ \t\n]*\)/ ")"
Packit Service a2ae7a
Packit Service a2ae7a
let empty_line = [ del /[ \t]*\n/ "\n" ]
Packit Service a2ae7a
Packit Service a2ae7a
let no_ws_comment =
Packit Service a2ae7a
    [ label "#comment" . del /#[ \t]*/ "# " . store /[^ \t]+[^\n]*/ . del /\n/ "\n" ]
Packit Service a2ae7a
Packit Service a2ae7a
let standalone_comment = [ label "#scomment" . del /#/ "#" . store /.*/ . del /\n/ "\n" ]
Packit Service a2ae7a
(* Minor bug: The initial whitespace is stored, not deleted. *)
Packit Service a2ae7a
Packit Service a2ae7a
let ws_and_comment = ws . no_ws_comment
Packit Service a2ae7a
Packit Service a2ae7a
(* Either a word or a quoted string *)
Packit Service a2ae7a
let str_store = store /[A-Za-z0-9_.\/-]+|\"([^\"\\\\]|(\\\\.))*\"|'([^'\\\\]|(\\\\.))*'/
Packit Service a2ae7a
Packit Service a2ae7a
let str = [ label "string" . str_store ]
Packit Service a2ae7a
Packit Service a2ae7a
let var_name = key Rx.word
Packit Service a2ae7a
Packit Service a2ae7a
let rec thing =
Packit Service a2ae7a
    let array = [ label "array" . lbrack . Build.opt_list thing ws . ws_and_comment? . rbrack ] in
Packit Service a2ae7a
    let str = [ label "item" . str_store ] in
Packit Service a2ae7a
    str | array
Packit Service a2ae7a
Packit Service a2ae7a
let sexpr = [ lbrack . var_name . ws . no_ws_comment? . thing . ws_and_comment? . rbrack ]
Packit Service a2ae7a
Packit Service a2ae7a
let lns = ( empty_line | standalone_comment | sexpr ) *
Packit Service a2ae7a
Packit Service a2ae7a
let filter = incl "xend-config.sxp"
Packit Service a2ae7a
let xfm = transform lns filter