summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAsko Nõmm <84135165+askonomm@users.noreply.github.com>2022-05-01 19:53:46 +0300
committerGitHub <noreply@github.com>2022-05-01 19:53:46 +0300
commitff2279150638b43aab4e65b2578a5dbd348e21d8 (patch)
tree95439aa35bad656b36beede18a0ae424e2ce516b /src
parente8cb3717a66bf2bf3e5be815ad2c5311311c969e (diff)
parent64fe2ecd153e6414cf33fc887604a31ee36e7952 (diff)
Merge pull request #28 from askonomm/27-implement-list-block-newline-correctors
Implement newline corrector for list block.
Diffstat (limited to 'src')
-rw-r--r--src/clarktown/correctors.clj9
-rw-r--r--src/clarktown/correctors/list_block.clj36
2 files changed, 42 insertions, 3 deletions
diff --git a/src/clarktown/correctors.clj b/src/clarktown/correctors.clj
index e251595..1a61f2d 100644
--- a/src/clarktown/correctors.clj
+++ b/src/clarktown/correctors.clj
@@ -1,7 +1,8 @@
(ns clarktown.correctors
(:require
[clarktown.correctors.code-block :as code-block]
- [clarktown.correctors.atx-heading-block :as atx-heading-block]))
+ [clarktown.correctors.atx-heading-block :as atx-heading-block]
+ [clarktown.correctors.list-block :as list-block]))
(def
@@ -9,10 +10,12 @@
default-block-separation-correctors
{:newline-above
[code-block/empty-line-above?
- atx-heading-block/empty-line-above?]
+ atx-heading-block/empty-line-above?
+ list-block/empty-line-above?]
:newline-below
[code-block/empty-line-below?
- atx-heading-block/empty-line-below?]})
+ atx-heading-block/empty-line-below?
+ list-block/empty-line-below?]})
(def
diff --git a/src/clarktown/correctors/list_block.clj b/src/clarktown/correctors/list_block.clj
new file mode 100644
index 0000000..cf84bb1
--- /dev/null
+++ b/src/clarktown/correctors/list_block.clj
@@ -0,0 +1,36 @@
+(ns clarktown.correctors.list-block
+ (:require
+ [clojure.string :as string]
+ [clarktown.matchers.list-block :as matcher]))
+
+
+(defn empty-line-above?
+ "Determines whether there's a need for an empty new line
+ above the `line` at the current `index`. In the list block
+ case that's when the above line is not a newline and is not
+ a list block line."
+ [lines line index]
+ (and (matcher/match? line)
+ (> index 0)
+ (nil? (-> (nth lines (- index 1))
+ string/trim
+ matcher/match?))
+ (not (= (-> (nth lines (- index 1))
+ string/trim)
+ ""))))
+
+
+(defn empty-line-below?
+ "Determines whether there's a need for an empty new line
+ above the `line` at the current `index`. In the list block
+ case that's when the below line is not a newline and is not
+ a list block line."
+ [lines line index]
+ (and (matcher/match? line)
+ (> (- (count lines) 1) index)
+ (nil? (-> (nth lines (+ index 1))
+ string/trim
+ matcher/match?))
+ (not (= (-> (nth lines (+ index 1))
+ string/trim)
+ ""))))