[Kmymoney-devel] Re: Review Request: Fixes for problems when importing QIF files containing category/account sub-accounts
Allan Anderson
agander93 at gmail.com
Wed Jun 8 12:05:34 CEST 2011
> On June 8, 2011, 8:36 a.m., Thomas Baumgart wrote:
> > /trunk/extragear/office/kmymoney/kmymoney/converter/mymoneyqifreader.cpp, line 1462
> > <http://svn.reviewboard.kde.org/r/6705/diff/1/?file=46425#file46425line1462>
> >
> > Please keep coding style "} else {"
Yes, of course.
> On June 8, 2011, 8:36 a.m., Thomas Baumgart wrote:
> > /trunk/extragear/office/kmymoney/kmymoney/converter/mymoneyqifreader.cpp, line 1500
> > <http://svn.reviewboard.kde.org/r/6705/diff/1/?file=46425#file46425line1500>
> >
> > Is this some debug leftover?
Darn it. I spotted it when clearing up, couldn't understand what purpose it served, but
commented it out to test and make sure. Then left it in. :-(
Erm, see below.
> On June 8, 2011, 8:36 a.m., Thomas Baumgart wrote:
> > /trunk/extragear/office/kmymoney/kmymoney/converter/mymoneyqifreader.cpp, line 1503
> > <http://svn.reviewboard.kde.org/r/6705/diff/1/?file=46425#file46425line1503>
> >
> > Don't you want this to be inside the 'else if' part? Otherwise it could happen, that tr.m_strBrokerageAccount == tr.m_strInterestCategory and that does not seem to be right.
Not if the previous tmp.clear() is left in. If this is a genuine IntIncX with 'L[.....]' and the first path is taken, I clear out tmp so that tr.m_strInterestCategory is cleared below. Without the tmp.clear(), then, yes, tr.m_strBrokerageAccount == tr.m_strInterestCategory and that would not be right.
If, on the other hand, (!m_account.brokerageName().isEmpty()), then the transfer to brokerage occurs, and tr.m_strInterestCategory takes the contents of tmp.
So, with tmp.clear() left in, the code does what was intended. However, it could be done differently, if you prefer.
- Allan
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
http://svn.reviewboard.kde.org/r/6705/#review10216
-----------------------------------------------------------
On June 7, 2011, 7:44 p.m., Allan Anderson wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> http://svn.reviewboard.kde.org/r/6705/
> -----------------------------------------------------------
>
> (Updated June 7, 2011, 7:44 p.m.)
>
>
> Review request for kmymoney.
>
>
> Summary
> -------
>
> When importing a QIF investment file with Lcategory:sub-category, which
> indicates a sub-category for the transaction, the importation takes
> place without error. In the ledger view of the brokerage account all appears
> correct with the Category field or the Interest field displaying what appears
> to be Category:Sub-category.
>
> However when inspecting the category list it is evident that only a single
> new category has been created with the name of "Category:Sub-category" as
> one word and the transaction has been allocated to this category with
> nothing in the existing sub-category.
>
> The exact same transaction can be done manually with no error or
> newly created categories. This bug only occurs in QIF import of investments.
> The reason for this difference is that in imports, if the 'L' record is used
> to nominate a category, then there is no means by which to specify a
> transfer account.
>
> Looking at the reasons for these problems, two routines were found to be
> deficient. In mymoneystatementreader.cpp, the routine
> d->interestId(t_in.m_strInterestCategory)) was found not to recognise a
> category:sub-category structure already existing, and would create a new
> category named like 'category:sub-category'. When the categoryToAccount()
> routine was substituted, this recognised and found the correct existing
> sub-account, but did not create one if none existed.
>
> Then, in the QIF file in question, transactions of type IntInc were involved,
> and, once the category structure was correctly recognised, the categories
> created were created as income, when one of them should have been an expense.
> As it happened, the statements in question included quantity and price values,
> which KMM had decided were not relevant. As the quantity record showed the
> correct sign, changes were made to take notice of the quantity and price,
> in order to allow a decision to be made on whether a transaction should be
> an income or an expense. This should have no effect on others' files.
>
> To assist with the handling of 'L' records which were indicating a category,
> changes were made to use any existing brokerage account to supply/receive
> any monies. If no brokerage account already existed, the record would be
> left flagged as missing an assignment.
>
> MyMoneyStatementReader::Private::nameToId was rewritten to handle category
> sub-accounts, recognising existing ones and otherwise creating them.
>
>
> This addresses bug 274185.
> https://bugs.kde.org/show_bug.cgi?id=274185
>
>
> Diffs
> -----
>
> /trunk/extragear/office/kmymoney/kmymoney/converter/mymoneyqifreader.cpp 1235620
> /trunk/extragear/office/kmymoney/kmymoney/converter/mymoneystatementreader.cpp 1235620
>
> Diff: http://svn.reviewboard.kde.org/r/6705/diff
>
>
> Testing
> -------
>
> Imported several QIF files having varying formats, both real-life and
> constructed to contain mixtures of record types and category structure.
>
> atype run.
>
>
> Thanks,
>
> Allan
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mail.kde.org/pipermail/kmymoney-devel/attachments/20110608/7ed73190/attachment.htm
More information about the KMyMoney-devel
mailing list