-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathbuffer-streams.lisp
36 lines (26 loc) · 1.18 KB
/
buffer-streams.lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
(defpackage :lisp-binary/buffer-streams
(:use :common-lisp :trivial-gray-streams))
(in-package :lisp-binary/buffer-streams)
(defclass buffer-stream (fundamental-binary-stream)
((buffer :initarg :buffer)
(read-pointer :initform 0)))
(defun make-buffer-stream (element-type)
(make-instance 'buffer-stream :buffer (make-array 0 :element-type element-type :adjustable t :fill-pointer t)))
(defmethod stream-write-byte ((stream buffer-stream) byte)
(vector-push-extend byte (slot-value stream 'buffer)))
(defmethod stream-read-byte ((stream buffer-stream))
(handler-case
(aref
(slot-value stream 'buffer)
(prog1 (slot-value stream 'read-pointer)
(incf (slot-value stream 'read-pointer))))
(t ()
:eof)))
;; TRIVIAL-GRAY-STREAMS seems to be broken on SBCL.
(defmethod stream-write-sequence ((stream buffer-stream) sequence &optional start end)
(loop for ix from start to (or end (1- (length sequence)))
do (write-byte (aref sequence ix) stream)))
(defmacro with-output-to-buffer ((var &key (element-type ''(unsigned-byte 8))) &body body)
`(let ((,var (make-buffer-stream ,element-type)))
,@body
(slot-value ,var 'buffer)))