[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