From: Amélia Coutard-Sander Date: Fri, 13 Dec 2024 16:30:03 +0000 (+0100) Subject: Grille immutable X-Git-Url: https://git.ameliathe1st.gay/?a=commitdiff_plain;h=a6eddeb3497c62edfc6125ea1c11ab40bee7c7fa;p=cells.git Grille immutable --- diff --git a/automata/automata.ml b/automata/automata.ml index 968298a..e8a665f 100644 --- a/automata/automata.ml +++ b/automata/automata.ml @@ -40,7 +40,13 @@ let initial (type t) (m : (module Automaton with type t = t)) = let get x y (d, board) = if x < 0 || 63 < x || y < 0 || 63 < y then d else board.(x).(y) -let set x y c (_, board) = if x < 0 || 63 < x || y < 0 || 63 < y then () else board.(x).(y) <- c +let set x y c ((d, cells) as board) = + if x < 0 || 63 < x || y < 0 || 63 < y + then board + else + let res = Array.init 64 (fun x -> Array.init 64 (fun y -> cells.(x).(y))) in + res.(x).(y) <- c; + (d, res) let update (type t) (m : (module Automaton with type t = t)) ((d, cells) as board) = let module M = (val m) in diff --git a/automata/automata.mli b/automata/automata.mli index 2e1d96a..7d3aa7b 100644 --- a/automata/automata.mli +++ b/automata/automata.mli @@ -37,7 +37,7 @@ val initial : (module Automaton with type t = 't) -> 't board val get : int -> int -> 't board -> 't -val set : int -> int -> 't -> 't board -> unit +val set : int -> int -> 't -> 't board -> 't board val update : (module Automaton with type t = 't) -> 't board -> 't board diff --git a/bin/main.ml b/bin/main.ml index 0c2c005..3b86105 100644 --- a/bin/main.ml +++ b/bin/main.ml @@ -13,7 +13,7 @@ * with this program. If not, see . *) -type 't interface_state = { x: int; y: int; current: 't; running: bool } +type 't interface_state = { x: int; y: int; current: 't } let render (type t) @@ -43,44 +43,37 @@ let inputs (m : (module Automata.Automaton with type t = t)) (board : t Automata.board) (inter : t interface_state) = + let set_current inter = Automata.set inter.x inter.y inter.current in + let chpos dx dy ({ x; y; _ } as inter) = { inter with x = x + dx; y = y + dy } in + let chcur f ({ current; _ } as inter) = { inter with current = f current } in let module M = (val m) in if Graphics.key_pressed () then match Graphics.read_key () with - | ' ' -> - Automata.set inter.x inter.y inter.current board; - inter - | 'a' -> { inter with current = M.prev inter.current } - | 'e' -> { inter with current = M.next inter.current } - | 'z' -> { inter with y = inter.y + 1 } - | 'q' -> { inter with x = inter.x - 1 } - | 's' -> { inter with y = inter.y - 1 } - | 'd' -> { inter with x = inter.x + 1 } - | 'Z' -> - Automata.set inter.x inter.y inter.current board; - { inter with y = inter.y + 1 } - | 'Q' -> - Automata.set inter.x inter.y inter.current board; - { inter with x = inter.x - 1 } - | 'S' -> - Automata.set inter.x inter.y inter.current board; - { inter with y = inter.y - 1 } - | 'D' -> - Automata.set inter.x inter.y inter.current board; - { inter with x = inter.x + 1 } - | '\t' -> { inter with running = true } - | _ -> inter - else inter + | ' ' -> (Automata.set inter.x inter.y inter.current board, inter) + | 'a' -> (board, chcur M.prev inter) + | 'e' -> (board, chcur M.next inter) + | 'z' -> (board, chpos 0 1 inter) + | 'q' -> (board, chpos (-1) 0 inter) + | 's' -> (board, chpos 0 (-1) inter) + | 'd' -> (board, chpos 1 0 inter) + | 'Z' -> (set_current inter board, chpos 0 1 inter) + | 'Q' -> (set_current inter board, chpos (-1) 0 inter) + | 'S' -> (set_current inter board, chpos 0 (-1) inter) + | 'D' -> (set_current inter board, chpos 1 0 inter) + | '\t' -> (Automata.update m board, inter) + | _ -> (board, inter) + else (board, inter) let run (type t) (m : (module Automata.Automaton with type t = t)) = let module M = (val m) in let rec aux board inter = render m board inter; Graphics.synchronize (); - let inter = inputs m board inter in - aux (if inter.running then Automata.update m board else board) { inter with running = false } + let board, inter = inputs m board inter in + aux board inter in - aux (Automata.initial m) { x = 0; y = 0; current = M.default; running = false } + aux (Automata.initial m) { x = 0; y = 0; current = M.default } let () = Graphics.open_graph "";