blob: 5f63620c14cca405038535339ddf67de8e085479 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
(ns clarktown.parsers.italic
(:require
[clojure.string :as string]))
(defn render
"Renders all occurring italic text as italic."
[block _]
(loop [block block
matches (-> (re-seq #"(\*{1}|\_{1})(.*?)(\*{1}|\_{1})" block)
distinct)]
(if (empty? matches)
block
(let [match (ffirst matches)
value (subs match 1 (- (count match) 1))
replacement (str "<em>" value "</em>")]
(recur (string/replace block match replacement)
(drop 1 matches))))))
|