devout: recognise attr,attrs when parsing search term string
This commit is contained in:
parent
37d7e20582
commit
f091bbd706
@ -1,4 +1,4 @@
|
|||||||
(local { : dirname } (require :anoia))
|
(local { : dirname : merge } (require :anoia))
|
||||||
(local ll (require :lualinux))
|
(local ll (require :lualinux))
|
||||||
(local {
|
(local {
|
||||||
: AF_LOCAL
|
: AF_LOCAL
|
||||||
@ -101,7 +101,7 @@
|
|||||||
(fn database [options]
|
(fn database [options]
|
||||||
(let [db {}
|
(let [db {}
|
||||||
subscribers []
|
subscribers []
|
||||||
{ : sys-path } (or options {:sysfs-path "/sys" })]
|
{ : sys-path } (or options {:sys-path "/sys" })]
|
||||||
{
|
{
|
||||||
:find (fn [_ terms] (find-in-database db terms))
|
:find (fn [_ terms] (find-in-database db terms))
|
||||||
:add (fn [_ event-string]
|
:add (fn [_ event-string]
|
||||||
@ -147,8 +147,16 @@
|
|||||||
(values fd (if (> revent 0) revent nil)))))
|
(values fd (if (> revent 0) revent nil)))))
|
||||||
|
|
||||||
(fn parse-terms [str]
|
(fn parse-terms [str]
|
||||||
(collect [n (string.gmatch (str:gsub "\n+$" "") "([^ ]+)")]
|
(let [keys {}
|
||||||
(string.match n "(.-)=(.+)")))
|
attr {}
|
||||||
|
attrs {}]
|
||||||
|
(each [term (string.gmatch (str:gsub "\n+$" "") "([^ ]+)")]
|
||||||
|
(let [(k v) (string.match term "(.-)=(.+)")]
|
||||||
|
(match (string.match k "(.+)%.(.+)")
|
||||||
|
("attrs" a) (tset attrs a v)
|
||||||
|
("attr" a) (tset attr a v)
|
||||||
|
nil (tset keys k v))))
|
||||||
|
(merge keys {: attr : attrs})))
|
||||||
|
|
||||||
(fn handle-client [db client]
|
(fn handle-client [db client]
|
||||||
(match (ll.read client)
|
(match (ll.read client)
|
||||||
@ -208,4 +216,7 @@
|
|||||||
(ll.poll pollfds 5000)
|
(ll.poll pollfds 5000)
|
||||||
(loop:feed (unpack-pollfds pollfds))))))
|
(loop:feed (unpack-pollfds pollfds))))))
|
||||||
|
|
||||||
{ : database : run : event-loop : parse-event }
|
{ : database : run : event-loop : parse-event
|
||||||
|
|
||||||
|
: parse-terms
|
||||||
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
(local { : database : event-loop : parse-event : sysfs } (require :devout))
|
(local { : database : event-loop : parse-event : parse-terms } (require :devout))
|
||||||
(local { : view } (require :fennel))
|
(local { : view } (require :fennel))
|
||||||
(local ll (require :lualinux))
|
(local ll (require :lualinux))
|
||||||
(import-macros { : expect : expect= } :anoia.assert)
|
(import-macros { : expect : expect= } :anoia.assert)
|
||||||
@ -246,4 +246,11 @@ MINOR=17")
|
|||||||
))
|
))
|
||||||
|
|
||||||
|
|
||||||
|
(example
|
||||||
|
"parse terms from string"
|
||||||
|
(expect= (parse-terms "foo=bar baz=quuz")
|
||||||
|
{:foo "bar" :baz "quuz" :attr {} :attrs {}})
|
||||||
|
(expect= (parse-terms "foo=bar attr.womble=0x1234")
|
||||||
|
{:foo "bar" :attr {:womble "0x1234"} :attrs {}}))
|
||||||
|
|
||||||
(if failed (os.exit 1) (print "OK"))
|
(if failed (os.exit 1) (print "OK"))
|
||||||
|
Loading…
Reference in New Issue
Block a user