1 {-# LANGUAGE FlexibleContexts #-}
2 {-# LANGUAGE OverloadedStrings #-}
4 module Text.Edifact.Fetcher.Configuration
5 ( -- * Fetching environment
9 -- * Shortcuts for reading the environment
15 import Text.Edifact.Scaffolder.Commons (MessageCode, Revision,
18 import Control.Monad.Reader.Class (MonadReader, asks)
19 import Data.List.NonEmpty (NonEmpty, nonEmpty)
20 import Text.Parsec (char, parse, sepBy1)
22 data FetchingEnv = FetchingEnv { fetchingRevision :: Revision
23 , specificationHome :: FilePath
24 , selectedMessages :: Maybe (NonEmpty MessageCode)
27 getTargetRevision :: MonadReader FetchingEnv m => m Revision
28 getTargetRevision = asks fetchingRevision
30 getHome :: MonadReader FetchingEnv m => m FilePath
31 getHome = asks specificationHome
33 getSelectedMessages :: MonadReader FetchingEnv m => m (Maybe (NonEmpty MessageCode))
34 getSelectedMessages = asks selectedMessages
36 readSelectMessages :: Maybe String -> Maybe (NonEmpty MessageCode)
37 readSelectMessages value =
38 let tryParse p s = toMaybe . parse p s
39 toMaybe (Right v) = Just v
41 messageCodesParser = messageCodeParser `sepBy1` comma
43 in value >>= tryParse messageCodesParser "" >>= nonEmpty