aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Peter McGoron 2024-09-22 00:00:26 -0400
committerGravatar Peter McGoron 2024-09-22 00:00:26 -0400
commite109c255ad28591a40b994d1d38c6816443e4aa4 (patch)
tree7a2d834ba66909e65c3131064f40f940b9cc6f6d
parentread: factor out improper list reader (diff)
read: vectors
-rw-r--r--read.scm38
1 files changed, 37 insertions, 1 deletions
diff --git a/read.scm b/read.scm
index 004bd9e..d9ea7f7 100644
--- a/read.scm
+++ b/read.scm
@@ -139,6 +139,11 @@
(map:val node))))
(action table char acc port)))))
+;;; Run the action in TABLE with the next character from PORT.
+(define readtable:next
+ (lambda (table acc port)
+ (readtable:act table (port 'read) acc port)))
+
;;; Return a new readtable where CHAR is bound to ACTION.
(define readtable:update
(lambda (table char action)
@@ -196,6 +201,13 @@
(lambda (oldtable char acc port)
(readtable:act newtable char acc port))))
+;;; Jump to a new readtable, reading the new character, with the old
+;;; readtable as ACC.
+(define readtable:next/old-as-acc
+ (lambda (newtable)
+ (lambda (oldtable __ _ port)
+ (readtable:next newtable oldtable port))))
+
;;; ;;;;;;;;;;;;;;;;;
;;; Identifier reader
;;; ;;;;;;;;;;;;;;;;;
@@ -339,7 +351,29 @@
readtable:read-improper-cdr)
port)))
+(define readtable:read-proper-list
+ (lambda (table port)
+ (readtable:read-list-loop (readtable:table-for-list
+ table
+ (readtable:error "expected proper list"))
+ port)))
+
+;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
+;;; Reader for datum that start with "#"
+;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
+
+(define readtable:vector
+ (lambda (_ __ toplevel port)
+ (list 'vector (readtable:read-proper-list toplevel port))))
+
+(define readtable:hash
+ (readtable:process
+ (readtable:empty/default (readtable:error "unimplemented"))
+ (list readtable:update %bol readtable:vector)))
+
+;;; ;;;;;;;;;;;;;;;;
;;; Toplevel reader.
+;;; ;;;;;;;;;;;;;;;;
;;; This is defined as a function so that it dynamically loads each
;;; sub-readtable.
(define readtable:top
@@ -350,6 +384,8 @@
(list readtable:update #f (readtable:return 'eof))
(list readtable:update %bol readtable:read-list)
(list readtable:update %eol (readtable:error "unbalanced list"))
+ (list readtable:update #\# (readtable:next/old-as-acc
+ readtable:hash))
(list readtable:update #\;
(readtable:jump-discard readtable:read-to-newline)))))
@@ -387,4 +423,4 @@
(read-all "(a b c def (ghi j) k )")
(read-all "( a . b )")
(read-all "( a .b . c)")
-
+(read-all "#( a b y)")
ro' width='13' height='13' alt='Gravatar' /> bencollins 7-200/+199 2003-07-17Patch from Dan Maas to add raw1394_iso_recv_flush() call to API, using theGravatar bencollins 2-3/+25 2003-07-17pkg-config support from Kristian Hogsberg.Gravatar bencollins 3-1/+15 2003-07-17Remove trailing whitespace, which automake chokes on.Gravatar bencollins 1-1/+1 2003-07-13Fixed section for -dev package.Gravatar bencollins 1-1/+1 2003-07-13Re-add the pdf buildGravatar bencollins 1-0/+1 2003-07-13Update Debian files.Gravatar bencollins 4-25/+73 2003-07-13Ok, the Debian package was way out of sync with upstreamGravatar bencollins 1-1/+1 2003-07-13Ooops...libtool works a bit different than I thought, but atleast it worksGravatar bencollins 2-6/+1 2003-07-13Generate and install the pdf in the Debian package.Gravatar bencollins 3-3/+4 2003-07-13Don't run configure at the end of autogen.sh. Also, remove autom4te.cache.Gravatar bencollins 1-1/+1 2003-07-13Update Debian maintainerGravatar bencollins 1-1/+2 2003-07-13Update Debian changelog.Gravatar bencollins 1-0/+8 2003-07-13File doesn't really seem needed. The NEWS file gives a good overview, andGravatar bencollins 1-4/+0 2003-07-13Fix compiler warnings.Gravatar bencollins 4-12/+22 2003-07-13Updates from 0.10.0 release.Gravatar bencollins 4-5/+14 2003-04-23add libtoolize to bootstrapGravatar ddennedy 1-1/+10 2003-04-21added Dan Maas' rawiso docsGravatar ddennedy 1-32/+295 2003-04-07new_handle_on_port() error path fix from Jim RadfordGravatar dmaas 1-1/+3 2003-03-26add raw1394_new_handle_on_port() convenience functionGravatar dmaas 2-1/+41 2003-02-22Updates for new rawiso ioctl interface.Gravatar bencollins 3-37/+125 2003-01-15add iso_xmit_sync() and iso_xmit_write(); clean up iso handling a bitGravatar dmaas 5-39/+161 2003-01-15implement tag matching for rawiso receptionGravatar dmaas 3-4/+12 2003-01-06back out previous commit - don't drop the legacy API just yetGravatar dmaas 6-173/+130 2003-01-05emulate legacy ISO reception API on top of new rawiso APIGravatar dmaas 7-131/+174 2002-12-24update iso API for multi-channel reception and new packet buffer layoutGravatar dmaas 4-123/+236 2002-12-20oops, irq_interval needs to be signedGravatar anonymous 1-1/+1 2002-12-20dmaas - renamed exported arm definitions into the raw1394_ namespace; brought...Gravatar anonymous 3-124/+48 2002-12-16rawiso updates:Gravatar dmaas 3-18/+25 2002-11-18fix cplusplus extern C blockGravatar ddennedy 1-4/+4 2002-11-18merged rawiso branchGravatar ddennedy 7-6/+488