Versionbump: Template Haskell in System.FilePath.Glob.TH

This commit is contained in:
Stephan Barth 2024-02-11 14:36:42 +01:00
parent b054d3cbdd
commit 0d40f85634

View File

@ -21,13 +21,13 @@ import qualified Data.Map.Strict as Map
deriving instance Lift CompOptions
patternFile' :: CompOptions -> FilePath -> TExpQ (Map Text Pattern)
patternFile' opts file = do
patternFile' :: CompOptions -> FilePath -> Code Q (Map Text Pattern)
patternFile' opts file = liftCode $ do
qAddDependentFile file
patternStrings <- runIO $ filter (not . isComment) . Text.lines <$> Text.readFile file
unsafeTExpCoerce . appE [e|Map.fromList|] . listE $ map (\pat'@(Text.unpack -> pat) -> [e|(pat', compileWith opts pat)|]) patternStrings
patternFile :: CompOptions -> FilePath -> TExpQ [Pattern]
patternFile :: CompOptions -> FilePath -> Code Q [Pattern]
patternFile opts file = [||Map.elems $$(patternFile' opts file)||]
isComment :: Text -> Bool