Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add the --until=YYYY-MM-DD option #19

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 23 additions & 7 deletions Main.hs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import Control.Monad
import Data.List ( sortOn )
import Data.Maybe
import qualified Data.Text as T
import Data.Time
import Data.Version
import System.Console.GetOpt
import System.Environment
Expand All @@ -28,6 +29,7 @@ data Options = Options
, optDCC :: Maybe DayCountConvention
, optRate :: Maybe Rate
, optBalanceToday :: Bool
, optBalanceUntil :: Maybe String
, optIgnoreAssertions :: Bool
}

Expand All @@ -42,6 +44,7 @@ defaultOptions = Options
, optDCC = Nothing
, optRate = Nothing
, optBalanceToday = False
, optBalanceUntil = Nothing
, optIgnoreAssertions = False
}

Expand All @@ -52,7 +55,8 @@ options =
, Option ['v'] ["verbose"] (NoArg (\o -> o { optVerbose = True })) "echo input ledger to stdout (default)"
, Option ['q'] ["quiet"] (NoArg (\o -> o { optVerbose = False })) "don't echo input ledger to stdout"
, Option [] ["today"] (NoArg (\o -> o { optBalanceToday = True })) "compute interest up until today"
, Option ['f'] ["file"] (ReqArg (\f o -> o { optInput = f : optInput o }) "FILE") "input ledger file (pass '-' for stdin)"
, Option [] ["until"] (ReqArg (\d o -> o { optBalanceUntil = Just d}) "YYYY-MM-DD") "compute interest up until the given date"
, Option ['f'] ["file"] (ReqArg (\f o -> o { optInput = f : optInput o }) "FILE") "input ledger file (pass '-' for stdin)"
, Option ['s'] ["source"] (ReqArg (\a o -> o { optSourceAcc = a }) "ACCOUNT") "interest source account"
, Option ['t'] ["target"] (ReqArg (\a o -> o { optTargetAcc = a }) "ACCOUNT") "interest target account"
, Option ['I'] ["ignore-assertions"] (NoArg (\o -> o { optIgnoreAssertions = True })) "ignore any failing balance assertions"
Expand All @@ -78,7 +82,7 @@ commandLineError err = do hPutStrLn stderr (err ++ usageMessage)

parseOpts :: [String] -> IO (Options, [String])
parseOpts argv =
case getOpt Permute options argv of
case System.Console.GetOpt.getOpt Permute options argv of
(o,n,[] ) -> return (foldl (flip id) defaultOptions o, n)
(_,_,errs) -> commandLineError (concat errs)

Expand All @@ -91,6 +95,20 @@ main = bracket (return ()) (\() -> hFlush stdout >> hFlush stderr) $ \() -> do
when (null (optTargetAcc opts)) (commandLineError "required --target option is missing\n")
when (isNothing (optDCC opts)) (commandLineError "no day counting convention specified\n")
when (isNothing (optRate opts)) (commandLineError "no interest rate specified\n")
mbComputeInterestUntil <-
case optBalanceUntil opts of
Just untilStr
| optBalanceToday opts ->
commandLineError "Specify either --today or --until=YYYY-MM-DD.\n"
| otherwise -> do
let fmt = "%Y-%-m-%-d"
case parseTimeM True defaultTimeLocale fmt untilStr :: Maybe Day of
Nothing -> commandLineError $ "Can't parse the specified --until date." ++
" Make sure it has the format " ++ fmt ++ ".\n"
Just day -> pure $ Just day
Nothing
| optBalanceToday opts -> Just <$> getCurrentDay
| otherwise -> return Nothing
let ledgerInputOptions = definputopts { balancingopts_ = (balancingopts_ definputopts) { ignore_assertions_ = optIgnoreAssertions opts } }
jnl' <- runExceptT (readJournalFiles ledgerInputOptions (reverse (optInput opts))) >>= either fail return
interestAcc <- case args of
Expand All @@ -106,11 +124,9 @@ main = bracket (return ()) (\() -> hFlush stdout >> hFlush stderr) $ \() -> do
, dayCountConvention = fromJust (optDCC opts)
, interestRate = fromJust (optRate opts)
}
thisDay <- getCurrentDay
let finalize
| optBalanceToday opts = computeInterest thisDay
| otherwise = return ()
ts' = runComputer cfg (mapM_ processTransaction ts >> finalize)
let ts' = runComputer cfg $ do
mapM_ processTransaction ts
mapM_ computeInterest mbComputeInterestUntil
result
| optVerbose opts = ts' ++ ts
| otherwise = ts'
Expand Down