shithub: femtolisp

Download patch

ref: 00a57b3668bfc953ddc5b422fe4d0330f73a38a7
parent: 1d1500e0931e604e2a50dfbcf4854a92e29d5c4f
author: Sigrid Solveig Haflínudóttir <[email protected]>
date: Mon Dec 23 19:53:56 EST 2024

docs: section a bit better

--- a/system.lsp
+++ b/system.lsp
@@ -3,6 +3,8 @@
 ; by Jeff Bezanson (C) 2009
 ; Distributed under the BSD License
 
+;;; props
+
 ;; This is implemented in a slightly different fashion as expected:
 ;;
 ;;     *properties* : key → { symbol → value }
@@ -12,6 +14,58 @@
 (unless (bound? '*properties*)
   (define *properties* (table)))
 
+(define (putprop sym key val)
+  (let ((kt (get *properties* key #f)))
+    (unless kt
+        (let ((t (table)))
+          (put! *properties* key t)
+          (set! kt t)))
+    (put! kt sym val)
+    val))
+
+(define (getprop sym key (def #f))
+  (let ((kt (get *properties* key #f)))
+    (or (and kt (get kt sym def)) def)))
+
+(define (remprop sym key)
+  (let ((kt (get *properties* key #f)))
+    (and kt (has? kt sym) (del! kt sym))))
+
+;;; documentation
+
+(define (symbol-set-doc sym doc (funvars #f))
+  (putprop sym '*doc* doc)
+  (if funvars (putprop sym '*funvars* funvars)))
+
+;; chicken and egg - properties defined before symbol-set-doc
+(symbol-set-doc
+  '*properties*
+  "All properties of symbols recorded with putprop are recorded in this table.")
+
+(define (value-get-doc body)
+  (let ((first (car body))
+        (rest  (cdr body)))
+    (and (string? first) (cons? rest) first)))
+
+(define-macro (help term)
+  "Display documentation for the specified term, if available."
+  (let* ((doc     (getprop term '*doc*))
+         (funvars (getprop term '*funvars*)))
+  (if doc
+    (begin
+      (princ doc)
+      (newline)
+      (when funvars
+        (newline)
+        (print (cons term funvars)))
+      (newline))
+    (begin
+      (princ "no help for " (string term))
+      (newline)))
+  (void)))
+
+;;; void
+
 (define (void . rest)
   "Return the constant #<void> while ignoring any arguments.
 #<void> is mainly used when a function has side effects but does not
@@ -24,6 +78,8 @@
   "Return #t if x is #<void> and #f otherwise."
   (eq? x #.(void)))
 
+;;; syntax environment
+
 (unless (bound? '*syntax-environment*)
   (define *syntax-environment* (table)))
 
@@ -96,7 +152,7 @@
                             (cond-clauses->if (cdr lst)))))))))
   (cond-clauses->if clauses))
 
-; standard procedures ---------------------------------------------------------
+;;; standard procedures
 
 (define (member item lst)
   (cond ((null? lst)             #f)
@@ -195,7 +251,7 @@
                 (apply consumer (cdr res))
                 (consumer res))))))
 
-; list utilities --------------------------------------------------------------
+;;; list utilities
 
 (define (every pred lst)
   (or (atom? lst)
@@ -223,7 +279,6 @@
 
 (define (length= lst n)
   "Bounded length test.
-
 Use this instead of (= (length lst) n), since it avoids unnecessary
 work and always terminates."
   (cond ((< n 0)     #f)
@@ -343,7 +398,7 @@
                 (cons elt
                       (delete-duplicates tail)))))))
 
-; backquote -------------------------------------------------------------------
+;;; backquote
 
 (define (revappend l1 l2) (reverse-  l2 l1))
 (define (nreconc   l1 l2) (reverse!- l2 l1))
@@ -434,7 +489,7 @@
                   ;; (... . x)
                   (cons 'nconc (reverse! (cons (bq-process p d) q)))))))))
 
-; standard macros -------------------------------------------------------------
+;;; standard macros
 
 (define (quote-value v)
   (if (self-evaluating? v)
@@ -522,7 +577,7 @@
         (begin ,@body)
         (begin ,@(map (λ (v old) `(set! ,v ,old)) vars olds))))))
 
-; exceptions ------------------------------------------------------------------
+;;; exceptions
 
 (define (error . args) (raise (cons 'error args)))
 
@@ -544,7 +599,7 @@
                         (λ (,e) (begin (,thk) (raise ,e))))
               (,thk)))))
 
-; debugging utilities ---------------------------------------------------------
+;;; debugging utilities
 
 (define-macro (assert expr) `(if ,expr #t (raise '(assert-failed ,expr))))
 
@@ -582,7 +637,7 @@
         ,expr
         (princ "Elapsed time: " (- (time-now) ,t0) " seconds" *linefeed*)))))
 
-; text I/O --------------------------------------------------------------------
+;;; text I/O
 
 (define (print . args) (for-each write args))
 (define (princ . args)
@@ -618,7 +673,7 @@
   `(with-bindings ((*input-stream* ,stream))
                   ,@body))
 
-; vector functions ------------------------------------------------------------
+;;; vector functions
 
 (define (list->vector l) (apply vector l))
 (define (vector->list v)
@@ -637,7 +692,7 @@
            (aset! nv i (f (aref v i)))))
     nv))
 
-; table functions -------------------------------------------------------------
+;;; table functions
 
 (define (table-pairs t)
   (table-foldl (λ (k v z) (cons (cons k v) z))
@@ -659,7 +714,7 @@
                  () t)
     nt))
 
-; string functions ------------------------------------------------------------
+;;; string functions
 
 (define (string-tail s n) (string-sub s n))
 
@@ -712,59 +767,7 @@
                   (cdr strlist))
         (iostream->string b))))
 
-; props -----------------------------------------------------------------------
-
-(define (putprop sym key val)
-  (let ((kt (get *properties* key #f)))
-    (unless kt
-        (let ((t (table)))
-          (put! *properties* key t)
-          (set! kt t)))
-    (put! kt sym val)
-    val))
-
-(define (getprop sym key (def #f))
-  (let ((kt (get *properties* key #f)))
-    (or (and kt (get kt sym def)) def)))
-
-(define (remprop sym key)
-  (let ((kt (get *properties* key #f)))
-    (and kt (has? kt sym) (del! kt sym))))
-
-; documentation ---------------------------------------------------------------
-
-(define (symbol-set-doc sym doc (funvars #f))
-  (putprop sym '*doc* doc)
-  (if funvars (putprop sym '*funvars* funvars)))
-
-;; chicken and egg
-(symbol-set-doc
-  '*properties*
-  "All properties of symbols recorded with putprop are recorded in this table.")
-
-(define (value-get-doc body)
-  (let ((first (car body))
-        (rest  (cdr body)))
-    (and (string? first) (cons? rest) first)))
-
-(define-macro (help term)
-  "Display documentation for the specified term, if available."
-  (let* ((doc     (getprop term '*doc*))
-         (funvars (getprop term '*funvars*)))
-  (if doc
-    (begin
-      (princ doc)
-      (newline)
-      (when funvars
-        (newline)
-        (print (cons term funvars)))
-      (newline))
-    (begin
-      (princ "no help for " (string term))
-      (newline)))
-  (void)))
-
-; toplevel --------------------------------------------------------------------
+;;; toplevel
 
 (define (macrocall? e) (and (symbol? (car e))
                             (symbol-syntax (car e))))