aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Peter McGoron 2024-12-23 23:42:21 -0500
committerGravatar Peter McGoron 2024-12-23 23:42:21 -0500
commita7424d5838f3c6a2afefa49fc0fbe76a88596b6a (patch)
tree39fd7197dda091035eb7e18a08f99f22d066c810
parentstring-iterator: use external function to simplify iterative application of p... (diff)
make iterator-advance only take integers
Diffstat (limited to '')
-rw-r--r--generic-iterator.scm27
1 files changed, 17 insertions, 10 deletions
diff --git a/generic-iterator.scm b/generic-iterator.scm
index 3c76400..ee5ac9e 100644
--- a/generic-iterator.scm
+++ b/generic-iterator.scm
@@ -29,17 +29,23 @@
(comparison get-comparison-procedure)
(private iterator-get-private))
+(define-syntax define-with-field-of-iterator
+ (syntax-rules ()
+ ((_ (name field args ...) emsg body ...)
+ (define (name iterator args ...)
+ (let ((field (field iterator)))
+ (if (not field)
+ (error emsg iterator args ...)
+ (begin body ...)))))))
+
;;; Define a function that invokes a field of the iterator on the data
;;; object inside the iterator and any other arguments supplied to the
;;; function.
(define-syntax define-invoke-field-of-iterator
(syntax-rules ()
- ((define-invoker name field-accessor emsg args ...)
- (define (name iterator args ...)
- (let ((proc (field-accessor iterator)))
- (if (not proc)
- (error emsg iterator)
- (proc args ...)))))))
+ ((_ name field-accessor emsg args ...)
+ (define-with-field-of-iterator (name field-accessor args ...) emsg
+ (field-accessor args ...)))))
(define-invoke-field-of-iterator iterator-at-start?
get-start-predicate
@@ -48,10 +54,11 @@
get-end-predicate
"no end predicate")
-(define-invoke-field-of-iterator iterator-advance
- get-advance
- "no procedure to move iterator"
- spaces)
+(define-with-field-of-iterator (iterator-advance get-advance spaces)
+ "no advance procedure"
+ (if (not (integer? spaces))
+ (error "must advance an integer amount" spaces)
+ (get-advance spaces)))
(define-invoke-field-of-iterator iterator-ref
get-ref
td>Gravatar aeb 2-11/+11 2000-11-25Add some information about return values.Gravatar aeb 1-3/+29 2000-11-24Bump up version numbers for release.Gravatar aeb 2-3/+11 2000-11-24Added libraw1394.postinst.in to list of distributed files.Gravatar aeb 3-3/+35 2000-11-23Add ldconfig in deb postinst for Debian policy conformance.Gravatar aeb 2-2/+17 2000-11-23Removed acconfig.h, which wasn't needed for some time.Gravatar aeb 1-13/+0 2000-11-22Added ieee1394.h header.Gravatar aeb 3-1/+38 2000-09-13Fix raw1394_start_iso_write() which uses wrong variable.Gravatar aeb 1-1/+1 2000-09-10Work around compiler warnings for int/ptr casts.Gravatar aeb 6-10/+20 2000-09-10Added control files for Debian packages.Gravatar aeb 6-8/+106 2000-09-01Added missing prototypes for iso send functions.Gravatar aeb 1-0/+7 2000-08-08Added raw1394_get_irm_id().Gravatar aeb 7-7/+39 2000-08-06Added support for isochronous sending.Gravatar aeb 3-0/+35 2000-07-05Added raw1394_reset_bus() call.Gravatar aeb 4-0/+23 2000-06-22- Set library version info in configure.in, use in src/Makefile.am.Gravatar aeb 4-2/+16 2000-06-15Update libtool version number.Gravatar aeb 2-2/+2 2000-06-14Added copyright headers.Gravatar aeb 6-0/+54 2000-06-11Added explicit AC_PROG_INSTALL call.Gravatar aeb 1-0/+1 2000-06-09Fix size of error field.Gravatar aeb 1-2/+2 2000-06-02Modified support for 32/64 bit environments, control struct fields have fixed...Gravatar aeb 7-43/+28 2000-05-28Added support for environments with 64 bit kernel and 32 bit userland.Gravatar aeb 8-7/+45 2000-04-27Fixed missing setting of ext code in raw1394_start_lock()Gravatar aeb 1-0/+1 2000-04-15Fixed lock transaction to actually return response value.Gravatar aeb 3-5/+11 2000-04-12Add userdata functions as news.Gravatar aeb 1-0/+4 2000-04-05Add userdata functions.Gravatar aeb 3-0/+18 2000-03-18Bump version number to 0.6.Gravatar aeb 3-5/+6 2000-03-18Mention byte order change.Gravatar aeb 1-0/+2 2000-03-18Mention SourceForge home.Gravatar aeb 1-1/+5