[up] [log] [?]
[first] [prev] [entry] [exit] [next] [last]
(meg/match ~{:close-tag (drop (* "</" (cmt (* (backref :tag-name) (capture :w+)) "<function =>") ">")) :main (* :tagged -1) :open-tag (* (constant :tag) "<" (capture :w+ :tag-name) ">") :tagged (unref (replace (* :open-tag :value :close-tag) "<cfunction struct>")) :untagged (capture (some (if-not "<" 1))) :value (* (constant :value) (group (any (+ :tagged :untagged))))}
           "<p><em>Hello</em> <strong>world</strong>!</p>")
captures and tags
captures: @[:tag "p" :value :tag "em" :value "Hello" :tag]
tagged-captures:
  tags: @[nil :tag-name nil nil :tag-name nil nil nil]
  values: @[:tag "p" :value :tag "em" :value "Hello" :tag]
current frame
status: exiting frame 83 with value: 13
peg: "<"
text: <p><em>Hello</em> <strong>world</strong>!</p>
index: 12 advanced to: 13
matched: <
frames call stack
83 "<"
81 (* (constant :tag) "<" (capture :w+ :tag-name) ">")
80 :open-tag
79 (* :open-tag :value :close-tag)
78 (replace (* :open-tag :value :close-tag) "<cfunction struct>")
77 (unref (replace (* :open-tag :value :close-tag) "<cfunction struct>"))
76 :tagged
75 (+ :tagged :untagged)
45 (any (+ :tagged :untagged))
44 (group (any (+ :tagged :untagged)))
42 (* (constant :value) (group (any (+ :tagged :untagged))))
41 :value
26 (* :open-tag :value :close-tag)
25 (replace (* :open-tag :value :close-tag) "<cfunction struct>")
24 (unref (replace (* :open-tag :value :close-tag) "<cfunction struct>"))
23 :tagged
22 (+ :tagged :untagged)
21 (any (+ :tagged :untagged))
20 (group (any (+ :tagged :untagged)))
18 (* (constant :value) (group (any (+ :tagged :untagged))))
17 :value
4 (* :open-tag :value :close-tag)
3 (replace (* :open-tag :value :close-tag) "<cfunction struct>")
2 (unref (replace (* :open-tag :value :close-tag) "<cfunction struct>"))
1 :tagged
0 (* :tagged -1)