From fe17200dc305e6b1e1b0e2ea54135e7f04bb4d40 Mon Sep 17 00:00:00 2001 From: Tony Kelman Date: Mon, 22 Aug 2016 09:35:01 -0700 Subject: [PATCH] Revert "Revert "fix #18129, optimize some more cases of captured variables"" This reverts commit d45bcaeb76c2693834520f8f39785903ab85efd3. --- src/julia-syntax.scm | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/julia-syntax.scm b/src/julia-syntax.scm index f762753a5f80f..aaf07bca7d74a 100644 --- a/src/julia-syntax.scm +++ b/src/julia-syntax.scm @@ -2721,25 +2721,27 @@ f(x) = yt(x) (any vinfo:sa vi)) (let* ((leading (filter (lambda (x) (and (pair? x) - (or (and (eq? (car x) 'method) - (length> x 2)) - (eq? (car x) '=)))) + (let ((cx (car x))) + (or (and (eq? cx 'method) (length> x 2)) + (eq? cx '=) + (eq? cx 'call))))) (take-statements-while (lambda (e) (or (atom? e) (memq (car e) '(quote top core line inert local unnecessary meta inbounds boundscheck simdloop implicit-global global globalref - const newvar = null method)))) + const newvar = null method call)))) (lam:body lam)))) - (unused (map cadr leading)) + (unused (map cadr (filter (lambda (x) (memq (car x) '(method =))) + leading))) (def (table))) ;; TODO: reorder leading statements to put assignments where the RHS is ;; `simple-atom?` at the top. (for-each (lambda (e) (set! unused (filter (lambda (v) (not (expr-uses-var e v))) unused)) - (if (memq (cadr e) unused) + (if (and (memq (car e) '(method =)) (memq (cadr e) unused)) (put! def (cadr e) #t))) leading) (for-each (lambda (v)