{-# LANGUAGE BlockArguments #-} {-# LANGUAGE DisambiguateRecordFields #-} {-# LANGUAGE OverloadedRecordDot #-} {-# LANGUAGE OverloadedStrings #-} module Issue (Issue (..), fromMatch) where import Data.Text (Text) import Data.Text qualified as T import Issue.Tag (Tag) import Issue.Tag qualified as I import Issue.Text qualified as I import TreeGrepper.Match (Match (..)) import TreeGrepper.Match qualified as G import TreeGrepper.Result (Result (..)) import TreeGrepper.Result qualified as G data Issue = Issue { title :: Text, description :: Maybe Text, start :: G.Position, end :: G.Position, tags :: [Tag], internalTags :: [Tag] } fromMatch :: G.Result -> G.Match -> Maybe Issue fromMatch result match = if T.isPrefixOf marker title' then Just Issue { title = title, description = stripTags <$> description, start = match.start, end = match.end, tags = maybe [] I.extractTags description, internalTags = I.internalTags title } else Nothing where (title', description) = I.extractText result.file_type match.text title = stripMarker title' marker :: Text marker = "TODO" stripMarker :: Text -> Text stripMarker text = maybe text T.stripStart (T.stripPrefix marker text) stripTags :: Text -> Text stripTags text = T.strip (T.unlines (filter (not . T.isPrefixOf "@") (T.lines text)))