X-Git-Url: http://git.kpe.io/?p=clsql.git;a=blobdiff_plain;f=sql%2Futils.lisp;h=39ee349387e2f437c2b7f88388e75fec1e1cb7a5;hp=dff2ab02ac52a9f0a35c73bdddd2eb951b67af7d;hb=534849c88501e0ea2ee5dbf78d13d8cb73814d71;hpb=b50166ae0ba2bc09a9094c0e675ec92010b7293e diff --git a/sql/utils.lisp b/sql/utils.lisp index dff2ab0..39ee349 100644 --- a/sql/utils.lisp +++ b/sql/utils.lisp @@ -17,10 +17,21 @@ (in-package #:clsql-sys) (defmacro defaulting (&rest place-value-plist) + "for places and values (as an &rest plist) + if place-n is null set it to value-n" `(progn ,@(loop for (place value . rest) on place-value-plist by #'cddr collect `(unless ,place (setf ,place ,value))))) +(defmacro pop-n (place &optional (n 1)) + "pops n items off of a list in place and returns their values in a new list + + if n > the length of the list in place, then we return the full list, + setting the place to nil" + `(loop repeat ,n + while ,place + collect (pop ,place))) + (defun %get-int (v) (etypecase v (string (parse-integer v :junk-allowed t))