~ chicken-core (chicken-5) 6a679103a60c60322bdc509ea374bd756703c685
commit 6a679103a60c60322bdc509ea374bd756703c685 Author: felix <felix@call-with-current-continuation.org> AuthorDate: Sat May 15 01:04:44 2010 +0200 Commit: felix <felix@call-with-current-continuation.org> CommitDate: Sat May 15 01:04:44 2010 +0200 fixed incorrect codegen for no-global-procedure-checks that caused hidden vars to be handled incorrectly diff --git a/c-backend.scm b/c-backend.scm index 65bf43b6..6b6c2323 100644 --- a/c-backend.scm +++ b/c-backend.scm @@ -279,8 +279,10 @@ (carg #f)) (gen #t "((C_proc" nf ")") (cond (no-global-procedure-checks - (set! carg - (string-append "*((C_word*)lf[" (number->string index) "]+1)")) + (set! carg + (if block + (string-append "lf[" (number->string index) "]") + (string-append "*((C_word*)lf[" (number->string index) "]+1)"))) (gen "(void*)(*((C_word*)(" carg ")+1))")) (block (set! carg (string-append "lf[" (number->string index) "]")) diff --git a/library.scm b/library.scm index 275582fe..ff0aff8e 100644 --- a/library.scm +++ b/library.scm @@ -2733,7 +2733,7 @@ EOF (##sys#print x #f port) ) (define-inline (*print-each lst) - (for-each (cut ##sys#print <> #f ##sys#standard-output) lst) ) + (for-each (lambda (x) (##sys#print x #f ##sys#standard-output)) lst) ) (define (print . args) (*print-each args)Trap