{-# LANGUAGE LambdaCase #-} module Text.Docvim.Visitor.Mapping (extractMapping) where import Control.Applicative import Text.Docvim.AST import Text.Docvim.Visitor -- | Extracts a list of nodes (if any exist) identified by the `@mapping` -- annotation of the source code. extractMapping :: Alternative f => [Node] -> (f [Node], [Node]) extractMapping = extractBlocks f where f = \case MappingAnnotation _ -> Just endSection _ -> Nothing