diff options
-rw-r--r-- | lib.functions.lisp | 31 | ||||
-rw-r--r-- | main.lisp | 2 | ||||
-rw-r--r-- | odraw.asd | 1 | ||||
-rw-r--r-- | packages.lisp | 6 |
4 files changed, 39 insertions, 1 deletions
diff --git a/lib.functions.lisp b/lib.functions.lisp new file mode 100644 index 0000000..c7b3ed1 --- /dev/null +++ b/lib.functions.lisp @@ -0,0 +1,31 @@ +;;; lib.functions.lisp - 2025-02-09 + +;; Copyright (C) 2025 Aryadev Chavali + +;; This program is distributed in the hope that it will be useful, but WITHOUT +;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +;; FOR A PARTICULAR PURPOSE. See the GNU General Public License Version 2 for +;; details. + +;; You may distribute and modify this code under the terms of the GNU General +;; Public License Version 2, which you should have received a copy of along with +;; this program. If not, please go to <https://www.gnu.org/licenses/>. + +;;; Commentary: + +;; Helpful functions for usage throughout the project. + +;;; Code: + +(in-package :lib.functions) + +(fn range (start end &optional (step 1)) (-> (fixnum fixnum &optional fixnum) list) + "Make a list of numbers from START to END (exclusive). If STEP is given, then +each member is STEP distance apart." + (if (<= end start) + (error (format nil "~a < ~a" end start)) + (loop :for i :from start :to (1- end) :by step + :collect i))) + +(fn parse-integer* (inp) (-> (string) (or integer list)) + (parse-integer inp :junk-allowed t)) @@ -28,7 +28,7 @@ (fn parse-integers (input) (-> (string) list) (->> input (uiop:split-string) - (mapcar (lambda (s) (parse-integer s :junk-allowed t))) + (mapcar #'parse-integer*) (remove-if #'null))) (fn read-integers () (-> nil list) @@ -2,6 +2,7 @@ :depends-on (:deploy) :components ((:file "packages") (:file "lib.macros") + (:file "lib.functions") (:file "main")) :build-operation "deploy-op" :build-pathname "odraw" diff --git a/packages.lisp b/packages.lisp index f7e56a6..aff5b68 100644 --- a/packages.lisp +++ b/packages.lisp @@ -24,6 +24,12 @@ :while :-> :fn)) +(defpackage lib.functions + (:use :cl :lib.macros) + (:export + :range + :parse-integer*)) + (defpackage main (:use :cl :lib.macros) (:export :start)) |