Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Fetching contributors…

Cannot retrieve contributors at this time

23 lines (20 sloc) 0.994 kB
;; Copyright (c) Nicola Mometto, Rich Hickey & contributors.
;; The use and distribution terms for this software are covered by the
;; Eclipse Public License 1.0 (http://opensource.org/licenses/eclipse-1.0.php)
;; which can be found in the file epl-v10.html at the root of this distribution.
;; By using this software in any fashion, you are agreeing to be bound by
;; the terms of this license.
;; You must not remove this notice, or any other, from this software.
(ns clojure.tools.analyzer.passes.index-vector-nodes)
(defn index-vector-nodes
"Adds an :idx attribute to nodes in vector children, representing the position
of the node vector."
[ast]
(merge ast
(reduce (fn [m c]
(let [v (c ast)
v (if (vector? v)
(mapv (fn [x i] (assoc x :idx i ))
v (range))
v)]
(assoc m c v))) {} (:children ast))))
Jump to Line
Something went wrong with that request. Please try again.