aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib.functions.lisp31
-rw-r--r--main.lisp2
-rw-r--r--odraw.asd1
-rw-r--r--packages.lisp6
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))
diff --git a/main.lisp b/main.lisp
index 26ef67a..7d52e22 100644
--- a/main.lisp
+++ b/main.lisp
@@ -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)
diff --git a/odraw.asd b/odraw.asd
index 350d9c9..79d714c 100644
--- a/odraw.asd
+++ b/odraw.asd
@@ -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))