Introduce lib.functions which includes helper functions

Splitting macros and functions into different packages and source code
makes it easier to look at.   Functions currently implemented:
- range: like Python's range
- parse-integer*: parse-integer but junk-allowed is set to t.
This commit is contained in:
2025-02-10 06:31:43 +00:00
parent 5a48b66dd6
commit ef572b992b
4 changed files with 39 additions and 1 deletions

31
lib.functions.lisp Normal file
View File

@@ -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))

View File

@@ -28,7 +28,7 @@
(fn parse-integers (input) (-> (string) list) (fn parse-integers (input) (-> (string) list)
(->> input (->> input
(uiop:split-string) (uiop:split-string)
(mapcar (lambda (s) (parse-integer s :junk-allowed t))) (mapcar #'parse-integer*)
(remove-if #'null))) (remove-if #'null)))
(fn read-integers () (-> nil list) (fn read-integers () (-> nil list)

View File

@@ -2,6 +2,7 @@
:depends-on (:deploy) :depends-on (:deploy)
:components ((:file "packages") :components ((:file "packages")
(:file "lib.macros") (:file "lib.macros")
(:file "lib.functions")
(:file "main")) (:file "main"))
:build-operation "deploy-op" :build-operation "deploy-op"
:build-pathname "odraw" :build-pathname "odraw"

View File

@@ -24,6 +24,12 @@
:while :while
:-> :fn)) :-> :fn))
(defpackage lib.functions
(:use :cl :lib.macros)
(:export
:range
:parse-integer*))
(defpackage main (defpackage main
(:use :cl :lib.macros) (:use :cl :lib.macros)
(:export :start)) (:export :start))