-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathnxt-utilities.lisp
83 lines (67 loc) · 2.46 KB
/
nxt-utilities.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
;;; Copyright (c) 2010-2011 by Willem Rein Oudshoorn
;;;
;;; Licensed under the BSD License, see accompanied LICENSE file
;;;
(in-package :nxt)
(defun value-of (key assoc)
(cdr (assoc key assoc)))
(defun status-ok-p (reply)
(eq (value-of 'status reply) :success))
(defun find-all-files ()
(loop
:for reply = (nxt-find-first :file-name "*.*")
:then (nxt-find-next :handle (value-of 'handle reply))
:while (status-ok-p reply)
:collect reply
:finally (nxt-close :handle (value-of 'handle reply))))
(defun find-all-modules ()
(loop
:for reply = (nxt-request-first-module :resource-name "*.*")
:then (nxt-request-next-module :handle (value-of 'handle reply))
:while (status-ok-p reply)
:collect reply
:finally (nxt-close-module-handle :handle (value-of 'handle reply))))
(defun get-file (file-name)
(let* ((open-result (nxt-open-read :file-name file-name))
(handle (value-of 'handle open-result))
(file-size (value-of 'file-size open-result)))
(if (status-ok-p open-result)
(let ((result (make-array file-size)))
(loop :for i :below file-size :by 500
:for l = (min 500 (- file-size i))
:for read-result = (nxt-read :handle handle :nr-of-bytes l)
:do
(setf (subseq result i) (value-of 'data read-result)))
(nxt-close :handle handle)
result)
open-result)))
(defun copy-file-from-nxt (file-name-nxt file-name)
(let ((file-content (get-file file-name-nxt)))
(with-open-file (s file-name :direction :output
:element-type '(unsigned-byte 8)
:if-exists :supersede)
(write-sequence file-content s))))
(defun copy-file-to-nxt (file-name file-name-nxt)
(put-file file-name-nxt
(coerce
(with-open-file (s file-name :direction :input
:element-type '(unsigned-byte 8))
(loop :for value = (read-byte s nil nil)
:while value
:collect value))
'vector)))
(defun put-file (file-name data)
(let* ((vdata (typecase data
(string (map 'vector #'char-code data))
(vector data)
(t (error "put-file can only handle vectors and strings"))))
(open-result (nxt-open-write :file-name file-name :file-size (length vdata))))
(if (status-ok-p open-result)
(progn
(loop :for i :below (length vdata) :by 500
:for l = (min (+ i 500) (length vdata))
:do
(nxt-write :handle (value-of 'handle open-result)
:data (subseq vdata i l)))
(nxt-close :handle (value-of 'handle open-result)))
open-result)))