[functional tests] more work on the binary-format macro
This commit is contained in:
parent
78488e8909
commit
d0040a169d
@ -1,7 +1,14 @@
|
|||||||
(library
|
(library
|
||||||
(binary-format)
|
(binary-format)
|
||||||
(export binary-format)
|
(export size-type binary-format le32 le64 bytes)
|
||||||
(import (rnrs))
|
(import (rnrs)
|
||||||
|
(list-utils))
|
||||||
|
|
||||||
|
(define-syntax size-type
|
||||||
|
(syntax-rules (le32 le64 bytes)
|
||||||
|
((_ le32) 4)
|
||||||
|
((_ le64) 8)
|
||||||
|
((_ (bytes count)) count)))
|
||||||
|
|
||||||
(define-syntax unpack-type
|
(define-syntax unpack-type
|
||||||
(syntax-rules (le32 le64 bytes)
|
(syntax-rules (le32 le64 bytes)
|
||||||
@ -16,26 +23,34 @@
|
|||||||
(bytevector-copy! bv offset copy 0 count)
|
(bytevector-copy! bv offset copy 0 count)
|
||||||
copy))))
|
copy))))
|
||||||
|
|
||||||
(define (size-type t)
|
|
||||||
(syntax-case t (le32 le64 bytes)
|
|
||||||
(le32 #'4)
|
|
||||||
(le64 #'8)
|
|
||||||
((bytes count) #'count)))
|
|
||||||
|
|
||||||
;;; FIXME: (bytes <count>) has to use a literal rather than a symbol.
|
|
||||||
(define-syntax binary-format
|
(define-syntax binary-format
|
||||||
(lambda (x)
|
(syntax-rules ()
|
||||||
(syntax-case x ()
|
|
||||||
((_ (name pack-name unpack-name) (field type) ...)
|
((_ (name pack-name unpack-name) (field type) ...)
|
||||||
(with-syntax ((((t o) ...)
|
(begin
|
||||||
(let f ((acc 0) (types #'(type ...)))
|
|
||||||
(if (null? types)
|
|
||||||
'()
|
|
||||||
(cons (list (car types) acc)
|
|
||||||
(f (+ (syntax->datum (size-type (car types))) acc) (cdr types)))))))
|
|
||||||
#`(begin
|
|
||||||
(define-record-type name (fields field ...))
|
(define-record-type name (fields field ...))
|
||||||
|
|
||||||
(define (unpack-name bv offset)
|
(define (unpack-name bv offset)
|
||||||
((record-constructor (record-type-descriptor name))
|
(let ((offset offset))
|
||||||
(unpack-type bv (+ offset o) t) ...)))))))))
|
|
||||||
|
(define (inc-offset n v)
|
||||||
|
(set! offset (+ offset n))
|
||||||
|
v)
|
||||||
|
|
||||||
|
((record-constructor (record-constructor-descriptor name))
|
||||||
|
(inc-offset (size-type type) (unpack-type bv offset type)) ...)))))))
|
||||||
|
|
||||||
|
;;; since le32, le64 and bytes are used as auxiliary keywords, we must export
|
||||||
|
;;; definitions of them as well.
|
||||||
|
;;; FIXME: use a macro to remove duplication
|
||||||
|
(define-syntax le32
|
||||||
|
(lambda (x)
|
||||||
|
(syntax-violation 'le32 "misplaced auxiliary keyword" x)))
|
||||||
|
|
||||||
|
(define-syntax le64
|
||||||
|
(lambda (x)
|
||||||
|
(syntax-violation 'le64 "misplaced auxiliary keyword" x)))
|
||||||
|
|
||||||
|
(define-syntax bytes
|
||||||
|
(lambda (x)
|
||||||
|
(syntax-violation 'bytes "misplaced auxiliary keyword" x))))
|
||||||
|
|
||||||
|
@ -3,7 +3,8 @@
|
|||||||
|
|
||||||
(export btree-open
|
(export btree-open
|
||||||
btree-lookup
|
btree-lookup
|
||||||
btree-each)
|
btree-each
|
||||||
|
le64-type)
|
||||||
|
|
||||||
(import (block-io)
|
(import (block-io)
|
||||||
(chezscheme)
|
(chezscheme)
|
||||||
@ -68,16 +69,15 @@
|
|||||||
;;; Performs a binary search looking for the key and returns the index of the
|
;;; Performs a binary search looking for the key and returns the index of the
|
||||||
;;; lower bound.
|
;;; lower bound.
|
||||||
(define (lower-bound node header key)
|
(define (lower-bound node header key)
|
||||||
(let ((nr-entries (node-header-nr-entries header)))
|
(let loop ((lo 0) (hi (node-header-nr-entries header)))
|
||||||
(let loop ((lo 0) (hi nr-entries))
|
(if (<= (- hi lo) 1)
|
||||||
(if (= 1 (- hi lo))
|
|
||||||
lo
|
lo
|
||||||
(let* ((mid (+ lo (/ (- hi lo) 2)))
|
(let* ((mid (+ lo (/ (- hi lo) 2)))
|
||||||
(k (key-at mid)))
|
(k (key-at node mid)))
|
||||||
(cond
|
(cond
|
||||||
((= key k) mid)
|
((= key k) mid)
|
||||||
((< k key) (loop mid hi))
|
((< k key) (loop mid hi))
|
||||||
(else (loop lo mid))))))))
|
(else (loop lo mid)))))))
|
||||||
|
|
||||||
;;;;----------------------------------------------
|
;;;;----------------------------------------------
|
||||||
;;;; Lookup
|
;;;; Lookup
|
||||||
|
@ -1,20 +1,21 @@
|
|||||||
(import
|
(import
|
||||||
|
(binary-format)
|
||||||
(block-io)
|
(block-io)
|
||||||
(fmt fmt)
|
(fmt fmt)
|
||||||
(matchable))
|
(matchable)
|
||||||
|
(rnrs))
|
||||||
|
|
||||||
;;;;---------------------------------------------------
|
;;;;---------------------------------------------------
|
||||||
;;;; Constants
|
;;;; Constants
|
||||||
;;;;---------------------------------------------------
|
;;;;---------------------------------------------------
|
||||||
|
|
||||||
;; FIXME: duplicate with main.scm
|
;; FIXME: duplicate with main.scm
|
||||||
(define (current-metadata)
|
(define (current-metadata) "./metadata.bin")
|
||||||
"./metadata.bin")
|
|
||||||
|
|
||||||
(define superblock-magic 27022010)
|
(define $superblock-magic 27022010)
|
||||||
(define superblock-salt 160774)
|
(define $superblock-salt 160774)
|
||||||
(define uuid-size 16)
|
(define $uuid-size 16)
|
||||||
(define space-map-root-size 128)
|
(define $space-map-root-size 128)
|
||||||
|
|
||||||
(binary-format (superblock pack-superblock unpack-superblock)
|
(binary-format (superblock pack-superblock unpack-superblock)
|
||||||
(csum le32)
|
(csum le32)
|
||||||
@ -54,5 +55,5 @@
|
|||||||
(with-metadata (md (current-metadata))
|
(with-metadata (md (current-metadata))
|
||||||
(let ((superblock (read-block md 0)))
|
(let ((superblock (read-block md 0)))
|
||||||
(fmt #t (dsp "checksum on disk: ") (dsp (bytevector-u32-ref superblock 0 (endianness little))) nl)
|
(fmt #t (dsp "checksum on disk: ") (dsp (bytevector-u32-ref superblock 0 (endianness little))) nl)
|
||||||
(fmt #t (dsp "calculated checksum: ") (dsp (crc32-region superblock-salt superblock 4 4092)) nl)
|
;(fmt #t (dsp "calculated checksum: ") (dsp (crc32-region $superblock-salt superblock 4 4092)) nl)
|
||||||
(check-magic superblock))))
|
(check-magic superblock))))
|
||||||
|
@ -1,8 +1,13 @@
|
|||||||
(library
|
(library
|
||||||
(list-utils)
|
(list-utils)
|
||||||
(export intersperse iterate accumulate)
|
(export tails intersperse iterate accumulate)
|
||||||
(import (rnrs))
|
(import (rnrs))
|
||||||
|
|
||||||
|
(define (tails xs)
|
||||||
|
(if (null? xs)
|
||||||
|
'()
|
||||||
|
(cons xs (tails (cdr xs)))))
|
||||||
|
|
||||||
(define (intersperse sep xs)
|
(define (intersperse sep xs)
|
||||||
(cond
|
(cond
|
||||||
((null? xs) '())
|
((null? xs) '())
|
||||||
|
Loading…
Reference in New Issue
Block a user