blob: d01a1fd710a56447b70f884746f3ace2c963d7e3 (
plain)
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
|
(in-package :extreload)
(defclass config ()
((socket-url
:initarg :socket-url
:reader socket-url
:documentation "DevTools WebSocket URL")
(extension-ids
:initarg :extension-ids
:reader extension-ids
:documentation "Sequence of extension IDs")
(reload-current-tab
:initarg :reload-current-tab
:initform nil
:reader reload-current-tab
:documentation "True if the current tab should be reloaded")
(debug-output
:initarg :debug-output
:initform nil
:reader debug-output
:documentation "True to enable debug output")
(ws-client
:reader ws-client
:documentation "WebSocket client")))
(defmethod print-object ((object config) stream)
(print-unreadable-object (object stream :type t)
(with-slots (socket-url
extension-ids
reload-current-tab
debug-output
ws-client)
object
(format
stream
":socket-url ~s :extension-ids ~s :reload-current-tab ~s :debug-output ~s :ws-client ~s"
socket-url extension-ids reload-current-tab debug-output ws-client))))
(defun make-config (&key socket-url
extension-ids
reload-current-tab
debug-output)
(let ((config (make-instance 'config
:socket-url socket-url
:extension-ids extension-ids
:reload-current-tab reload-current-tab
:debug-output debug-output)))
;; Initialise a new websocket-driver client
(setf (slot-value config 'ws-client) (wsd:make-client socket-url))
config))
|