Clean up the godawful utils file
author |
Steve Losh <steve@stevelosh.com> |
date |
Sat, 09 Apr 2016 21:04:26 +0000 (2016-04-09) |
parents |
9f3dbec1414f
|
children |
3e9db801d234
|
branches/tags |
(none) |
files |
src/utils.lisp |
Changes
--- a/src/utils.lisp Sat Apr 09 20:47:56 2016 +0000
+++ b/src/utils.lisp Sat Apr 09 21:04:26 2016 +0000
@@ -3,54 +3,29 @@
(defvar *log* *error-output*)
-(defun make-hash (&rest keyvals)
- (do ((h (make-hash-table :test #'equal))
- (kvs keyvals (cddr kvs)))
- ((not kvs) h)
- (setf (gethash (first kvs) h) (second kvs))))
-
-(defmacro when-let (bindings &rest body)
- (labels ((build (bindings body)
- (if (not bindings)
- body
- `(let ((,(caar bindings) ,(cadar bindings)))
- (when ,(caar bindings)
- ,(build (cdr bindings) body))))))
- (build bindings `(progn ,@body))))
-
-(defmacro if-let (bindings then else)
- `(let (,@bindings)
- (if (and ,@(mapcar #'car bindings))
- ,then
- ,else)))
-
-(defun pairs (l)
- (loop for (a b) on l by #'cddr
- collect (cons a b)))
+(defun pairs (sequence)
+ "Return a list of cons pairs of the items of the riffle `sequence`."
+ (loop :for (a b) :on sequence :by #'cddr
+ :collect (cons a b)))
(defun make-map (&rest keyvals)
+ "Create an fset map of the given riffle of keys and values."
(fset:convert 'fset:map (pairs keyvals)))
-(defun set-when (h &rest keyvals)
- (loop for (key val) on keyvals by #'cddr
- do (when val (setf (gethash key h) val))))
-
-(defun with-when (m &rest keyvals)
- (labels ((build (m keyvals)
- (if (not keyvals)
- m
+(defun with-when (map &rest keyvals)
+ "Add the items in the `keyvals` riffle with non-nil values to `map`."
+ (labels ((build (map keyvals)
+ (if (null keyvals)
+ map
(destructuring-bind (k v &rest remaining) keyvals
(build (if v
- (fset:with m k v)
- m)
+ (fset:with map k v)
+ map)
remaining)))))
- (build m keyvals)))
-
-(defun with-map (m key f)
- (let ((val (fset:lookup m key)))
- (fset:with m key (funcall f val))))
+ (build map keyvals)))
(defun read-all-from-string (s)
+ "Read all forms in `s` and return them as a list."
(labels ((read-next-from-string (s results)
(if (equal (string-trim " " s) "")
results
@@ -58,24 +33,18 @@
(read-next-from-string (subseq s pos) (cons i results))))))
(nreverse (read-next-from-string s ()))))
-(defmacro comment (&rest body)
- (declare (ignore body))
- nil)
-
(defun curry (fn &rest curried-args)
(lambda (&rest args)
(apply fn (append curried-args args))))
(defun random-uuid ()
+ "Return a random UUID as a string."
(format nil "~a" (uuid:make-v4-uuid)))
(defun hash-keys (h)
- (loop for key being the hash-keys of h
- collect key))
+ (loop :for key :being :the :hash-keys :of h
+ :collect key))
-(defun starts-with (prefix str)
- (string= str prefix :end1 (min (length str)
- (length prefix))))
(defun l (&rest args)
(apply #'format *log* args))
@@ -86,15 +55,21 @@
(defun respond (message response)
+ "Respond to `message` with the `response` map.
+
+ Takes care of finding the transport and patching the message and session IDs
+ into the response.
+
+ "
(funcall (fset:lookup message "transport")
(with-when response
- "id" (fset:lookup message "id")
- "session" (fset:lookup message "session"))))
+ "id" (fset:lookup message "id")
+ "session" (fset:lookup message "session"))))
(defmethod print-object ((object hash-table) stream)
(format stream "#HASH{~%~{~{ (~s : ~s)~}~%~}}"
- (loop for key being the hash-keys of object
- using (hash-value value)
- collect (list key value))))
+ (loop :for key :being :the :hash-keys :of object
+ :using (hash-value value)
+ :collect (list key value))))