Sha256: 8e9293efb6f075fff7ae47b269669aee38062b43c005e1bddb3d5a2ca582a3c1

Contents?: true

Size: 1.38 KB

Versions: 101

Compression:

Stored size: 1.38 KB

Contents

open Core.Std
open React

let allowed_failures = 9

type progress =
    | Win
    | Lose
    | Busy of int

type t = {
    send_feed : ?step:React.step -> char -> unit;
    masked_word_s : string signal;
    progress_s : progress signal;
}

let feed c { send_feed; _ } = send_feed c
let masked_word { masked_word_s; _ } = masked_word_s
let progress { progress_s; _ } = progress_s

let calc_failures target tried =
    let rec go fails target' = function
        | h :: t when Char.Set.mem target' h ->
            go fails (Char.Set.remove target' h) t
        | _ :: t -> go (fails+1) target' t
        | [] -> fails
    in go 0 target tried

let mask_word word tried =
    let tried' = Char.Set.of_list tried in
    String.map ~f:(function c when Set.mem tried' c -> c | _ -> '_') word

let calc_progress masked_word failures =
    if failures > allowed_failures then
        Lose
    else if not (String.mem masked_word '_') then
        Win
    else
        Busy (allowed_failures - failures)

let create word =
    let target = String.to_list word |> Char.Set.of_list in
    let feed_e, send_feed = E.create () in
    let tried_s = S.fold (fun t h -> h :: t) [] feed_e in
    let failures_s = S.map (calc_failures target) tried_s in
    let masked_word_s = S.map (mask_word word) tried_s in
    let progress_s = S.l2 calc_progress masked_word_s failures_s in
    { send_feed; masked_word_s; progress_s }

Version data entries

101 entries across 101 versions & 1 rubygems

Version Path
trackler-2.1.0.21 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.20 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.19 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.18 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.17 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.16 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.15 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.14 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.13 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.12 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.11 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.10 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.9 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.8 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.7 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.6 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.5 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.4 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.3 tracks/ocaml/exercises/hangman/example.ml
trackler-2.1.0.2 tracks/ocaml/exercises/hangman/example.ml