Safe Haskell | None |
---|---|
Language | Haskell2010 |
A reader for hledger's journal file format (http://hledger.org/MANUAL.html#the-journal-file). hledger's journal format is a compatible subset of c++ ledger's (http://ledger-cli.org/3.0/doc/ledger3.html#Journal-Format), so this reader should handle many ledger files as well. Example:
2012/3/24 gift expenses:gifts $10 assets:cash
Journal format supports the include directive which can read files in other formats, so the other file format readers need to be importable here. Some low-level journal syntax parsers which those readers also use are therefore defined separately in Hledger.Read.Common, avoiding import cycles.
- reader :: Reader
- genericSourcePos :: SourcePos -> GenericSourcePos
- parseAndFinaliseJournal :: ErroringJournalParser IO ParsedJournal -> Bool -> FilePath -> Text -> ExceptT String IO Journal
- runJournalParser :: Monad m => TextParser m a -> Text -> m (Either (ParseError Char MPErr) a)
- rjp :: Monad m => TextParser m a -> Text -> m (Either (ParseError Char MPErr) a)
- runErroringJournalParser :: Monad m => ErroringJournalParser m a -> Text -> m (Either String a)
- rejp :: Monad m => ErroringJournalParser m a -> Text -> m (Either String a)
- getParentAccount :: JournalParser m AccountName
- journalp :: MonadIO m => ErroringJournalParser m ParsedJournal
- directivep :: MonadIO m => ErroringJournalParser m ()
- defaultyeardirectivep :: JournalParser m ()
- marketpricedirectivep :: Monad m => JournalParser m MarketPrice
- datetimep :: JournalParser m LocalTime
- datep :: JournalParser m Day
- modifiedaccountnamep :: JournalParser m AccountName
- postingp :: MonadIO m => Maybe Day -> ErroringJournalParser m Posting
- statusp :: TextParser m Status
- emptyorcommentlinep :: JournalParser m ()
- followingcommentp :: JournalParser m Text
- accountaliasp :: TextParser m AccountAlias
- tests_Hledger_Read_JournalReader :: Test
Reader
Parsing utils
parseAndFinaliseJournal :: ErroringJournalParser IO ParsedJournal -> Bool -> FilePath -> Text -> ExceptT String IO Journal Source #
Given a megaparsec ParsedJournal parser, balance assertion flag, file path and file content: parse and post-process a Journal, or give an error.
runJournalParser :: Monad m => TextParser m a -> Text -> m (Either (ParseError Char MPErr) a) Source #
Run a journal parser with a null journal-parsing state.
rjp :: Monad m => TextParser m a -> Text -> m (Either (ParseError Char MPErr) a) Source #
Run a journal parser with a null journal-parsing state.
runErroringJournalParser :: Monad m => ErroringJournalParser m a -> Text -> m (Either String a) Source #
Run an error-raising journal parser with a null journal-parsing state.
rejp :: Monad m => ErroringJournalParser m a -> Text -> m (Either String a) Source #
Run an error-raising journal parser with a null journal-parsing state.
Parsers used elsewhere
journalp :: MonadIO m => ErroringJournalParser m ParsedJournal Source #
A journal parser. Accumulates and returns a ParsedJournal, which should be finalised/validated before use.
>>>
rejp (journalp <* eof) "2015/1/1\n a 0\n"
Right Journal with 1 transactions, 1 accounts
directivep :: MonadIO m => ErroringJournalParser m () Source #
Parse any journal directive and update the parse state accordingly. Cf http://hledger.org/manual.html#directives, http://ledger-cli.org/3.0/doc/ledger3.html#Command-Directives
defaultyeardirectivep :: JournalParser m () Source #
marketpricedirectivep :: Monad m => JournalParser m MarketPrice Source #
datetimep :: JournalParser m LocalTime Source #
Parse a date and time in YYYYMMDD HH:MM[:SS][+-ZZZZ] format. Hyphen (-) and period (.) are also allowed as date separators. The year may be omitted if a default year has been set. Seconds are optional. The timezone is optional and ignored (the time is always interpreted as a local time). Leading zeroes may be omitted (except in a timezone).
datep :: JournalParser m Day Source #
Parse a date in YYYYMMDD format. Hyphen (-) and period (.) are also allowed as separators. The year may be omitted if a default year has been set. Leading zeroes may be omitted.
modifiedaccountnamep :: JournalParser m AccountName Source #
> parsewith twoorthreepartdatestringp "2016/01/2"
Right "2016012" twoorthreepartdatestringp = do n1 <- some digitChar c <- datesepchar n2 <- some digitChar mn3 optional $ char c> some digitChar return $ n1 ++ c:n2 ++ maybe "" (c:) mn3
Parse an account name, then apply any parent account prefix and/or account aliases currently in effect.
statusp :: TextParser m Status Source #
emptyorcommentlinep :: JournalParser m () Source #
followingcommentp :: JournalParser m Text Source #
Parse a possibly multi-line comment following a semicolon.