From 7b40ab6d7640c7216435ffa1e230534a93ca6168 Mon Sep 17 00:00:00 2001 From: Jason Walker Date: Mon, 2 Dec 2024 19:45:35 -0500 Subject: [PATCH] Add from-optional function --- library/optional.lisp | 9 +++++++++ library/prelude.lisp | 2 ++ 2 files changed, 11 insertions(+) diff --git a/library/optional.lisp b/library/optional.lisp index 7e38a3c00..e23bee9bd 100644 --- a/library/optional.lisp +++ b/library/optional.lisp @@ -7,6 +7,7 @@ (#:cell #:coalton-library/cell) (#:iter #:coalton-library/iterator)) (:export + #:from-optional #:from-some #:some? #:none?)) @@ -23,6 +24,14 @@ ;; Optional ;; + (declare from-optional (:a -> (Optional :a) -> :a)) + (define (from-optional def opt) + "Get the value of OPT, or return DEF if OPT is None." + (match opt + ((Some x) x) + ((None) def))) + + (declare from-some (String -> (Optional :a) -> :a)) (define (from-some str opt) "Get the value of OPT, erroring with the provided string if it is None." diff --git a/library/prelude.lisp b/library/prelude.lisp index f7756e22c..937d86e6f 100644 --- a/library/prelude.lisp +++ b/library/prelude.lisp @@ -130,10 +130,12 @@ (:import-from #:coalton-library/optional + #:from-optional #:from-some #:some? #:none?) (:export + #:from-optional #:from-some #:some? #:none?)