Files
beluga/lisp-interpreter/stdlib/2_forms.scm
T
Arthur Barraux d8fc7d2d67
Meson Build and Deploy / build (push) Failing after 29s
adding lisp-interpreter
2025-09-24 10:58:09 +02:00

76 lines
2.9 KiB
Scheme

(_shorthand-accessors "AA" "DD" "AD" "DA" "AAA" "AAD" "ADA" "DAA" "ADD" "DAD" "DDA" "DDD")
(define (_and-helper preds)
(cond ((null? preds) #t)
((null? (cdr preds)) (car preds))
(else
`(IF ,(car preds) ,(_and-helper (cdr preds)) #f))))
(define-macro and (lambda preds (_and-helper preds)))
(define (_or-helper preds var)
(cond ((null? preds) #f)
((null? (cdr preds)) (car preds))
(else
`(BEGIN (SET! ,var ,(car preds))
(IF ,var ,var ,(_or-helper (cdr preds) var))))))
(define-macro or (lambda preds
(let ((var (gensym)))
`(LET ((,var '())) ,(_or-helper preds var)))))
(define-macro case (lambda (key . clauses)
(let ((expr (gensym)))
`(LET ((,expr ,key))
,(cons 'COND (map1 (lambda (entry)
(cons (if (pair? (car entry))
`(MEMV ,expr (quote ,(car entry)))
(car entry))
(cdr entry))) clauses))))))
(define-macro push
(lambda (v l)
`(begin (set! ,l (cons ,v ,l)) ,l)))
; (DO ((<var0> <init0> <step0>) ...) (<test> <result>) <body>)
(define-macro do
(lambda (vars loop-check . loops)
(let ( (names '()) (inits '()) (steps '()) (f (gensym)) )
(for-each1 (lambda (var)
(push (car var) names)
(set! var (cdr var))
(push (car var) inits)
(set! var (cdr var))
(push (car var) steps)) vars)
`((LAMBDA ()
(DEFINE ,f (LAMBDA ,names
(IF ,(car loop-check)
,(if (pair? (cdr loop-check)) (car (cdr loop-check)) '())
,(cons 'BEGIN (append loops (list (cons f steps)))) )))
,(cons f inits)
)) )))
(define-macro dotimes
(lambda (form body)
(apply (lambda (i n . result)
`(DO ((,i 0 (+ ,i 1)))
((>= ,i ,n) ,(if (null? result) result (car result)) )
,body)
) form)))
(define-macro swap!
(lambda (x y)
(let ((temp (gensym)))
`(LET ((,temp ,x))
(SET! ,temp ,x)
(SET! ,x ,y)
(SET! ,y ,temp)))))
(define-macro inc! ; CL incf
(lambda (x)
`(SET! ,x (+ ,x 1))))
(define-macro dec! ; CL decf
(lambda (x)
`(SET! ,x (- ,x 1))))