blob: fb167508e2192cda368cca20fbb974985f353e2c (
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
|
@(do
(defun stream-positioned-to-right-place (name)
(let* ((stream (open-file name "r+b"))
(pre (read-until-match #/@\(txr\)/ stream t)))
(when (or (empty pre) (not (search-str pre "@(txr)")))
(throwf 'error "~a isn't a TXR executable" name))
stream)))
@(next :args)
@(cases)
-w
@string
@file
@ (eof)
@ (do
(let ((f (stream-positioned-to-right-place file)))
(with-in-string-byte-stream (s string)
(mapdo (op put-byte @1 f)
(take 127 (pad (gun (get-byte s)) 0)))
(put-byte 0 f))))
@(or)
@file
@ (eof)
@ (do
(let ((f (stream-positioned-to-right-place file)))
(let ((arg-str (with-out-string-stream (u8)
(mapdo (op put-byte @1 u8)
(take 127 (gun (get-byte f)))))))
(put-line arg-str))))
@(or)
@ (output)
usage: @{self-path} [-w string] txr-executable
@ (end)
@ (do (exit 1))
@(end)
|