1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-06-11 22:31:12 +02:00

cse passes a lookup procedure to the effects analyzer

* module/language/tree-il/cse.scm (cse): Arrange to pass a lookup
  procedure to compute-effects, for better effects analysis.
This commit is contained in:
Andy Wingo 2012-05-15 17:23:06 +02:00
parent 83bd53abb6
commit 63216d80de

View file

@ -177,7 +177,7 @@
(lambda (sym)
(vhash-assq sym table))))
(define compute-effects
(define %compute-effects
(make-effects-analyzer assigned-lexical?))
(define (negate exp ctx)
@ -201,9 +201,6 @@
(make-application #f (make-primitive-ref #f 'not) (list exp)))))
(define (bailout? exp)
(causes-effects? (compute-effects exp) &definite-bailout))
(define (hasher n)
(lambda (x size) (modulo n size)))
@ -338,6 +335,16 @@
(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)))
(let lp ((n 0))
(and (< n env-len)
(match (vlist-ref env n)
((#(exp _ sym* _) . _)
(if (eq? sym sym*)
exp
(lp (1+ n)))))))))
(define (intersection db+ db-)
(vhash-fold-right
(lambda (k h out)
@ -365,6 +372,12 @@
(lp (cdr in) (cons x out) (concat db** db*))))
(values (reverse out) db*))))
(define (compute-effects exp)
(%compute-effects exp (lambda (sym) (lookup-lexical sym env))))
(define (bailout? exp)
(causes-effects? (compute-effects exp) &definite-bailout))
(define (return exp db*)
(let ((effects (compute-effects exp)))
(cond