私はF#のLand of Lispという本を読んでいます(ええ、奇妙です、私は知っています)。彼らの最初の例のテキストアドベンチャーでは、グローバル変数の突然変異を利用しているので、それを避けたいと思います。私のモナドフーは弱いので、今私はこのように醜い状態通過をしています:
let pickUp player thing (objects: Map<Location, Thing list>) =
let objs = objects.[player.Location]
let attempt = objs |> List.partition (fun o -> o.Name = thing)
match attempt with
| [], _ -> "You cannot get that.", player, objs
| thing :: _, things ->
let player' = { player with Objects = thing :: player.Objects }
let msg = sprintf "You are now carrying %s %s" thing.Article thing.Name
msg, player', things
let player = { Location = Room; Objects = [] }
let objects =
[Room, [{ Name = "whiskey"; Article = "some" }; { Name = "bucket"; Article = "a" }];
Garden, [{ Name = "chain"; Article = "a length of" }]]
|> Map.ofList
let msg, p', o' = pickUp player "bucket" objects
// etc.
明示的な状態を除外して、より美しくするにはどうすればよいですか?(役立つ場合は、Stateモナドタイプにアクセスできると仮定します。F#にサンプルコードがあることを知っています。)