aboutsummaryrefslogtreecommitdiff
path: root/main.lisp
blob: 674d09c532487e2e9b73bd445353d17a6bd7ae95 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
;;; main.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:

;; Implementation of `main' package.  Defines the entrypoint of the program,
;; handling any input from the user and passing it into the system.

;;; Code:

(in-package :main)

(fn read-input (&optional (prompt "> "))
    (-> (&optional string) string)
  (format t "~a" prompt)
  (force-output)
  (read-line))

(fn read-integers ()
    (-> nil list)
  (->> (read-input "Enter numbers: ")
       (uiop:split-string)
       (mapcar (lambda (s) (parse-integer s :junk-allowed t)))
       (remove-if #'null)))

(fn read-until-integers ()
    (-> nil list)
  (let ((inp (read-integers)))
    (while (null inp)
      (format t "Need at least one integer...~%")
      (setq inp (read-integers)))
    inp))

(defun start ()
  (--> (read-until-integers)
       (format t "~a = ~a~%" (cons '+ _) (reduce #'+ _))))