-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathformat.lisp
42 lines (39 loc) · 1.3 KB
/
format.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
(defpackage :kiln/scripts/format
(:use :cl :alexandria :serapeum :kiln)
(:import-from :clawk)
(:import-from :clingon)
(:documentation "Use format like awk"))
(in-package :kiln/scripts/format)
(def options
(list
(clingon:make-option
:string
:description "Field separator (char or regexp)"
:initial-value " "
:short-name #\F
:long-name "field-separator"
:key :field-separator)
(clingon:make-option
:flag
:description "Treat arguments as a list"
:short-name #\L
:long-name "list"
:key :list)))
(def command
(clingon:make-command
:name "kiln-format"
:description "Use format like AWK"
:options options))
(defun main (args)
(let* ((opts (clingon:parse-command-line command args))
(field-separator (clingon:getopt opts :field-separator #\Space)))
(destructuring-bind (control-string)
(clingon:command-arguments command)
(let ((list? (clingon:getopt opts :list)))
(with-boolean (list?)
(let ((formatter (compile nil (eval `(formatter ,control-string)))))
(clawk:for-stream-lines (*standard-input*)
(let ((fields (clawk:split nil field-separator)))
(:if list?
(format t formatter fields)
(format t "~?" formatter fields))))))))))