From: Tim Vaughan Date: Sat, 29 Apr 2017 02:18:22 +0000 (+1200) Subject: Solved hygiene problem, MCE runs (VERY slowly) X-Git-Url: https://thelambdalab.xyz/gitweb/index.cgi?p=scheme.forth.jl.git;a=commitdiff_plain;h=840b141d1ea220f15fc5f46b889ab37e24ebf0c9 Solved hygiene problem, MCE runs (VERY slowly) --- diff --git a/examples/metacirc.scm b/examples/metacirc.scm index d63e685..f28367b 100644 --- a/examples/metacirc.scm +++ b/examples/metacirc.scm @@ -329,6 +329,7 @@ (define-variable! 'false false initial-env) initial-env)) + (define (primitive-procedure? proc) (tagged-list? proc 'primitive)) @@ -352,8 +353,6 @@ (list 'primitive (cadr proc))) primitive-procedures)) - - (define (apply-primitive-procedure proc args) (apply-in-underlying-scheme (primitive-implementation proc) args)) @@ -390,4 +389,6 @@ ')) (display object))) -;; (define the-global-environment (setup-environment)) + +(define the-global-environment (setup-environment)) + diff --git a/src/scheme-library.scm b/src/scheme-library.scm index 73e8a4e..2c6146e 100644 --- a/src/scheme-library.scm +++ b/src/scheme-library.scm @@ -12,8 +12,14 @@ (define (cadr l) (car (cdr l))) (define (cdar l) (cdr (car l))) (define (cddr l) (cdr (cdr l))) +(define (caaar l) (car (car (car l)))) +(define (caadr l) (car (car (cdr l)))) (define (cadar l) (car (cdr (car l)))) (define (caddr l) (car (cdr (cdr l)))) +(define (cdaar l) (cdr (car (car l)))) +(define (cdadr l) (cdr (car (cdr l)))) +(define (cddar l) (cdr (cdr (car l)))) +(define (cdddr l) (cdr (cdr (cdr l)))) (define (cadddr l) (car (cdr (cdr (cdr l))))) ;; FUNCTIONAL PROGRAMMING @@ -203,6 +209,10 @@ (define (integer? x) (= x (round x))) (define (exact? x) (fixnum? x)) (define (inexact? x) (flonum? x)) +(define (number? x) + (if (fixnum? x) #t + (if (flonum? x) #t + (if (ratnum? x) #t #f)))) ;; LISTS @@ -255,61 +265,66 @@ ; cond -(define (cond-predicate clause) (car clause)) -(define (cond-actions clause) (cdr clause)) -(define (cond-else-clause? clause) - (eq? (cond-predicate clause) 'else)) - -(define (expand-clauses clauses) - (display "Expanding cond clauses...") - (if (null? clauses) - (none) - (let ((first (car clauses)) - (rest (cdr clauses))) - (if (cond-else-clause? first) - (if (null? rest) - `(begin ,@(cond-actions first)) - (error "else clause isn't last in cond expression.")) - `(if ,(cond-predicate first) - (begin ,@(cond-actions first)) - ,(expand-clauses rest)))))) - -(define-macro (cond . clauses) - (if (null? clauses) - (error "cond requires at least one clause.") - (expand-clauses clauses))) +((lambda () + (define (cond-predicate clause) (car clause)) + (define (cond-actions clause) (cdr clause)) + (define (cond-else-clause? clause) + (eq? (cond-predicate clause) 'else)) + + (define (expand-clauses clauses) + (if (null? clauses) + (none) + (let ((first (car clauses)) + (rest (cdr clauses))) + (if (cond-else-clause? first) + (if (null? rest) + `(begin ,@(cond-actions first)) + (error "else clause isn't last in cond expression.")) + `(if ,(cond-predicate first) + (begin ,@(cond-actions first)) + ,(expand-clauses rest)))))) + + (define-macro (cond . clauses) + (if (null? clauses) + (error "cond requires at least one clause.") + (expand-clauses clauses))) + )) ; and -(define (expand-and-expressions expressions) - (let ((first (car expressions)) - (rest (cdr expressions))) - (if (null? rest) - first - `(if ,first - ,(expand-and-expressions rest) - #f)))) - -(define-macro (and . expressions) - (if (null? expressions) - #t - (expand-and-expressions expressions))) +((lambda () + (define (expand-and-expressions expressions) + (let ((first (car expressions)) + (rest (cdr expressions))) + (if (null? rest) + first + `(if ,first + ,(expand-and-expressions rest) + #f)))) + + (define-macro (and . expressions) + (if (null? expressions) + #t + (expand-and-expressions expressions))) + )) ; or -(define (expand-or-expressions expressions) - (if (null? expressions) - #f - (let ((first (car expressions)) - (rest (cdr expressions)) - (val (gensym))) - `(let ((,val ,first)) - (if ,val - ,val - ,(expand-or-expressions rest)))))) - -(define-macro (or . expressions) - (expand-or-expressions expressions)) +((lambda () + (define (expand-or-expressions expressions) + (if (null? expressions) + #f + (let ((first (car expressions)) + (rest (cdr expressions)) + (val (gensym))) + `(let ((,val ,first)) + (if ,val + ,val + ,(expand-or-expressions rest)))))) + + (define-macro (or . expressions) + (expand-or-expressions expressions)) + )) ;; TESTING diff --git a/src/scheme.4th b/src/scheme.4th index 63f8ace..2ce481c 100644 --- a/src/scheme.4th +++ b/src/scheme.4th @@ -1968,7 +1968,7 @@ variable gc-stack-depth ; :noname - ." GC! " + \ ." GC! " gc-unmark