Did you try wrapping everything w/ a call to lazy-seq?

On Jan 15, 3:21 pm, Nicolas Buduroi <nbudu...@gmail.com> wrote:
> Hi, I'm still not familiar with laziness and I'm trying to make a
> function recursively walk arbitrary data structures to perform some
> action on all strings. The non-lazy version is quite easy to do:
>
> (use
>   'clojure.walk
>   'clojure.contrib.str-utils)
>
> (defn recursive-string-walk [f form]
>   (walk #(if (string? %) (f %) (recursive-string-walk f %))
>     identity form))
>
> But it blow up the stack quite rapidly, I've tried to inject some
> laziness inside, but only came up with a slight improvement. It can
> take forms that are a little more than two time as deep.
>
> (defn recursive-string-walk [f form]
>   (walk #(cond
>            (string? %) (f %)
>            (seq? %)    (lazy-seq (recursive-string-walk f %))
>            :default    (recursive-string-walk f %))
>     identity form))
>
> Is there a way too make a fully lazy version of this function?
>
> Thanks
>
> - budu
-- 
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to clojure@googlegroups.com
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
clojure+unsubscr...@googlegroups.com
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en

Reply via email to