aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Peter McGoron 2025-04-12 12:54:35 -0400
committerGravatar Peter McGoron 2025-04-12 12:54:35 -0400
commit638df69633e1a36079a9c53bf35b4f9090609bb4 (patch)
tree062e091c1f0341898c1c89bda6673d6911a93b92
parenttrigger a manual minor garbage collection to try and smoke out stack corruption (diff)
test predicates on non-procedures0.9.0
Diffstat (limited to '')
-rw-r--r--lowlevel.scm2
-rw-r--r--srfi-259.egg2
-rw-r--r--srfi-259.sld1
-rw-r--r--tests/run.scm8
4 files changed, 12 insertions, 1 deletions
diff --git a/lowlevel.scm b/lowlevel.scm
index 3f22155..21bfba8 100644
--- a/lowlevel.scm
+++ b/lowlevel.scm
@@ -28,6 +28,8 @@
;;; The code works by having a "signifier pair", whose car is a unique
;;; (in the sense of eqv) symbol and whose cdr is a integer map to the
;;; tag values.
+;;;
+;;; The code is similar to `extend-procedure`.
(define unique-id
;; Generate a fixnum, which will serve as the ID for each tagged
diff --git a/srfi-259.egg b/srfi-259.egg
index 6cc1531..559e739 100644
--- a/srfi-259.egg
+++ b/srfi-259.egg
@@ -8,4 +8,4 @@
(components (extension srfi-259
(source "srfi-259.sld")
(source-dependencies "lowlevel.scm")
- (csc-options "-k" "-debug-info" "-R" "r7rs" "-X" "r7rs" "-O3"))))
+ (csc-options "-R" "r7rs" "-X" "r7rs" "-O3"))))
diff --git a/srfi-259.sld b/srfi-259.sld
index 20a78be..7a3dfb2 100644
--- a/srfi-259.sld
+++ b/srfi-259.sld
@@ -47,6 +47,7 @@
(set! predicate?
(lambda (proc)
(cond
+ ((not (procedure? proc)) #f)
((get-mapping proc) => (cut fxmapping-contains? <> id))
(else #f))))
(set! accessor
diff --git a/tests/run.scm b/tests/run.scm
index b35427d..bdc08c2 100644
--- a/tests/run.scm
+++ b/tests/run.scm
@@ -74,4 +74,12 @@
(test "get-tag-foo" 'foo (get-tag-foo tagged))
(test "get-tag-baz" 'baz (get-tag-baz tagged))))
+(test-group "predicates on other objects"
+ (test-assert "integers are not tagged" (not (tag-foo? 0)))
+ (test-assert "strings are not tagged" (not (tag-foo? "hello")))
+ (test-assert "bytevectors are not tagged" (not (tag-foo? #u8(1 2 3 4))))
+ (test-assert "vectors are not tagged" (not (tag-foo? #(call/cc))))
+ (test-assert "lists are not tagged" (not (tag-foo? '(1 2 3 4))))
+ (test-assert "non-tagged procedures are not tagged" (not (tag-foo? call/cc))))
+
(test-end "SRFI 259")
6546dfacd0?s=13&d=retro' width='13' height='13' alt='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