2013-09-20 20:38:54 +04:00
|
|
|
#!/usr/bin/env runhaskell
|
|
|
|
{-
|
|
|
|
|
|
|
|
Like ledger's equity command, print a journal entry posting the total
|
|
|
|
balance of all accounts (or the specified account and its subaccounts)
|
|
|
|
in the default journal.
|
|
|
|
|
|
|
|
An entry like this is useful in the transition to a new journal file,
|
|
|
|
to zero out asset/liability balances in the old file and initialise
|
|
|
|
them in the new one. This way you get correct balances when reporting
|
|
|
|
on either file, and when including both files at once.
|
|
|
|
|
|
|
|
Usage: hledger-equity [ACCTPAT]
|
|
|
|
-}
|
2014-02-08 02:05:13 +04:00
|
|
|
|
2014-07-15 18:02:14 +04:00
|
|
|
import Data.Maybe (fromMaybe)
|
2013-09-20 20:38:54 +04:00
|
|
|
import Hledger.Cli
|
|
|
|
|
2014-04-14 23:03:52 +04:00
|
|
|
argsmode :: Mode RawOpts
|
|
|
|
argsmode = (defCommandMode ["equity"])
|
|
|
|
{ modeHelp = "print a journal entry posting the total balance of all accounts"
|
|
|
|
++ " (or the specified account and its subaccounts)"
|
|
|
|
, modeGroupFlags = Group
|
|
|
|
{ groupNamed =
|
|
|
|
[ ("Input",inputflags)
|
|
|
|
, ("Reporting",reportflags)
|
|
|
|
, ("Misc",helpflags)
|
|
|
|
]
|
|
|
|
, groupUnnamed = []
|
|
|
|
, groupHidden = []
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
main :: IO ()
|
2013-09-20 20:38:54 +04:00
|
|
|
main = do
|
2014-04-14 23:03:52 +04:00
|
|
|
opts <- getCliOpts argsmode
|
|
|
|
withJournalDo opts $
|
|
|
|
\CliOpts{reportopts_=ropts} j -> do
|
2014-07-15 18:02:14 +04:00
|
|
|
today <- getCurrentDay
|
2014-04-14 23:03:52 +04:00
|
|
|
let ropts_ = ropts{flat_=True}
|
2014-07-15 18:02:14 +04:00
|
|
|
q = queryFromOpts today ropts_
|
|
|
|
(acctbals,_) = balanceReport ropts_ q j
|
|
|
|
balancingamt = negate $ sum $ map (\((_,_,_),b) -> b) acctbals
|
|
|
|
ps = [posting{paccount=a, pamount=b} | ((a,_,_),b) <- acctbals]
|
2014-04-14 23:03:52 +04:00
|
|
|
++ [posting{paccount="equity:opening balances", pamount=balancingamt}]
|
2014-07-15 18:02:14 +04:00
|
|
|
enddate = fromMaybe today $ queryEndDate (date2_ ropts_) q
|
2014-07-24 04:16:13 +04:00
|
|
|
nps = [posting{paccount=a, pamount=negate b} | ((a,_,_),b) <- acctbals]
|
|
|
|
++ [posting{paccount="equity:closing balances", pamount=negate balancingamt}]
|
|
|
|
putStr $ showTransactionUnelided (nulltransaction{tdate=enddate, tpostings=nps})
|
|
|
|
putStr $ showTransactionUnelided (nulltransaction{tdate=enddate, tpostings=ps})
|