shithub: sl

Download patch

ref: bb46003e44b4d2a7009f1888771c499a6e660054
parent: c8ff8d599f84e0209ed0c37e92b6e05f1d06995f
author: Sigrid Solveig Haflínudóttir <sigrid@ftrv.se>
date: Sat Mar 8 15:58:09 EST 2025

system, compiler: use "when" more, clean up "begin", fix indentation

--- a/boot/sl.boot
+++ b/boot/sl.boot
@@ -44,8 +44,8 @@
   #fn("n2120C5020:1J40q:1R3=021072151e3:1H3=023072151e3:1=J>0230721<51e3:74751523=0260271e2e3:280271e2e3:" #(else
   eq? quote-value eqv? every symbol? memq quote memv) vals->cond)
   #fn(gensym) let #fn(nconc) cond #fn(map) #fn("n1A<F0<520=P:" #())))  receive #fn("z22021q1e32221e10e123825153e3:" #(call-with-values
-  λ #fn(nconc) #fn(copy-list)))  unwind-protect #fn("n2202122q1e3e2e1232402225e12621e12725e2e3e3e321e1e3e3:" #(let
-  #:g350 λ prog1 trycatch #:g351 begin raise))  dotimes #fn("z10<0T20E2187Ke32223e186e1e12415153e4:" #(for
+  λ #fn(nconc) #fn(copy-list)))  unwind-protect #fn("n2202122q1e3e2e1232402225e121e12625e2e4e321e1e3e3:" #(let
+  #:g350 λ prog1 trycatch #:g351 raise))  dotimes #fn("z10<0T20E2187Ke32223e186e1e12415153e4:" #(for
   - #fn(nconc) λ #fn(copy-list)))  throw #fn("n220212223e201e4e2:" #(raise list quote thrown-value)))
 	    1+ #fn("n10KM:" #() 1+) 1-
 	    #fn("n10K~:" #() 1-) 1arg-lambda? #fn("n10B;3E04700<51;3:04710TK62:" #(is-lambda?
@@ -149,7 +149,7 @@
 	    compile-or #fn("n470018283q21q67:" #(compile-short-circuit brnn) compile-or)
 	    compile-prog1 #fn("n37001q82T544718251B3_00r40r4GKMp47201q718251544730245240r40r4Gr/Mp:q:" #(compile-in
   cddr compile-begin emit pop) compile-prog1)
-	    compile-set! #fn("n470821E538821CF07201q83544730248263:88<El288=T893<07588=51@9076082528:3o07308937027@40288;5340r40r4GKMp47201q835440r40r4Gr/Mp47302962:7201q8354489JA07:2;2<825251@30q47302=8;63:" #(lookup-sym
+	    compile-set! #fn("n470821E538821CF07201q83544730248263:88<El288=T893<07588=51@9076082528:3o07308937027@40288;5340r40r4GKMp47201q835440r40r4Gr/Mp47302962:7201q8354489360q@>07:2;2<82525147302=8;63:" #(lookup-sym
   global compile-in emit setg vinfo:index capture-var! loada loadc set-car! error #fn(string)
   "internal error: misallocated var " seta) compile-set!)
 	    compile-short-circuit #fn("n783H3?0700182848665:83=H3@070018283<8665:86;J70421507001q83<865540r40r4GKMp486360q@9072023524720858;5340r40r4Gr/Mp486360q@907202452475018283=84858657486340q:720268;63:" #(compile-in
@@ -306,9 +306,9 @@
   #fn(io-write) *linefeed* #fn(io-close))) #fn("n1A50420061:" #(#fn(raise)))) make-system-image)
 	    map! #fn("n21I1B3B04101<51_41=?1@\x1d/4:" #() map!) map-int
 	    #fn("n2701E52340q:0E51qPqb78786_4K7115122870>2|486:" #(<= 1- #fn("n1A<F051qPN4AA<=_:" #())) map-int)
-	    max #fn("z11J400:70210163:" #(foldl #fn("n201L23401:0:" #())) max) member
+	    max #fn("z113;070210163:0:" #(foldl #fn("n201L23401:0:" #())) max) member
 	    #fn("n21<0d3401:13:07001=62:q:" #(member) member) memv #fn("n21<0c3401:13:07001=62:q:" #(memv) memv)
-	    min #fn("z11J400:70210163:" #(foldl #fn("n201L23400:1:" #())) min) mod
+	    min #fn("z113;070210163:0:" #(foldl #fn("n201L23400:1:" #())) min) mod
 	    #fn("n207001521i2~:" #(div) mod) mod0 #fn("n2001k1i2~:" #() mod0) negative?
 	    #fn("n10EL2:" #() negative?) nestlist #fn("n37082E52340q:1710015182K~53P:" #(<=
   nestlist) nestlist)
@@ -416,10 +416,10 @@
 										  *stderr* #fn("n0Aw0:" #(*output-stream*))
 										  #fn("n070A51471225061:" #(print-exception
   print-stack-trace #fn(stacktrace))) #fn("n1A50420061:" #(#fn(raise)))) top-level-exception-handler)
-	    trace #fn("n120051718551Jg0220732425262728290e225e3e22:e12;2985e225e3e4e35152@30q^147<60:" #(#fn(top-level-value)
-  traced? #fn(set-top-level-value!) eval λ #:g352 begin write cons quote newline apply void) trace)
-	    traced? #fn("n170051;3?042105121A<51d:" #(closure? #fn(function:code)) #((#fn("z020210P51472504230}2:" #(#fn(write)
-  x newline #.apply)))))
+	    trace #fn("n120051718551Jc02207324252627280e225e3e229e12:2885e225e3e55152@30q^147;60:" #(#fn(top-level-value)
+  traced? #fn(set-top-level-value!) eval λ #:g352 write cons quote newline apply void) trace)
+	    traced? #fn("n170051;3>042105121A51d:" #(closure? #fn(function:code)) #(#fn("z020210P51472504230}2:" #(#fn(write)
+  x newline #.apply))))
 	    untrace #fn("n1200517185513C0220238551r3G52@30q^147460:" #(#fn(top-level-value) traced?
 								       #fn(set-top-level-value!)
 								       #fn(function:vals) void) untrace)
--- a/src/compiler.lsp
+++ b/src/compiler.lsp
@@ -31,18 +31,17 @@
                   (else
                    (aset! e 0 (cons inst bc)))))
         (begin
-          (if (memq inst '(loadv loadg setg))
-              (set! args (list (bcode:indexfor e (car args)))))
+          (when (memq inst '(loadv loadg setg))
+            (set! args (list (bcode:indexfor e (car args)))))
           (let ((longform
                  (assq inst '((loadv loadv.l) (loadg loadg.l) (setg setg.l)
                               (loada loada.l) (seta  seta.l)  (box  box.l)))))
-            (if (and longform
-                     (> (car args) 255))
-                (set! inst (cadr longform))))
+            (when (and longform (> (car args) 255))
+              (set! inst (cadr longform))))
           (let ((longform
                  (assq inst '((loadc loadc.l)))))
-            (if (and longform (> (car  args) 255))
-                (set! inst (cadr longform))))
+            (when (and longform (> (car  args) 255))
+              (set! inst (cadr longform))))
           (if (eq? inst 'loada)
               (cond ((equal? args '(0))
                      (set! inst 'loada0)
@@ -90,59 +89,57 @@
           (vi             nil)
           (nxt            nil))
       (while (< i n)
-        (begin
-          (set! vi (aref v i))
-          (if (eq? vi 'label)
-              (begin (put! label-to-loc (aref v (+ i 1)) (sizeof bcode))
-                     (set! i (+ i 2)))
-              (begin
-                (io-write bcode
-                          (get Instructions
-                               (if long?
-                                   (case vi
-                                     (jmp  'jmp.l)
-                                     (brne 'brne.l)
-                                     (brnn 'brnn.l)
-                                     (brn  'brn.l)
-                                     (else vi))
-                                   vi)))
-                (set! i (+ i 1))
-                (set! nxt (and (< i n) (aref v i)))
-                (cond ((memq vi '(jmp brne brnn brn))
-                       (put! fixup-to-label (sizeof bcode) nxt)
-                       (io-write bcode ((if long? s32 s16) 0))
-                       (set! i (+ i 1)))
-                      ((eq? vi 'brbound)
-                       (io-write bcode (s32 nxt))
-                       (set! i (+ i 1)))
-                      ((number? nxt)
-                       (case vi
-                         ((loadv.l loadg.l setg.l loada.l seta.l
-                           argc.l vargc.l call.l tcall.l loadc.l box.l)
-                          (io-write bcode (s32 nxt))
-                          (set! i (+ i 1)))
+        (set! vi (aref v i))
+        (if (eq? vi 'label)
+            (begin (put! label-to-loc (aref v (+ i 1)) (sizeof bcode))
+                   (set! i (+ i 2)))
+            (begin
+              (io-write bcode
+                        (get Instructions
+                             (if long?
+                                 (case vi
+                                   (jmp  'jmp.l)
+                                   (brne 'brne.l)
+                                   (brnn 'brnn.l)
+                                   (brn  'brn.l)
+                                   (else vi))
+                                 vi)))
+              (set! i (+ i 1))
+              (set! nxt (and (< i n) (aref v i)))
+              (cond ((memq vi '(jmp brne brnn brn))
+                     (put! fixup-to-label (sizeof bcode) nxt)
+                     (io-write bcode ((if long? s32 s16) 0))
+                     (set! i (+ i 1)))
+                    ((eq? vi 'brbound)
+                     (io-write bcode (s32 nxt))
+                     (set! i (+ i 1)))
+                    ((number? nxt)
+                     (case vi
+                       ((loadv.l loadg.l setg.l loada.l seta.l
+                         argc.l vargc.l call.l tcall.l loadc.l box.l)
+                        (io-write bcode (s32 nxt))
+                        (set! i (+ i 1)))
 
-                         ((optargs keyargs)  ; 2 s32 args
-                          (io-write bcode (s32 nxt))
-                          (set! i (+ i 1))
+                       ((optargs keyargs)  ; 2 s32 args
+                        (io-write bcode (s32 nxt))
+                        (set! i (+ i 1))
+                        (io-write bcode (s32 (aref v i)))
+                        (set! i (+ i 1))
+                        (when (eq? vi 'keyargs)
                           (io-write bcode (s32 (aref v i)))
-                          (set! i (+ i 1))
-                          (if (eq? vi 'keyargs)
-                              (begin (io-write bcode (s32 (aref v i)))
-                                     (set! i (+ i 1)))))
+                                   (set! i (+ i 1))))
 
-                         (else
-                          ; other number arguments are always u8
-                          (io-write bcode (u8 nxt))
-                          (set! i (+ i 1)))))
-                      (else nil))))))
+                       (else
+                        ; other number arguments are always u8
+                        (io-write bcode (u8 nxt))
+                        (set! i (+ i 1)))))
+                    (else nil)))))
 
       (for-each
        (λ (addr labl)
-         (begin (io-seek bcode addr)
-                (io-write bcode ((if long? s32 s16)
-                                 (- (get label-to-loc labl)
-                                    addr)))))
+         (io-seek bcode addr)
+         (io-write bcode ((if long? s32 s16)
+                          (- (get label-to-loc labl) addr))))
        fixup-to-label)
       (iostream->string bcode))))
 
@@ -203,13 +200,13 @@
 
           ((= (car loc) 0)
            (emit g 'loada (vinfo:index (cdr loc)))
-           (if (and deref (vinfo:heap? (cdr loc)))
-               (emit g 'car)))
+           (when (and deref (vinfo:heap? (cdr loc)))
+             (emit g 'car)))
 
           (else
            (emit g 'loadc (capture-var! g s))
-           (if (and deref (vinfo:heap? (cdr loc)))
-               (emit g 'car))))))
+           (when (and deref (vinfo:heap? (cdr loc)))
+             (emit g 'car))))))
 
 (def (compile-aset! g env args)
   (let ((nref (- (length args) 2)))
@@ -240,15 +237,15 @@
                        (emit g 'set-car!))
 
                 (begin (compile-in g env nil rhs)
-                       (if (not arg?) (error (string "internal error: misallocated var " s)))
+                       (unless arg? (error (string "internal error: misallocated var " s)))
                        (emit g 'seta idx))))))))
 
 (def (box-vars g env)
   (let loop ((e env))
-    (if (cons? e)
-    (begin (if (cadr (car e))
-               (emit g 'box (caddr (car e))))
-               (loop (cdr e))))))
+    (when (cons? e)
+      (if (cadr (car e))
+          (emit g 'box (caddr (car e))))
+          (loop (cdr e)))))
 
 ;; control flow
 
@@ -288,11 +285,11 @@
 
 (def (compile-prog1 g env x)
   (compile-in g env nil (cadr x))
-  (if (cons? (cddr x))
-      (begin (bcode:stack g 1)
-             (compile-begin g env nil (cddr x))
-             (emit g 'pop)
-             (bcode:stack g -1))))
+  (when (cons? (cddr x))
+    (bcode:stack g 1)
+    (compile-begin g env nil (cddr x))
+    (emit g 'pop)
+    (bcode:stack g -1)))
 
 (def (compile-while g env cond body)
   (let ((top  (make-label g))
@@ -374,9 +371,8 @@
         (argc-error b 1)
         (emit g b nargs)))
   (let ((count (get arg-counts b nil)))
-    (if (and count
-             (not (length= (cdr x) count)))
-        (argc-error b count))
+    (when (and count (not (length= (cdr x) count)))
+      (argc-error b count))
     (case b  ; handle special cases of vararg builtins
       (list (if (= nargs 0)
                 (emit g 'loadnil)
@@ -431,8 +427,8 @@
                      (cdr env))))
           (compile-in g newenv tail? (caddr lam))
           (bcode:stack g (- n))
-          (if (and (> n 0) (not tail?))
-              (emit g 'shift n)))))))
+          (when (and (> n 0) (not tail?))
+            (emit g 'shift n)))))))
 
 (def (compile-app g env tail? x)
   (let ((head (car x)))
@@ -501,12 +497,11 @@
            (prog1    (compile-prog1 g env x))
            (λ        (receive (the-f cenv) (compile-f- env x)
                        (begin (emit g 'loadv the-f)
-                              (if cenv
-                                  (begin
-                                    (for-each (λ (var)
-                                                (compile-sym g env var nil))
-                                              cenv)
-                                    (emit g 'closure (length cenv)))))))
+                              (when cenv
+                                (for-each (λ (var)
+                                            (compile-sym g env var nil))
+                                          cenv)
+                                (emit g 'closure (length cenv))))))
            (and      (compile-and g env tail? (cdr x) outl))
            (or       (compile-or  g env tail? (cdr x)))
            (while    (compile-while g env (cadr x) (cons 'begin (cddr x))))
@@ -572,15 +567,15 @@
 
 (def (emit-optional-arg-inits g env opta vars i)
   ; i is the lexical var index of the opt arg to process next
-  (if (cons? opta)
-      (let ((nxt (make-label g)))
-        (emit g 'brbound i)
-        (emit g 'brnn nxt)
-        (compile-in g (extend-env env (list-head vars i) '()) nil (cadar opta))
-        (emit g 'seta i)
-        (emit g 'pop)
-        (mark-label g nxt)
-        (emit-optional-arg-inits g env (cdr opta) vars (+ i 1)))))
+  (when (cons? opta)
+    (let ((nxt (make-label g)))
+      (emit g 'brbound i)
+      (emit g 'brnn nxt)
+      (compile-in g (extend-env env (list-head vars i) '()) nil (cadar opta))
+      (emit g 'seta i)
+      (emit g 'pop)
+      (mark-label g nxt)
+      (emit-optional-arg-inits g env (cdr opta) vars (+ i 1)))))
 
 ;; define
 
@@ -651,13 +646,13 @@
 (def (complex-bindings- e vars head nested capt setd)
   (cond ((not vars) nil)
         ((symbol? e)
-         (if (and nested (memq e vars))
-             (put! capt e t)))
+         (when (and nested (memq e vars))
+           (put! capt e t)))
         ((or (atom? e) (quoted? e)) nil)
         ((eq? (car e) 'set!)
-         (if (memq (cadr e) vars)
-             (begin (put! setd (cadr e) t)
-                    (if nested (put! capt (cadr e) t))))
+         (when (memq (cadr e) vars)
+           (put! setd (cadr e) t)
+           (if nested (put! capt (cadr e) t)))
          (complex-bindings- (caddr e) vars nil nested capt setd))
         ((is-lambda? (car e))
          (complex-bindings- (lambda:body e)
@@ -782,7 +777,7 @@
                                         (or z (and (= v (aref code i))
                                                    k)))
                                       nil Instructions)))
-               (if (> i 0) (newline))
+               (when (> i 0) (newline))
                (dotimes (xx lev) (princ "\t"))
                (set! i (+ i 1))
                (case inst
@@ -813,11 +808,10 @@
                   (set! i (+ i 4))
                   (princ (number->string (ref-s32-LE code i)))
                   (set! i (+ i 4))
-                  (if (eq? inst 'keyargs)
-                      (begin
-                        (princ " ")
-                        (princ (number->string (ref-s32-LE code i)) " ")
-                        (set! i (+ i 4)))))
+                  (when (eq? inst 'keyargs)
+                    (princ " ")
+                    (princ (number->string (ref-s32-LE code i)) " ")
+                    (set! i (+ i 4))))
 
                  ((brbound)
                   (print-inst inst i 4)
--- a/src/system.lsp
+++ b/src/system.lsp
@@ -46,10 +46,11 @@
       (set! body (cdr body)))
     (let ((thelambda
            `(λ ,(map (λ (c) (if (cons? c) (car c) c))
-                          binds)
+                     binds)
               ,@body))
           (theargs
-           (map (λ (c) (if (cons? c) (cadr c) (void))) binds)))
+           (map (λ (c) (if (cons? c) (cadr c) (void)))
+                binds)))
       (cons (if lname
                 `(letrec ((,lname ,thelambda)) ,lname)
                 thelambda)
@@ -76,7 +77,8 @@
                           ; test => (λ (x) ...)
                           (let ((var (caadr (caddr clause))))
                             `(let ((,var ,(car clause)))
-                               (if ,var ,(cons 'begin (cddr (caddr clause)))
+                               (if ,var
+                                   ,(cons 'begin (cddr (caddr clause)))
                                    ,(cond-clauses->if (cdr lst)))))
                           ; test => proc
                           `(let ((b# ,(car clause)))
@@ -200,38 +202,79 @@
   "Return T if not all arguments are equal. Shorthand for (not (= …))."
   `(not (= ,a ,@rest)))
 
-(def (negative? x) (< x 0))
-(def (zero? x)     (= x 0))
-(def (positive? x) (> x 0))
-(def (even? x) (= (logand x 1) 0))
-(def (odd? x) (not (even? x)))
-(def (identity x) x)
-(def (1+ n) (+ n 1))
-(def (1- n) (- n 1))
-(def (mod0 x y) (- x (* (div0 x y) y)))
-(def (div x y) (+ (div0 x y)
-                     (or (and (< x 0)
-                              (or (and (< y 0) 1)
-                                  -1))
-                         0)))
-(def (mod x y) (- x (* (div x y) y)))
+(def (negative? x)
+  (< x 0))
+
+(def (zero? x)
+  (= x 0))
+
+(def (positive? x)
+  (> x 0))
+
+(def (even? x)
+  (= (logand x 1) 0))
+
+(def (odd? x)
+  (not (even? x)))
+
+(def (identity x)
+  x)
+
+(def (1+ n)
+  (+ n 1))
+
+(def (1- n)
+  (- n 1))
+
+(def (div x y)
+  (+ (div0 x y)
+     (or (and (< x 0)
+              (or (and (< y 0) 1)
+                  -1))
+         0)))
+
+(def (mod0 x y)
+  (- x (* (div0 x y) y)))
+
+(def (mod x y)
+  (- x (* (div x y) y)))
+
 (def (random n)
   (if (integer? n)
       (mod (rand) n)
       (* (rand-double) n)))
-(def (abs x)   (if (< x 0) (- x) x))
+
+(def (abs x)
+  (if (< x 0)
+      (- x)
+      x))
+
 (def (max x0 . xs)
-  (if (not xs) x0
-      (foldl (λ (a b) (if (< a b) b a)) x0 xs)))
+  (if xs
+      (foldl (λ (a b) (if (< a b) b a))
+             x0
+             xs)
+      x0))
+
 (def (min x0 . xs)
-  (if (not xs) x0
-      (foldl (λ (a b) (if (< a b) a b)) x0 xs)))
-(def (char? x) (eq? (typeof x) 'rune))
-(def (array? x) (or (vector? x)
-                       (let ((tx (typeof x)))
-                         (and (cons? tx) (eq? (car tx) 'array)))))
-(def (closure? x) (and (function? x) (not (builtin? x))))
+  (if xs
+      (foldl (λ (a b) (if (< a b) a b))
+             x0
+             xs)
+      x0))
 
+(def (char? x)
+  (eq? (typeof x) 'rune))
+
+(def (array? x)
+  (or (vector? x)
+      (let ((tx (typeof x)))
+        (and (cons? tx) (eq? (car tx) 'array)))))
+
+(def (closure? x)
+  (and (function? x)
+       (not (builtin? x))))
+
 (def (caar x) (car (car x)))
 (def (cdar x) (cdr (car x)))
 (def (cddr x) (cdr (cdr x)))
@@ -288,11 +331,13 @@
 (def (list? a) (or (not a) (and (cons? a) (list? (cdr a)))))
 
 (def (list-tail lst n)
-  (if (<= n 0) lst
+  (if (<= n 0)
+      lst
       (list-tail (cdr lst) (- n 1))))
 
 (def (list-head lst n)
-  (if (<= n 0) ()
+  (if (<= n 0)
+      ()
       (cons (car lst)
             (list-head (cdr lst) (- n 1)))))
 
@@ -369,22 +414,27 @@
   (count- f l 0))
 
 (def (nestlist f zero n)
-  (if (<= n 0) ()
+  (if (<= n 0)
+      ()
       (cons zero (nestlist f (f zero) (- n 1)))))
 
 (def (foldr f zero lst)
-  (if (not lst) zero
+  (if (not lst)
+      zero
       (f (car lst) (foldr f zero (cdr lst)))))
 
 (def (foldl f zero lst)
-  (if (not lst) zero
+  (if (not lst)
+      zero
       (foldl f (f (car lst) zero) (cdr lst))))
 
 (def (reverse- zero lst)
-  (if (not lst) zero
+  (if (not lst)
+      zero
       (reverse- (cons (car lst) zero) (cdr lst))))
 
-(def (reverse lst) (reverse- () lst))
+(def (reverse lst)
+  (reverse- () lst))
 
 (def (reverse!- prev l)
   (while (cons? l)
@@ -393,12 +443,14 @@
                                       (set! prev l))))))
   prev)
 
-(def (reverse! l) (reverse!- () l))
+(def (reverse! l)
+  (reverse!- () l))
 
 (def (copy-tree l)
-  (if (atom? l) l
-    (cons (copy-tree (car l))
-          (copy-tree (cdr l)))))
+  (if (atom? l)
+      l
+      (cons (copy-tree (car l))
+            (copy-tree (cdr l)))))
 
 (def (delete-duplicates lst)
   (if (length> lst 20)
@@ -520,7 +572,8 @@
       (list 'quote v)))
 
 (defmacro (let* binds . body)
-  (if (atom? binds) `((λ () ,@body))
+  (if (atom? binds)
+      `((λ () ,@body))
       `((λ (,(caar binds))
           ,@(if (cons? (cdr binds))
                 `((let* ,(cdr binds) ,@body))
@@ -615,7 +668,7 @@
 (defmacro (unwind-protect expr finally)
   `(let ((thk# (λ () ,finally)))
      (prog1 (trycatch ,expr
-                      (λ (e#) (begin (thk#) (raise e#))))
+                      (λ (e#) (thk#) (raise e#)))
             (thk#))))
 
 ;;; debugging utilities
@@ -623,9 +676,9 @@
 (defmacro (assert expr) `(if ,expr t (raise '(assert-failed ,expr))))
 
 (def traced?
-  (letrec ((sample-traced-lambda (λ args (begin (write (cons 'x args))
-                                                     (newline)
-                                                     (apply #.apply args)))))
+  (let ((sample-traced-lambda (λ args (write (cons 'x args))
+                                      (newline)
+                                      (apply #.apply args))))
     (λ (f)
       (and (closure? f)
            (equal? (function:code f)
@@ -632,14 +685,14 @@
                    (function:code sample-traced-lambda))))))
 
 (def (trace sym)
-  (let* ((func (top-level-value sym)))
+  (let ((func (top-level-value sym)))
     (when (not (traced? func))
       (set-top-level-value! sym
                             (eval
                               `(λ args#
-                                  (begin (write (cons ',sym args#))
-                                         (newline)
-                                         (apply ',func args#)))))))
+                                  (write (cons ',sym args#))
+                                  (newline)
+                                  (apply ',func args#))))))
   (void))
 
 (def (untrace sym)
@@ -739,12 +792,12 @@
 (def (string-trim s at-start at-end)
   (def (trim-start s chars i L)
     (if (and (< i L) (string-find chars (string-char s i)))
-              (trim-start s chars (1+ i) L)
-              i))
+        (trim-start s chars (1+ i) L)
+        i))
   (def (trim-end s chars i)
     (if (and (> i 0) (string-find chars (string-char s (1- i))))
-              (trim-end s chars (1- i))
-              i))
+        (trim-end s chars (1- i))
+        i))
   (let ((L (string-length s)))
     (string-sub s
                 (trim-start s at-start 0 L)
@@ -755,8 +808,8 @@
         (n (string-length s)))
     (let ((i 0))
       (while (< i n)
-             (begin (io-putc b (f (string-char s i)))
-                    (set! i (1+ i)))))
+         (io-putc b (f (string-char s i)))
+         (set! i (1+ i))))
     (iostream->string b)))
 
 (def (string-rep s k)
@@ -777,7 +830,8 @@
     (iostream->string b)))
 
 (def (string-join strlist sep)
-  (if (not strlist) ""
+  (if (not strlist)
+      ""
       (let ((b (buffer)))
         (io-write b (car strlist))
         (for-each (λ (s) (io-write b sep)
@@ -791,9 +845,11 @@
                             (symbol-syntax (car e))))
 
 (def (macroexpand-1 e)
-  (if (atom? e) e
+  (if (atom? e)
+      e
       (let ((f (macrocall? e)))
-        (if f (apply f (cdr e))
+        (if f
+            (apply f (cdr e))
             e))))
 
 (def (macroexpand e)
@@ -813,7 +869,8 @@
   (def *expanded* (list '*expanded*))
 
   (def (expand-body body env)
-    (if (atom? body) body
+    (if (atom? body)
+        body
         (let* ((body  (if (top? 'begin env)
                           (splice-begin body)
                           body))
@@ -845,7 +902,8 @@
                 ex-nondefs)))))
 
   (def (expand-lambda-list l env)
-    (if (atom? l) l
+    (if (atom? l)
+        l
         (cons (if (and (cons? (car l)) (cons? (cdr (car l))))
                   (list (caar l) (expand-in (cadar l) env))
                   (car l))
@@ -907,12 +965,14 @@
   (def (local-expansion-env menv lenv) menv)
 
   (def (expand-in e env)
-    (if (atom? e) e
+    (if (atom? e)
+        e
         (let* ((head (car e))
                (bnd  (assq head env))
                (default (λ ()
                           (let loop ((e e))
-                            (if (atom? e) e
+                            (if (atom? e)
+                                e
                                 (cons (if (atom? (car e))
                                           (car e)
                                           (expand-in (car e) env))
@@ -1049,7 +1109,8 @@
          (princ ": ")
          (let ((msg (cadr e)))
            ((if (or (string? msg) (symbol? msg))
-                princ print)
+                princ
+                print)
             msg)))
 
         (else (princ "*** Unhandled exception: ")
@@ -1058,7 +1119,8 @@
   (princ *linefeed*))
 
 (def (simple-sort l)
-  (if (or (not l) (not (cdr l))) l
+  (if (or (not l) (not (cdr l)))
+      l
       (let ((piv (car l)))
         (receive (less grtr)
                  (partition (λ (x) (< x piv)) (cdr l))
@@ -1105,8 +1167,8 @@
 
 (def (__script fname)
   (trycatch (load fname)
-            (λ (e) (begin (top-level-exception-handler e)
-                               (exit 1)))))
+            (λ (e) (top-level-exception-handler e)
+                   (exit 1))))
 
 (def (__rcscript)
   (let* ((homevar (case *os-name*
@@ -1119,7 +1181,8 @@
                    (("plan9") "lib/slrc")
                    (else ".slrc")))
          (fname (and home (string home *directory-separator* rcpath))))
-    (when (and fname (path-exists? fname)) (load fname))))
+    (when (and fname (path-exists? fname))
+      (load fname))))
 
 (def (__start argv)
   (__init_globals)