* cleanup of hash-tables.ss

This commit is contained in:
Abdulaziz Ghuloum 2007-05-06 18:23:07 -04:00
parent fcf401b076
commit 81179a5e5d
2 changed files with 4 additions and 40 deletions

Binary file not shown.

View File

@ -2,26 +2,15 @@
(library (ikarus hash-tables) (library (ikarus hash-tables)
(export hash-table? make-hash-table get-hash-table put-hash-table!) (export hash-table? make-hash-table get-hash-table put-hash-table!)
(import (import
(only (scheme) $set-car! $set-cdr! $car $cdr $fxlogxor $fxsra (ikarus system $pairs)
$fxsll $fxlognot $fx+ $fx- $fx= $fx> $fxadd1 (ikarus system $vectors)
$vector-length $vector-ref $vector-set! (ikarus system $tcbuckets)
$make-tcbucket $set-tcbucket-val! (ikarus system $fx)
$tcbucket-next $tcbucket-key $set-tcbucket-next!
$tcbucket-val $set-tcbucket-tconc! $fxlogand)
(except (ikarus) hash-table? make-hash-table get-hash-table (except (ikarus) hash-table? make-hash-table get-hash-table
put-hash-table!)) put-hash-table!))
(define-record hasht (vec count tc)) (define-record hasht (vec count tc))
;(let ([hash-rtd (make-record-type '"hash-table" '(hash-vec count tc))])
; ;;; accessors
; (define get-vec (record-field-accessor hash-rtd 0))
; (define set-vec! (record-field-mutator hash-rtd 0))
; (define get-count (record-field-accessor hash-rtd 1))
; (define set-count! (record-field-mutator hash-rtd 1))
; (define get-tc (record-field-accessor hash-rtd 2))
;;; implementation
;;; directly from Dybvig's paper ;;; directly from Dybvig's paper
(define tc-pop (define tc-pop
(lambda (tc) (lambda (tc)
@ -119,28 +108,6 @@
($vector-set! vec idx b) ($vector-set! vec idx b)
(void)))))))) (void))))))))
;(define hash-remove!
; (lambda (h x)
; (let ([vec (get-vec h)]
; [next ($tcbucket-next b)])
; ;;; first remove it from its old place
; (let ([idx
; (if (fixnum? next)
; next
; (get-bucket-index next))])
; (let ([fst ($vector-ref vec idx)])
; (cond
; [(eq? fst b)
; ($vector-set! vec idx next)]
; [else
; (replace! fst b next)]))))
; (let ([b1 ($tcbucket-dlink-next b)]
; [b2 ($tcbucket-dlink-prev b)])
; ($set-tcbucket-dlink-next! b2 b1)
; ($set-tcbucket-dlink-prev! b1 b2)
; (void))))
(define get-hash (define get-hash
(lambda (h x v) (lambda (h x v)
(let ([pv (pointer-value x)] (let ([pv (pointer-value x)]
@ -155,7 +122,6 @@
($tcbucket-val b))] ($tcbucket-val b))]
[else v]))))))) [else v])))))))
(define put-hash! (define put-hash!
(lambda (h x v) (lambda (h x v)
(let ([pv (pointer-value x)] (let ([pv (pointer-value x)]
@ -213,8 +179,6 @@
(move-all vec1 0 n1 vec2 ($fx- n2 1)) (move-all vec1 0 n1 vec2 ($fx- n2 1))
(set-hasht-vec! h vec2)))) (set-hasht-vec! h vec2))))
(define init-vec (define init-vec
(lambda (v i n) (lambda (v i n)
(if ($fx= i n) (if ($fx= i n)