aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAryadev Chavali <aryadev@aryadevchavali.com>2025-02-14 17:01:12 +0000
committerAryadev Chavali <aryadev@aryadevchavali.com>2025-02-14 17:17:43 +0000
commit76a70172464f054a3ff3d0d51642a143d76ec31a (patch)
tree3886fb4d75b45431f9bfb27a097c0b42a295a7de
parentf4b43031adf1094d007ce9e44b191255909d178c (diff)
downloadcantedraw-76a70172464f054a3ff3d0d51642a143d76ec31a.tar.gz
cantedraw-76a70172464f054a3ff3d0d51642a143d76ec31a.tar.bz2
cantedraw-76a70172464f054a3ff3d0d51642a143d76ec31a.zip
Implement some simple converters for custom types to/from integers
Given n in 0..51, certainly there exists r, s s.t. `n = 13s + r` where r in 0..12 and s in 0..3. `r` is the rank, and `s` is the suit. ranks are ordered Ace, 2, 3, ..., Queen, King and suits are ordered Diamond, Club, Heart, Spade. Therefore there is a 1-1 correspondence between 0..51 and any card in the deck. Jokers are a bit less straightforward; for now I'll define them as an outlier which doesn't exist in the same bounds (which is why they're the default return for suit in int->suit). Likely I'll go for -1 representing a Joker.
-rw-r--r--model.lisp41
-rw-r--r--packages.lisp8
2 files changed, 48 insertions, 1 deletions
diff --git a/model.lisp b/model.lisp
index 7ce8b99..6554e80 100644
--- a/model.lisp
+++ b/model.lisp
@@ -35,3 +35,44 @@
(deftype cardset () `(and list (satisfies cardsetp)))
+(fn int->suit (n) (-> (int-card) suit)
+ (case (floor n 13)
+ (0 :Diamonds)
+ (1 :Clubs)
+ (2 :Hearts)
+ (3 :Spades)
+ (t :Joker)))
+
+(fn suit->int (item) (-> (suit) (integer 0 4))
+ (case item
+ (:Diamonds 0)
+ (:Clubs 1)
+ (:Hearts 2)
+ (:Spades 3)
+ (t 4)))
+
+(fn int->rank (n) (-> (int-card) rank)
+ (case (mod n 13)
+ (0 :Ace)
+ (10 :Jack)
+ (11 :Queen)
+ (12 :King)
+ (t (+ n 1))))
+
+(fn rank->int (rank) (-> (rank) (integer 0 12))
+ (case rank
+ (:Ace 0)
+ (:Jack 10)
+ (:Queen 11)
+ (:King 12)
+ (t (- rank 1))))
+
+(fn int->card (num) (-> (int-card) card)
+ (cons (int->rank num)
+ (int->suit num)))
+
+(fn card->int (card) (-> (card) int-card)
+ (destructuring-bind (rank . suit) card
+ (->> (suit->int suit)
+ (* 13)
+ (+ (rank->int rank)))))
diff --git a/packages.lisp b/packages.lisp
index cd99262..386abe1 100644
--- a/packages.lisp
+++ b/packages.lisp
@@ -34,7 +34,13 @@
(defpackage cantedraw.model
(:use :cl :cantedraw.lib.macros :cantedraw.lib.functions)
- (:export :int-card :rank :suit :card :cardset))
+ (:export
+ ;; Types
+ :int-card :rank :suit :card :cardset
+ ;; Converters
+ :int->suit :int->rank :int->card
+ :suit->int :rank->int :card->int
+ ))
(defpackage cantedraw.main
(:use :cl :cantedraw.lib.macros :cantedraw.lib.functions)