* added an (ikarus system $bytevectors) library
This commit is contained in:
parent
97f59ad1ee
commit
9d3e23fb6d
src
ikarus.bootikarus.compiler.ssmakefile.ss
old-tests
tests-1.1-req.scmtests-1.2-req.scmtests-1.3-req.scmtests-1.4-req.scmtests-1.5-req.scmtests-1.6-req.scmtests-1.7-req.scmtests-1.8-req.scmtests-1.9-req.scmtests-2.1-req.scmtests-2.2-req.scmtests-2.3-req.scmtests-2.4-req.scmtests-2.6-req.scmtests-2.8-req.scmtests-2.9-req.scmtests-3.1-req.scmtests-3.2-req.scmtests-3.3-req.scmtests-3.4-req.scmtests-4.1-req.scmtests-4.2-req.scmtests-4.3-req.scmtests-5.1-req.scmtests-5.2-req.scmtests-5.3-req.scmtests-5.6-req.scmtests-new.scm
run-tests.sstests
BIN
src/ikarus.boot
BIN
src/ikarus.boot
Binary file not shown.
|
@ -126,6 +126,12 @@
|
||||||
[$string-length 1 value]
|
[$string-length 1 value]
|
||||||
[$string-ref 2 value]
|
[$string-ref 2 value]
|
||||||
[$string-set! 3 effect]
|
[$string-set! 3 effect]
|
||||||
|
;;; bytevectors
|
||||||
|
[bytevector? 1 pred]
|
||||||
|
[$make-bytevector 1 value]
|
||||||
|
[$bytevector-length 1 value]
|
||||||
|
[$bytevector-ref 2 value]
|
||||||
|
[$bytevector-set! 3 effect]
|
||||||
;;; symbols
|
;;; symbols
|
||||||
[$make-symbol 1 value]
|
[$make-symbol 1 value]
|
||||||
[$symbol-value 1 value]
|
[$symbol-value 1 value]
|
||||||
|
|
|
@ -117,6 +117,7 @@
|
||||||
[$chars (ikarus system $chars) #f]
|
[$chars (ikarus system $chars) #f]
|
||||||
[$strings (ikarus system $strings) #f]
|
[$strings (ikarus system $strings) #f]
|
||||||
[$vectors (ikarus system $vectors) #f]
|
[$vectors (ikarus system $vectors) #f]
|
||||||
|
[$bytes (ikarus system $bytevectors) #f]
|
||||||
[$fx (ikarus system $fx) #f]
|
[$fx (ikarus system $fx) #f]
|
||||||
[$symbols (ikarus system $symbols) #f]
|
[$symbols (ikarus system $symbols) #f]
|
||||||
[$records (ikarus system $records) #f]
|
[$records (ikarus system $records) #f]
|
||||||
|
@ -130,6 +131,7 @@
|
||||||
[$boot (ikarus system $bootstrap) #f]
|
[$boot (ikarus system $bootstrap) #f]
|
||||||
))
|
))
|
||||||
|
|
||||||
|
|
||||||
(define bootstrap-collection
|
(define bootstrap-collection
|
||||||
(let ([ls (map
|
(let ([ls (map
|
||||||
(lambda (x)
|
(lambda (x)
|
||||||
|
@ -469,6 +471,14 @@
|
||||||
[$string-set! $strings]
|
[$string-set! $strings]
|
||||||
[$string-length $strings]
|
[$string-length $strings]
|
||||||
|
|
||||||
|
[bytevector? i]
|
||||||
|
|
||||||
|
[$make-bytevector $bytes]
|
||||||
|
[$bytevector-length $bytes]
|
||||||
|
[$bytevector-ref $bytes]
|
||||||
|
[$bytevector-set! $bytes]
|
||||||
|
|
||||||
|
|
||||||
[$make-vector $vectors]
|
[$make-vector $vectors]
|
||||||
[$vector-length $vectors]
|
[$vector-length $vectors]
|
||||||
[$vector-ref $vectors]
|
[$vector-ref $vectors]
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
#!/usr/bin/env ikarus --r6rs-script
|
||||||
|
|
||||||
|
(import (ikarus)
|
||||||
|
(tests bytevectors))
|
||||||
|
|
||||||
|
(test-bytevectors)
|
||||||
|
(printf "Happy Happy Joy Joy\n")
|
|
@ -0,0 +1,23 @@
|
||||||
|
|
||||||
|
(library (tests bytevectors)
|
||||||
|
(export test-bytevectors)
|
||||||
|
(import (ikarus) (tests framework))
|
||||||
|
|
||||||
|
(define (not-byte-vector? x)
|
||||||
|
(not (bytevector? x)))
|
||||||
|
|
||||||
|
(define-tests test-bytevectors
|
||||||
|
[bytevector? (make-bytevector 1)]
|
||||||
|
[bytevector? (make-bytevector 1 17)]
|
||||||
|
[bytevector? (make-bytevector 10 -17)]
|
||||||
|
[not-bytevector? 'foo]
|
||||||
|
[not-bytevector? "hey"]
|
||||||
|
[not-bytevector? (current-output-port)]
|
||||||
|
[not-bytevector? (current-input-port)]
|
||||||
|
[not-bytevector? '#(2837 2398 239)]
|
||||||
|
))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
|
||||||
|
(library (tests framework)
|
||||||
|
(export define-tests)
|
||||||
|
(import (ikarus))
|
||||||
|
(define-syntax define-tests
|
||||||
|
(syntax-rules ()
|
||||||
|
[(_ test-all [p0 e0] ...)
|
||||||
|
(define test-all
|
||||||
|
(lambda ()
|
||||||
|
(let ([p p0] [e e0])
|
||||||
|
(unless (p e)
|
||||||
|
(error 'test-all "~s failed, got ~s"
|
||||||
|
'(p0 e0) e)))
|
||||||
|
...
|
||||||
|
(printf "[~s] Happy Happy Joy Joy\n" 'test-all)))])))
|
Loading…
Reference in New Issue