S | |
save_entry, Redis | |
savedefault, Grub | |
schedule, Cron | |
Schroot | |
screen, Xorg | |
script, Xymon_Alerting | |
search, Resolv | |
section, Xorg | |
section_entry, Xorg | |
section_re, Xorg | |
SECTIONS, Xorg | |
secton_re_obsolete, Xorg | |
selector, Syslog | |
selectors, Syslog | |
semicol, Channels | |
semicolon | |
sensor, Ntpd | |
sep | |
Sep | |
sep_ace, Test_IniFile | |
sep_acf, Test_IniFile | |
sep_ade, Test_IniFile | |
sep_adf, Test_IniFile | |
sep_base64, Ldif | |
sep_bce, Test_IniFile | |
sep_bcf, Test_IniFile | |
sep_bde, Test_IniFile | |
sep_bdf, Test_IniFile | |
sep_col, Sudoers | |
sep_colon | |
sep_com, Sudoers | |
sep_cont, Sudoers | |
sep_cont_opt, Sudoers | |
sep_cont_opt_build, Sudoers | |
sep_default, IniFile | |
sep_dquote | |
sep_eq | |
sep_line, Ldif | |
sep_moddir, Solaris_System | |
sep_modspec, Ldif | |
sep_noindent, IniFile | |
sep_re, IniFile | |
sep_record, Ldif | |
sep_semi, Up2date | |
sep_space, Modprobe | |
sep_spc | |
sep_tab | |
sep_tab_opt, Syslog | |
sep_url, Ldif | |
sep_ws, Aptsources | |
separators | |
Separators | |
serial, Grub | |
server, Ntpd | |
server_peer, Chrony | |
servers, Ntpd | |
service | |
service_attr, Xinetd | |
Services | |
set, BootConf | |
set_operator, Solaris_System | |
set_sep_spc, Solaris_System | |
set_value, Solaris_System | |
set_var, Solaris_System | |
setkey, Grub | |
setting, Puppet_Auth | |
settings, Chrony | |
Shadow | |
shell, Passwd | |
shell_command, Hosts_Access | |
shell_command_rx, Hosts_Access | |
Shells | |
shellvar | |
Shellvars | |
simple | |
simple values, Test_Erlang | |
simple_config, Test_FAI_DiskConfig | |
simple_keys, Chrony | |
Simplelines | |
Simplevars | |
single | |
single characters macro, Syslog | |
single_command, BootConf | |
single_entry, Up2date | |
single_opt | |
single_opt_re, Quote | |
Sip_Conf | |
size, FAI_DiskConfig | |
size_kw, FAI_DiskConfig | |
slaveof_entry, Redis | |
SmbUsers | |
smtp_check, Test_Keepalived | |
smtp_check_field, Keepalived | |
smtp_host_check_field, Keepalived | |
softdep, Modprobe | |
Solaris_System | |
sortlist, Resolv | |
space | |
space_equal, Sep | |
space_in, Rx | |
space_list_re, Subversion | |
space_or_eol | |
space_or_eol_re, Postfix_Virtual | |
Spaces, Rx | |
Spacing Functions, Erlang | |
spare_missing, FAI_DiskConfig | |
spc, Grub | |
spec | |
spec_list, Sudoers | |
SPECIAL OPTIONS, Resolv | |
Split, Util | |
Splunk | |
squote, Quote | |
squote_opt, Quote | |
squote_opt_nil | |
squote_spaces | |
Ssh | |
Sshd | |
ssl_options | |
sssd.aug | |
standard_entry, Redis | |
static_ipaddress_field, Keepalived | |
static_routes, Keepalived | |
static_routes_field, Keepalived | |
std_re, Subversion | |
stdexcl, Util | |
sto_bool, Host_Conf | |
sto_bool_warn, Host_Conf | |
sto_email_addr, Keepalived | |
sto_integer, Sudoers | |
sto_line, Modules | |
sto_multiline, IniFile | |
sto_multiline_nocomment, IniFile | |
sto_no_colons, Modprobe | |
sto_no_spaces, Modprobe | |
sto_num, Keepalived | |
sto_to_colon, Hosts_Access | |
sto_to_com, Sudoers | |
sto_to_com_cmnd, Sudoers | |
sto_to_com_col, Sudoers | |
sto_to_com_dquot, Sudoers | |
sto_to_com_host, Sudoers | |
sto_to_com_user, Sudoers | |
sto_to_comment | |
sto_to_eol | |
sto_to_eq, Sudoers | |
sto_to_spc, Sudoers | |
sto_to_spc_no_dquote, Sudoers | |
sto_value, Systemd | |
sto_value_single, Systemd | |
sto_word, Keepalived | |
stop, Xymon_Alerting | |
Store types, Erlang | |
store_address, Chrony | |
store_word, Xymon_Alerting | |
Stores | |
stratum_re, Ntpd | |
stty, BootConf | |
subnet, Sysconfig_Route | |
SUBNODE CONSTRUCTIONS | |
Subversion | |
Sudoers | |
switch, Grub | |
switch_arg, Grub | |
Sysconfig_Route | |
Sysctl | |
Syslog | |
Systemd |
Entries identified by the “save” keyword can be found more than once.
let save_entry = [ indent . key save . del_ws_spc . seconds . del_ws_spc . keys . eol ]
let savedefault = [ command "savedefault" "\t" . (spc . store Rx.integer)? . eol ]
Time in the format “@keyword”
let schedule = [ label "schedule" . Util.del_str "@" . store schedule_re ]
The Screen entry of ServerLayout
let screen = [ indent . del /[sS]creen/ "Screen" . label "Screen" . [ sep_spc . label "num" . store int ]? . ( sep_spc . quoted_string_val . [ sep_spc . label "position" . store to_eol ]? )? . eol ]
The script recipient definition
let script = [ key "SCRIPT" . ws . [ label "script" . store_word ] . ws . [ label "recipient" . store_word ] . filters_opt ]
let search = Build.key_value_line_comment "search" Sep.space (Build.opt_list [label "domain" . store Rx.word] Sep.space) comment_eol
A section in xorg.conf
let section = [ indent . del "Section" "Section" . sep_spc . sep_dquote . key (section_re|section_re_obsolete) . sep_dquote . eol . section_entry* . indent . del "EndSection" "EndSection" . eol ]
let section_entry = option | screen | display | extmod | input_device | driver | identifier | videoram | default_depth | device | entry_generic | empty | comment
Known values for Section names
let section_re = /(Extensions|Files|ServerFlags|Module|InputDevice|InputClass|Device|VideoAdaptor|Monitor|Modes|Screen|ServerLayout|DRI|Vendor)/
a list of selectors, separated by semicolons
let selectors = label_opt_list "selector" selector semicolon
let semicol = Util.del_str ";"
let semicolon = Util.del_str ";"
Deletes a semicolon and default to it
let semicolon = sep_tab_opt . Util.del_str ";" . sep_tab_opt
sensor device [correction microseconds] [weight weight-value] [refid string] [stratum stratum-value]
let sensor = let device = [ label "device" . store device_re ] in let correction = opt_value "correction" correction_re in let weight = opt_value "weight" weight_re in let refid = opt_value "refid" refid_re in let stratum = opt_value "stratum" stratum_re in [ key "sensor" . space . device . (space . correction)? . (space . weight)? . (space . refid)? . (space . stratum)? . eol ]
Only treat one space as the sep, extras are stripped by IniFile
let sep = Util.del_str " "
let sep = /[ \t]+/
let sep = IniFile.sep IniFile.sep_re IniFile.sep_default
let sep = IniFile.sep "=" "="
Generic separator
let sep (pat:regexp) (default:string) = Sep.opt_space . del pat default
let sep = IniFile.sep /=[ \t]*/ "="
The separator for network/mask entries
let sep = Util.del_ws_tab
Key and values are separated by either spaces or an equal sign
let sep = del /([ \t]+)|([ \t]*=[ \t]*)/ " = "
An IniFile.sep entry
let sep = IniFile.sep "=" "="
let sep = IniFile.sep IniFile.sep_default IniFile.sep_default
An IniFile.sep entry
let sep = IniFile.sep "=" "="
let sep_ace = IniFile.sep IniFile.sep_re IniFile.sep_default
let sep_acf = IniFile.sep IniFile.sep_re IniFile.sep_default
let sep_ade = IniFile.sep IniFile.sep_re IniFile.sep_default
let sep_adf = IniFile.sep IniFile.sep_re IniFile.sep_default
The separator for attributes and base64 encoded values
let sep_base64 = del /::[ \t]*/ ":: "
let sep_bce = IniFile.sep "=" "="
let sep_bcf = IniFile.sep "=" "="
let sep_bde = IniFile.sep "=" "="
let sep_bdf = IniFile.sep "=" "="
let sep_col = sep_cont_opt_build ":"
The separator for attributes and values
let sep_colon = del /:[ \t]*/ ": "
The separator for database entries
let sep_colon = del /:[ \t]*/ ": "
The separator for key/value entries
let sep_colon = del /:[ \t]*/ ": "
let sep_com = sep_cont_opt_build ","
let sep_cont = Sep.cl_or_space
let sep_cont_opt = Sep.cl_or_opt_space
let sep_cont_opt_build (sep:string) = del (Rx.cl_or_opt_space . sep . Rx.cl_or_opt_space) (" " . sep . " ")
The default separator value
let sep_default = "="
let sep_dquote = Util.del_str "\""
let sep_dquote = Util.del_str "\""
let sep_eq = Util.del_str "="
let sep_eq = sep_cont_opt_build "="
let sep_line = empty | comment
The separator of directories in a moddir search path
let sep_moddir = del /[: ]+/ " "
Separator between modify operations
let sep_modspec = Util.del_str "-" . eol
Generic separator, no indentation
let sep_noindent (pat:regexp) (default:string) = del pat default
The default regexp for a separator
let sep_re = /[=:]/
let sep_record = ( sep_line | attr_include )*
let sep_semi = Sep.semicolon
let sep_space = del /([ \t]|(\\\\\n))+/ " "
let sep_spc = Util.del_ws_spc
let sep_spc = Sep.space
let sep_spc = Sep.space
let sep_spc = Util.del_ws_spc
let sep_tab = Sep.tab
let sep_tab = del /([ \t]+|[ \t]*\\\\\n[ \t]*)/ "\t"
let sep_tab_opt = del /([ \t]*|[ \t]*\\\\\n[ \t]*)/ ""
let sep_ws = del /[ \t]+/ " "
let serial = [ command "serial" "" . [ spc . switch_arg /unit|port|speed|word|parity|stop|device/ ]* . eol ]
server address [weight weight-value] [rtable table-id]
let server = let addr = [ label "address" . store address_re ] in key_opt_weight_rtable_line "server" addr
Server/Peer key names
let server_peer = "server"|"peer"
servers address [weight weight-value] [rtable table-id]
let servers = let addr = [ label "address" . store address_re ] in key_opt_weight_rtable_line "servers" addr
The service specification like `files’, `db’, or `nis’
let service = [ label "service" . store Rx.word ]
The (ex)?service filter definition
let service = kw_word /(EX)?SERVICE/
It is much faster to combine, for example, all the attr_one attributes into one regexp and pass that to a lens instead of using lens union (attr_one “a” | attr_one “b”|..)
let service_attr = attr_one (/socket_type|protocol|wait|user|group|server|instances/i |/rpc_version|rpc_number|id|port|nice|banner|bind|interface/i |/per_source|groups|banner_success|banner_fail|disable|max_load/i |/rlimit_as|rlimit_cpu|rlimit_data|rlimit_rss|rlimit_stack|v6only/i |/deny_time|umask|mdns|libwrap/i)
set [varname [value]]
let set = Build.key_value "set" space (key_opt_value_line set_cmd (store Rx.space_in))
Valid set operators: equals, bitwise AND and OR
let set_operators = /[=&|]/
let set_sep_spc = Util.del_opt_ws " "
Sets an integer value or char pointer
let set_value = [ label "value" . store Rx.no_spaces ]
Loads the variable name from a set command, no module
let set_var = [ label "variable" . store Rx.word ]
let setkey = [ command "setkey" "" . ( spc . [ label "to" . store Rx.no_spaces ] . spc . [ label "from" . store Rx.no_spaces ] )? . eol ]
let setting = list "environment" Rx.word | list "method" /find|search|save|destroy/ | list "allow" /[^# \t\n,][^#\n,]*[^# \t\n,]|[^# \t\n,]/ | list "allow_ip" /[A-Za-z0-9.:\/]+/ | auth
All supported chrony settings
let settings = host_list | log_list | bcast | fdrift | istepslew | local | email | makestep | maxchange | kv | all_flags
pw_shell
let shell = [ label "shell" . sto_to_eol? ]
let shell_command = [ label "shell_command" . store shell_command_rx ]
let shell_command_rx = /[^ \t\n:][^\n]*[^ \t\n]|[^ \t\n:\\\\]/ - ( option_kw . /.*/ )
A shell variable in crontab
let shellvar = Cron.shellvar
A shell variable in crontab
let shellvar = let key_re = /[A-Za-z-1-9_]+(\[[0-9]+\])?/ - "entry" in let sto_to_eol = store /[^\n]*[^ \t\n]/ in [ key key_re . sep_eq . sto_to_eol . eol ]
A simple entry
let simple = let kw = Rx.word - block_re_all in let sto = store /[^ \t\n;][^;]*/ . Sep.semicolon in [ Util.indent . key kw . Sep.space . sto . (Util.eol|Util.comment_eol) ]
let simple = "LoadPlugin contextswitch LoadPlugin cpu FQDNLookup \"true\" Include \"/var/lib/puppet/modules/collectd/plugins/*.conf\" "
A simple configuration file
let simple_config = "# A comment disk_config disk2 raw-disk - 0 - - disk_config lvm vg my_pv sda2 vg test disk1.9 my_pv-_swap swap 2048 swap sw my_pv-_root / 2048 ext3 rw,errors=remount-ro disk_config raid raid1 /boot disk1.1,disk2.1,disk3.1,disk4.1,disk5.1,disk6.1 ext3 rw raid1 swap disk1.2,disk2.2,disk3.2,disk4.2,disk5.2,disk6.2 swap sw raid5 /srv/data disk1.11,disk2.11,disk3.11,disk4.11,disk5.11,disk6.11 ext3 ro createopts=\"-m 0\" raid0 - disk2.2,sdc1,sde1:spare:missing ext2 default disk_config tmpfs tmpfs /var/opt/hosting/tmp 500 defaults "
Options with single values
let simple_keys = "acquisitionport" | "allow" | "bindaddress" | "bindcmdaddress" | "cmdallow" | "cmddeny" | "combinelimit" | "commandkey" | "cmdport" | "corrtimeratio" | "deny" | "driftfile" | "dumpdir" | "keyfile" | "leapsectz" | "linux_hz" | "linux_freq_scale" | "logbanner" | "logchange" | "logdir" | "maxclockerror" | "maxsamples" | "maxupdateskew" | "minsamples" | "clientloglimit" | "pidfile" | "port" | "reselectdist" | "rtcdevice" | "rtcfile" | "sched_priority" | "stratumweight" | "user"
A single-quoted value
let single = let body = store /[^\n]*/ in do_squote body
let single = [ label "single" . Quote.single ]
single command such as ‘help’ or ‘time’
let single_command = let line_re = /help|time|reboot/ in [ Util.indent . key line_re . eol ]
key=foo
let single_entry = [ label "value" . store value_re ]
An optionaly single-quoted value Single quotes are not allowed in value Value cannot begin or end with spaces
let single_opt = let body = store single_opt_re in do_squote_opt body
let single_opt = [ label "single_opt" . Quote.single_opt ]
The regexp to store when value is optionally single-quoted
let single_opt_re = /[^\n\t ']([^\n']*[^\n\t '])?/
let size = [ label "size" . store size_kw . resize? ]
Regexps for size
let size_kw = /[0-9]+[kMGTP%]?(-([0-9]+[kMGTP%]?)?)?/ | /-[0-9]+[kMGTP%]?/
Entries identified by the “slaveof” keyword can be found more than once.
let slaveof_entry = [ indent . key slaveof . del_ws_spc . ip . del_ws_spc . port . eol ]
An example of an SMTP health checker
let smtp_check = "virtual_server 192.168.1.11 22 { real_server 10.20.40.10 22 { SMTP_CHECK { host { connect_ip 10.20.40.11 connect_port 587 bindto 192.168.1.1 } connect_timeout 3 retry 5 delay_before_retry 10 helo_name \"Testing Augeas\" } } } " test Keepalived.lns get smtp_check = { "virtual_server" { "ip" = "192.168.1.11" } { "port" = "22" } { "real_server" { "ip" = "10.20.40.10" } { "port" = "22" } { "SMTP_CHECK" { "host" { "connect_ip" = "10.20.40.11" } { "connect_port" = "587" } { "bindto" = "192.168.1.1" } } { "connect_timeout" = "3" } { "retry" = "5" } { "delay_before_retry" = "10" } { "helo_name" = "\"Testing Augeas\"" } } } }
let smtp_check_field = let word_re = "connect_ip" | "bindto" in let num_re = "connect_timeout" | "retry" | "delay_before_retry" in let to_eol_re = "helo_name" in field word_re sto_word | field num_re sto_num | field to_eol_re sto_to_eol | block "host" smtp_host_check_field
let smtp_host_check_field = let word_re = "connect_ip" | "bindto" in let num_re = "connect_port" in field word_re sto_word | field num_re sto_num
let softdep = let premod = [ label "pre" . sep_space . sto_no_colons ] in let pre = sep_space . Util.del_str "pre:" . premod+ in let postmod = [ label "post" . sep_space . sto_no_colons ] in let post = sep_space . Util.del_str "post:" . postmod+ in [ key "softdep" . sep_space . sto_no_colons . pre? . post? . Util.comment_or_eol ]
let sortlist = Build.key_value_line_comment "sortlist" Sep.space (Build.opt_list ipaddr Sep.space) comment_eol
Separation between key and value
let space = Util.del_ws_spc
let space = Sep.space
Separation between key and value
let space = Util.del_ws_spc
let space = Sep.space
let space = del /[ \t\n]*/ ""
let space = Sep.space
let space = Sep.space
A mandatory space or tab
let space = /[ \t]+/
Deletes a Rx.space and default to a single space
let space = del Rx.space " "
let space_equal = Util.delim "="
A string which not starting or ending with a space
let space_in = /[^ \r\t\n].*[^ \r\t\n]|[^ \t\n\r]/
let space_list_re = "global-ignores" | "preserved-conflict-file-exts"
let space_or_eol = del /([ \t]*\n)?[ \t]+/ " "
let space_or_eol (sep:regexp) (default:string) = del (space_or_eol_re? . sep . space_or_eol_re?) default
let space_or_eol_re = /([ \t]*\n)?[ \t]+/
let spare_missing = tag /spare|missing/
let spc = Util.del_ws_spc
A user specification, listing colon-separated spec_lists
let spec = [ label "spec" . indent . alias_list "user" sto_to_com_user . sep_cont . Build.opt_list spec_list sep_col . comment_or_eol ]
Spec users can be aliases
test Sudoers.spec get "APACHE_ADMIN ALL= ALL\n" = { "spec" { "user" = "APACHE_ADMIN" } { "host_group" { "host" = "ALL" } { "command" = "ALL" } } }
Group of hosts with cmnd_spec_list
let spec_list = [ label "host_group" . alias_list "host" sto_to_com_host . sep_eq . cmnd_spec_list ]
A single quote
let squote = Util.del_str "'"
An optional single quote, default to single
let squote_opt = del /'?/ "'"
An optional single quote, default to nothing
let squote_opt_nil = del /'?/ ""
let squote_opt_nil = let body = store Quote.single_opt_re in [ label "squote_opt_nil" . Quote.do_squote_opt_nil body ]?
Make single quotes mandatory if value contains spaces, and optional if value doesn’t contain spaces.
let squote_spaces (lns:lens) =
(Incomplete) list of SSL options
let ssl_options = let option = Erlang.value /((ca)?cert|key)file/ Erlang.path | Erlang.value "verify" Erlang.bare | Erlang.value "verify_fun" Erlang.boolean | Erlang.value /fail_if_no_peer_cert|reuse_sessions/ Erlang.boolean | Erlang.value "depth" Erlang.integer | Erlang.value "password" Erlang.quoted in Erlang.list "ssl_options" option
test Rabbitmq.ssl_options get "{ssl_options, [ {cacertfile,\"/path/to/testca/cacert.pem\"}, {certfile,\"/path/to/server/cert.pem\"}, {keyfile,\"/path/to/server/key.pem\"}, {verify,verify_peer}, {fail_if_no_peer_cert,false}]}" = { "ssl_options" { "cacertfile" = "/path/to/testca/cacert.pem" } { "certfile" = "/path/to/server/cert.pem" } { "keyfile" = "/path/to/server/key.pem" } { "verify" = "verify_peer" } { "fail_if_no_peer_cert" = "false" } }
A standard entry is a key-value pair, separated by blank space, with optional blank spaces at line beginning & end.
let standard_entry = let reserved_k = "save" | "rename-command" | "slaveof" | "client-output-buffer-limit" in let entry_noempty = [ indent . key k . del_ws_spc . Quote.do_quote_opt_nil (store v) . eol ] in let entry_empty = [ indent . key (k - reserved_k) . del_ws_spc . dquote . store "" . dquote . eol ] in entry_noempty | entry_empty
The whole string is fed to ip addr add.
let static_ipaddress_field = [ indent . ipaddr . (sep_spc . ipdev)? . comment_or_eol ]
let static_routes = block "static_ipaddress" static_ipaddress_field | block "static_routes" static_routes_field
src $SRC_IP to $DST_IP dev $SRC_DEVICE
let static_routes_field = [ indent . label "route" . [ key "src" . sto_word ] . sep_spc . [ key "to" . sto_word ] . sep_spc . [ key "dev" . sto_word ] . comment_or_eol ]
let std_re = /[^ \t\r\n\/=#]+/ - (comma_list_re | space_list_re)
Exclusion for files that are commonly not wanted/needed
let stdexcl = (excl "*~") . (excl "*.rpmnew") . (excl "*.rpmsave") . (excl "*.dpkg-old") . (excl "*.dpkg-new") . (excl "*.dpkg-bak") . (excl "*.dpkg-dist") . (excl "*.augsave") . (excl "*.augnew") . (excl "*.bak") . (excl "*.old") . (excl "#*#")
Store a boolean value
let sto_bool = store ("on"|"off")
Store a boolean value
let sto_bool_warn = store ("on"|"off"|"warn"|"nowarn")
let sto_email_addr = store Rx.email_addr
let sto_integer = store /[0-9]+/
let sto_line = store /[^# \t\n].*[^ \t\n]|[^# \t\n]/
Store multiline values
let sto_multiline = Sep.opt_space . store (to_comment_re . (/[ \t]*\n/ . Rx.space . to_comment_re)*)
Store multiline values without an end-of-line comment
let sto_multiline_nocomment = Sep.opt_space . store (Rx.space_in . (/[ \t]*\n/ . Rx.space . Rx.space_in)*)
let sto_no_colons = store /[^:# \t\n\\\\]+/
let sto_no_spaces = store /[^# \t\n\\\\]+/
let sto_num = store Rx.relinteger
Allows escaped colon sequences
let sto_to_colon = store /[^ \t\n:=][^\n:]*((\\\\:|\\\\[ \t]*\n[ \t]+)[^\n:]*)*[^ \\\t\n:]|[^ \t\n:\\\\]/
There could be a \ in the middle of a command
let sto_to_com = store /([^,=:#() \t\n\\][^,=:#()\n]*[^,=:#() \t\n\\])|[^,=:#() \t\n\\]/
sto_to_com_cmnd does not begin or end with a space
let sto_to_com_cmnd = let alias = Rx.word - /(NO)?(PASSWD|EXEC|SETENV)/ in let non_alias = /(!?[\/a-z]([^,:#()\n\\]|\\\\[=:,\\])*[^,=:#() \t\n\\])|[^,=:#() \t\n\\]/ in store (alias | non_alias)
let sto_to_com_col = store to_com_chars
let sto_to_com_dquot = store (to_com_chars|to_com_dquot)
let sto_to_com_host = store /[^,=:#() \t\n\\]+/
Escaped spaces and NIS domains and allowed
let sto_to_com_user = let nis_re = /([A-Z]([-A-Z0-9]|(\\\\[ \t]))*+\\\\\\\\)/ in let user_re = /[%+@a-z]([-A-Za-z0-9._+]|(\\\\[ \t]))*/ in let alias_re = /[A-Z_]+/ in store ((nis_re? . user_re) | alias_re)
Store until comment
let sto_to_comment = Sep.opt_space . store /[^# \t\r\n][^#\r\n]*[^# \t\r\n]|[^# \t\r\n]/
Store until comment
let sto_to_comment = Sep.opt_space . store to_comment_re
Store until end of line
let sto_to_eol = Sep.opt_space . store Rx.space_in
let sto_to_eol = store /[^#! \t\n][^#!\n]*[^#! \t\n]|[^#! \t\n]/
let sto_to_eol = store /(([^# \t\n\\\\][^#\n\\\\]*[ \t]*\\\\[ \t]*\n[ \t]*)*([^# \t\n\\\\][^#\n\\\\]*[^# \t\n\\\\]|[^# \t\n\\\\])|[^# \t\n\\\\])/
let sto_to_eq = store /[^,=:#() \t\n\\]+/
let sto_to_spc = store /[^", \t\n\\]+|"[^", \t\n\\]+"/
let sto_to_spc_no_dquote = store /[^",# \t\n\\]+/ (* " relax emacs *)
let sto_value = store /[^# \t\n]*[^# \t\n\\]/
Support multiline values with a backslash
let sto_value_single = Util.del_opt_ws "" . store (value_single_re . (/\\\\\n/ . value_single_re)*)
let sto_word = store word
The stop recipient definition
let stop = flag_filters_opt "STOP"
let store_address = [ label "address" . store address_re ]
let store_word = store /[^ =\t\n#]+/
value between 1 and 15
let stratum_re = /1[0-5]|[1-9]/
stty [device [speed]]
let stty = let device = [ label "device" . store fspath ] in let speed = [ label "speed" . store Rx.integer ] in key_opt_value_line "stty" (device . (space . speed)?)
Subnet specification
let subnet = Rx.ipv4 . "/" . cidr
let switch (n:regexp) = dels "--" . key n
let switch_arg (n:regexp) = switch n . eq . store Rx.no_spaces