summaryrefslogtreecommitdiff
path: root/src/clarktown/renderers/italic.clj
blob: 970364ee8ac2bd956be41177e1ad405fa5863edf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
(ns clarktown.renderers.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))))))