В Clojure я мог бы использовать что-то вроде этого решения: ">Компактный код Clojure для совпадений регулярных выражений и их положения в строке, т.е. создание re-matcher
и извлечение информации из него, но похоже, что re-matcher не реализован в ClojureScript. Что было бы хорошим способом сделать то же самое в ClojureScript?
Изменить:
В итоге я написал дополнительную функцию, чтобы сохранить модификаторы регулярного выражения, поскольку оно поглощается re-pos
:
(defn regex-modifiers
"Returns the modifiers of a regex, concatenated as a string."
[re]
(str (if (.-multiline re) "m")
(if (.-ignoreCase re) "i")))
(defn re-pos
"Returns a vector of vectors, each subvector containing in order:
the position of the match, the matched string, and any groups
extracted from the match."
[re s]
(let [re (js/RegExp. (.-source re) (str "g" (regex-modifiers re)))]
(loop [res []]
(if-let [m (.exec re s)]
(recur (conj res (vec (cons (.-index m) m))))
res))))