|
From: | Stefan Israelsson Tampe |
Subject: | bug#12883: [2.0.6] CSE bug |
Date: | Mon, 19 Nov 2012 12:33:17 +0100 |
Hi Stefan,
> + (and (unroll db m niter)
Stefan Israelsson Tampe <address@hidden> skribis:
> --- a/module/language/tree-il/cse.scm
> +++ b/module/language/tree-il/cse.scm
> @@ -324,10 +324,11 @@
> (and (< n env-len)
> (match (vlist-ref env n)
> ((#(exp* name sym db-len*) . h*)
> - (and (unroll db m (- db-len db-len*))
> - (if (and (= h h*) (tree-il=? exp* exp))
> - (make-lexical-ref (tree-il-src exp) name sym)
> - (lp (1+ n) (- db-len db-len*))))))))))))
> + (let ((niter (- (- db-len db-len*) m)))
> + (if (and (= h h*) (tree-il=? exp* exp))I can confirm it solves the problem, but I don’t fully understand what’s
> + (make-lexical-ref (tree-il-src exp) name sym)
> + (lp (1+ n) (- db-len db-len*)))))))))))))
>
> (define (lookup-lexical sym env)
> (let ((env-len (vlist-length env)))
going on here. Could you elaborate? :-)
Also, it would be great if you could send a ‘git format-patch’ kind of
patch, with the original test case (and possibly others) added to
cse.test, along with the URL of this bug, and a proper ChangeLog-style
commit log.
TIA, :-)
Ludo’.
[Prev in Thread] | Current Thread | [Next in Thread] |