summaryrefslogtreecommitdiff
path: root/src/clarktown/correctors/fenced_code_block.clj
diff options
context:
space:
mode:
authorAsko Nõmm <ano@ano.ee>2022-05-08 12:23:35 +0300
committerAsko Nõmm <ano@ano.ee>2022-05-08 12:23:35 +0300
commitb97891cc45b9a087a372767e25aa36788bc979bf (patch)
tree0401ef1f090575c36f9e110eaeb50412e3fd4139 /src/clarktown/correctors/fenced_code_block.clj
parentff2279150638b43aab4e65b2578a5dbd348e21d8 (diff)
Naming improvements, code block matcher test
Diffstat (limited to 'src/clarktown/correctors/fenced_code_block.clj')
-rw-r--r--src/clarktown/correctors/fenced_code_block.clj37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/clarktown/correctors/fenced_code_block.clj b/src/clarktown/correctors/fenced_code_block.clj
new file mode 100644
index 0000000..77bc023
--- /dev/null
+++ b/src/clarktown/correctors/fenced_code_block.clj
@@ -0,0 +1,37 @@
+(ns clarktown.correctors.fenced-code-block
+ (:require
+ [clojure.string :as string]))
+
+
+(defn newline-above?
+ "Determines whether there's a need for an empty new line
+ above the `line` at the current `index`. In the case of a
+ code block, which starts with three backticks (```), if there's
+ no empty newline above, we need to create one, and so this
+ function must then return `true`."
+ [lines line index]
+ (and (string/starts-with? (string/trim line) "```")
+ (> index 0)
+ (->> (take index lines)
+ (filter #(string/starts-with? (string/trim %) "```"))
+ count
+ even?)
+ (not (= (-> (nth lines (- index 1))
+ string/trim) ""))))
+
+
+(defn newline-below?
+ "Determines whether there's a need for an empty new line
+ below the `line` at the current `index`. In the case of a
+ code block, which ends with three backticks (```), if there's
+ no empty newline above, we need to create one, and so this
+ function must then return `true`."
+ [lines line index]
+ (and (string/starts-with? (string/trim line) "```")
+ (< index (- (count lines) 1))
+ (->> (take index lines)
+ (filter #(string/starts-with? (string/trim %) "```"))
+ count
+ odd?)
+ (not (= (-> (nth lines (+ index 1))
+ string/trim) ""))))