source: project/release/4/vandusen/trunk/vandusen-remote.scm @ 24869

Last change on this file since 24869 was 24869, checked in by Moritz Heidkamp, 9 years ago

vandusen-remote: listen on localhost only by default and make it configurable

File size: 950 bytes
Line 
1(module vandusen-remote ()
2
3(import chicken scheme extras srfi-13)
4(require-library regex)
5(import irregex)
6(use vandusen tcp srfi-18)
7
8(plugin 'remote
9        (lambda ()
10          (let ((listener (tcp-listen ($ 'remote-port)
11                                      (or ($ 'remote-backlog) 10)
12                                      (or ($ 'remote-host) "localhost"))))
13            (add-finalizer (lambda ()
14                             (debug "finalizing remote listener")
15                             (tcp-close listener)))
16
17            (thread-start! (lambda ()
18                             (let loop ()
19                               (receive (in out) (tcp-accept listener)
20                                        (thread-start! (lambda ()
21                                                         (and-let* ((match (irregex-match 
22                                                                            '(seq (submatch (+ (~ space)))
23                                                                                  " " 
24                                                                                  (submatch (+ any)))
25                                                                            (read-line in))))
26                                                           (say (string-trim (irregex-match-substring match 2))
27                                                                (irregex-match-substring match 1)))
28                                                         (close-input-port in)
29                                                         (close-output-port out)))
30                                        (loop)))))))))
Note: See TracBrowser for help on using the repository browser.