module Game.Chess.Tree (positionTree, positionForest, plyTree, plyForest) where import Data.Tree (Forest, Tree (Node)) import Game.Chess.Internal positionTree :: Position -> Tree Position positionTree pos = Node pos $ positionForest pos positionForest :: Position -> Forest Position positionForest pos = positionTree . unsafeDoPly pos <$> legalPlies pos plyForest :: Position -> Forest Ply plyForest pos = plyTree pos <$> legalPlies pos plyTree :: Position -> Ply -> Tree Ply plyTree pos ply = Node ply . plyForest $ unsafeDoPly pos ply