module Game.Chess.Tree where import Data.Tree ( Tree(Node), Forest ) 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