From f459f2cad4759ab1e9383b0948ba77b90d5d6991 Mon Sep 17 00:00:00 2001 From: Sufiyan Adhikari Date: Tue, 22 Dec 2020 13:17:14 +0530 Subject: [PATCH] Use empty posting while balancing imported entry If an empty posting i.e., one without an amount, is entered by hand, it should be used to balance the transaction instead of a FIXME posting. --- .../source/generic_importer_source.py | 37 ++++++++++++++----- 1 file changed, 28 insertions(+), 9 deletions(-) diff --git a/beancount_import/source/generic_importer_source.py b/beancount_import/source/generic_importer_source.py index c7ef1b2a..52c6c4fb 100644 --- a/beancount_import/source/generic_importer_source.py +++ b/beancount_import/source/generic_importer_source.py @@ -139,21 +139,40 @@ def get_info(raw_entry: Directive) -> dict: line=raw_entry.meta['lineno'], ) +def _none_units_posting_index(txn:Transaction): + """Index of posting with None units""" + for i, posting in enumerate(txn.postings): + if posting.units is None: + return i + def balance_amounts(txn:Transaction)-> None: """Add FIXME account for the remaing amount to balance accounts""" inventory = SimpleInventory() + i = _none_units_posting_index(txn) for posting in txn.postings: inventory += posting.units for currency in inventory: - txn.postings.append( - Posting( - account=FIXME_ACCOUNT, - units=Amount(currency=currency, number=-inventory[currency]), - cost=None, - price=None, - flag=None, - meta={}, - )) + if not inventory[currency]: # if amount already balanced + continue + if i is not None: + # use empty posting to balance amount instead of FIXME + none_posting = txn.postings[i] + txn.postings.append( + none_posting._replace( + units=Amount(currency=currency, number=-inventory[currency]) + )) + else: + txn.postings.append( + Posting( + account=FIXME_ACCOUNT, + units=Amount(currency=currency, number=-inventory[currency]), + cost=None, + price=None, + flag=None, + meta={}, + )) + if i is not None: + txn.postings.pop(i) # remove the None posting after balancing def load(spec, log_status):