File: mularg.scm

package info (click to toggle)
slib 2c0-3
  • links: PTS
  • area: main
  • in suites: hamm
  • size: 1,524 kB
  • ctags: 1,473
  • sloc: lisp: 17,079; makefile: 287; sh: 136
file content (12 lines) | stat: -rw-r--r-- 323 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
;;; "mularg.scm" Redefine - and / to take more than 2 arguments.

(define / /)
(define - -)
(let ((maker
       (lambda (op)
	 (lambda (d1 . ds)
	   (cond ((null? ds) (op d1))
		 ((null? (cdr ds)) (op d1 (car ds)))
		 (else (for-each (lambda (d) (set! d1 (op d1 d))) ds) d1))))))
  (set! / (maker /))
  (set! - (maker -)))