;; ;; md5 - Scheme wrapper for Colin Plumb's Public Domain md5 implementation ;; ;; All code in this egg is in the Public Domain (module md5 (md5-primitive) (import chicken scheme foreign) (use message-digest-primitive) #>#include "md5-base.c"<# ;#>#include "md5-ssl.c"<# ;an alternative coding (define digest-length (foreign-value "MD5_DIGEST_SIZE" unsigned-int)) (define block-length (foreign-value "MD5_BLOCK_SIZE" unsigned-int)) (define context-size (foreign-value "sizeof(struct MD5Context)" unsigned-int)) (define init (foreign-lambda void MD5Init c-pointer)) (define update (foreign-lambda void MD5Update c-pointer scheme-pointer unsigned-int)) (define final (foreign-lambda void MD5Final c-pointer scheme-pointer)) (define md5-primitive (let ((the-md5-primitive #f)) (lambda () (unless the-md5-primitive (set! the-md5-primitive (make-message-digest-primitive context-size digest-length init update final block-length 'md5-primitive)) ) the-md5-primitive ) ) ) )