-
Notifications
You must be signed in to change notification settings - Fork 47
/
Copy pathcommon.lisp
124 lines (111 loc) · 4.61 KB
/
common.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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
;;; This file contains code moved from "dependent" files that has been unified.
(in-package :xlib)
;;; BUFFER-READ-DEFAULT - read data from the X stream
;;;
;;; READ-SEQUENCE was not present in ANSI Common Lisp when CLX was written. This
;;; implementation is portable and implements block transfer.
(defun buffer-read-default (display vector start end timeout)
(declare (type display display)
(type buffer-bytes vector)
(type array-index start end)
(type (or null (real 0 *)) timeout))
#.(declare-buffun)
(if (and (not (null timeout))
(zerop timeout)
(not (listen (display-input-stream display))))
:timeout
(let ((n (read-sequence vector
(display-input-stream display)
:start start
:end end)))
(cond
((= n end) nil)
((= n start) :end-of-file)
(t :truncated)))))
;;; This is a legacy and obsolete fallback implementation.
;;;
;;; WARNING
;;; CLX performance will suffer if your lisp uses read-byte for receiving
;;; all data from the X Window System server. You are encouraged to write a
;;; specialized version of buffer-read-default that does block transfers.
#+(or)
(defun buffer-read-default (display vector start end timeout)
(declare (type display display)
(type buffer-bytes vector)
(type array-index start end)
(type (or null (real 0 *)) timeout))
#.(declare-buffun)
(let ((stream (display-input-stream display)))
(declare (type (or null stream) stream))
(or (cond ((null stream))
((listen stream) nil)
((and timeout (= timeout 0)) :timeout)
((buffer-input-wait-default display timeout)))
(do* ((index start (index1+ index)))
((index>= index end) nil)
(declare (type array-index index))
(let ((c (read-byte stream nil nil)))
(declare (type (or null card8) c))
(if (null c)
(return t)
(setf (aref vector index) (the card8 c))))))))
;;; BUFFER-WRITE-DEFAULT - write data to the X stream
;;;
;;; WRITE-SEQUENCE was not present in ANSI Common Lisp when CLX was
;;; written. This implementation is portable and implements block transfer.
(defun buffer-write-default (vector display start end)
(declare (type buffer-bytes vector)
(type display display)
(type array-index start end))
#.(declare-buffun)
(write-sequence vector (display-output-stream display) :start start :end end)
nil)
;;; This is a legacy and obsolete fallback implementation.
;;;
;;; WARNING:
;;; CLX performance will be severely degraded if your lisp uses
;;; write-byte to send all data to the X Window System server.
;;; You are STRONGLY encouraged to write a specialized version
;;; of buffer-write-default that does block transfers.
#+(or)
(defun buffer-write-default (vector display start end)
;; The default buffer write function for use with common-lisp streams
(declare (type buffer-bytes vector)
(type display display)
(type array-index start end))
#.(declare-buffun)
(let ((stream (display-output-stream display)))
(declare (type (or null stream) stream))
(unless (null stream)
(with-vector (vector buffer-bytes)
(do ((index start (index1+ index)))
((index>= index end))
(declare (type array-index index))
(write-byte (aref vector index) stream))))))
;;; BUFFER-FORCE-OUTPUT-DEFAULT - force output to the X stream
(defun buffer-force-output-default (display)
;; The default buffer force-output function for use with common-lisp streams
(declare (type display display))
(let ((stream (display-output-stream display)))
(declare (type (or null stream) stream))
(unless (null stream)
(force-output stream))))
;;; BUFFER-CLOSE-DEFAULT - close the X stream
(defun buffer-close-default (display &key abort)
;; The default buffer close function for use with common-lisp streams
(declare (type display display))
#.(declare-buffun)
(let ((stream (display-output-stream display)))
(declare (type (or null stream) stream))
(unless (null stream)
(close stream :abort abort))))
;;; BUFFER-LISTEN-DEFAULT - returns T if there is input available for the
;;; buffer. This should never block, so it can be called from the scheduler.
;;; The default implementation is to just use listen.
(defun buffer-listen-default (display)
(declare (type display display))
(let ((stream (display-input-stream display)))
(declare (type (or null stream) stream))
(if (null stream)
t
(listen stream))))