From 85dd6befe9f37a204ce7c330ab9bb79de03c8fba Mon Sep 17 00:00:00 2001 From: Francois Andriot Date: Sun, 15 Jan 2012 21:59:56 +0100 Subject: RHEL/Fedora: adds working 'kmymoney' --- .../kmymoney/kmymoney-3.5.13-update_to_1.0.5.patch | 264 +++++++++++++++++++++ 1 file changed, 264 insertions(+) create mode 100644 redhat/applications/kmymoney/kmymoney-3.5.13-update_to_1.0.5.patch (limited to 'redhat/applications/kmymoney/kmymoney-3.5.13-update_to_1.0.5.patch') diff --git a/redhat/applications/kmymoney/kmymoney-3.5.13-update_to_1.0.5.patch b/redhat/applications/kmymoney/kmymoney-3.5.13-update_to_1.0.5.patch new file mode 100644 index 000000000..7aefe2026 --- /dev/null +++ b/redhat/applications/kmymoney/kmymoney-3.5.13-update_to_1.0.5.patch @@ -0,0 +1,264 @@ +commit 8654cea10f6902719006d5975db7dc07b2fcc713 +Author: Timothy Pearson +Date: 1326571732 -0600 + + Update to upstream stable version 1.0.5 + +diff --git a/ChangeLog b/ChangeLog +index d250496..c996acb 100644 +--- a/ChangeLog ++++ b/ChangeLog +@@ -1,7 +1,40 @@ + ++2010-05-15 Thomas Baumgart ++ * Released 1.0.5 ++ ++2010-05-12 Thomas Baumgart ++ * Fixed the way to calculate balance variation for the linear regression ++ forecast method (backported from KDE4) ++ ++2010-05-09 Alvaro Soliverez ++ * Fixed a crash when a budget selected for a report is no longer present ++ ++2010-05-04 Thomas Baumgart ++ * replace all new line characters because we only have one line ++ available for the displayed data (backported from KDE4) ++ * Don't allow import of investment transactions that don't have a share ++ amount. This used to end in a div by zero when calculating the price. ++ (Backported from KDE4) ++ ++2010-05-03 Alvaro Soliverez ++ * Add all overdue schedules when calculating forecast ++ * Do not show accounts of institutions if it has been selected ++ in the general settings to Do not show closed accounts ++ * Do not show an institution if it has no visible accounts and ++ it has been selected to not show closed accounts ++ ++2010-04-20 Thomas Baumgart ++ * Backported fix from Ian Neal to solve problems when opening the ledger ++ with specific scheduled transactions ++ ++2010-04-03 Alvaro Soliverez ++ * Fixed loop in payments of the home page when a schedule is set to ++ end by date ++ + 2010-03-30 Thomas Baumgart + * Backported encoding patch from KDE4 version + * Bumped version number ++ * Released 1.0.4 + + 2010-03-29 Thomas Baumgart + * Updated Finnish translation by Mikael Kujanpaa +diff --git a/configure.in b/configure.in +index 8a6c1b8..1a8dd02 100644 +--- a/configure.in ++++ b/configure.in +@@ -40,7 +40,7 @@ dnl Perform program name transformation + AC_ARG_PROGRAM + + dnl Automake doc recommends to do this only here. (Janos) +-AM_INIT_AUTOMAKE(kmymoney2, 1.0.4) dnl searches for some needed programs ++AM_INIT_AUTOMAKE(kmymoney2, 1.0.5) dnl searches for some needed programs + + KDE_SET_PREFIX + +diff --git a/configure.in.in b/configure.in.in +index 3f82103..a90f40f 100644 +--- a/configure.in.in ++++ b/configure.in.in +@@ -1,6 +1,6 @@ + #MIN_CONFIG(3.3.1) + +-AM_INIT_AUTOMAKE(kmymoney2,1.0.4) ++AM_INIT_AUTOMAKE(kmymoney2,1.0.5) + + KDE_ENABLE_HIDDEN_VISIBILITY + +diff --git a/kmymoney2/converter/mymoneystatementreader.cpp b/kmymoney2/converter/mymoneystatementreader.cpp +index 6756767..c08dcff 100644 +--- a/kmymoney2/converter/mymoneystatementreader.cpp ++++ b/kmymoney2/converter/mymoneystatementreader.cpp +@@ -664,6 +664,10 @@ void MyMoneyStatementReader::processTransactionEntry(const MyMoneyStatement::Tra + if(!t_in.m_price.isZero()) { + s1.setPrice(t_in.m_price); + } else { ++ if(t_in.m_shares.isZero()) { ++ KMessageBox::information(0, i18n("This imported statement contains investment transactions with no share amount. These transactions will be ignored."), i18n("No share amount provided"), TQString("BlankAmount")); ++ return; ++ } + s1.setPrice(((t_in.m_amount - t_in.m_fees) / t_in.m_shares).convert(MyMoneyMoney::precToDenom(KMyMoneyGlobalSettings::pricePrecision()))); + } + +diff --git a/kmymoney2/mymoney/mymoneyforecast.cpp b/kmymoney2/mymoney/mymoneyforecast.cpp +index bfecce0..c1c88c7 100644 +--- a/kmymoney2/mymoney/mymoneyforecast.cpp ++++ b/kmymoney2/mymoney/mymoneyforecast.cpp +@@ -651,7 +651,7 @@ void MyMoneyForecast::addScheduledTransactions (void) + TQValueList schedule; + + schedule = file->scheduleList("", MyMoneySchedule::TYPE_ANY, MyMoneySchedule::OCCUR_ANY, MyMoneySchedule::STYPE_ANY, +- TQDate::tqcurrentDate(), forecastEndDate()); ++ TQDate(), forecastEndDate()); + if(schedule.count() > 0) { + TQValueList::Iterator it; + do { +@@ -871,8 +871,21 @@ MyMoneyMoney MyMoneyForecast::accountCycleVariation(const MyMoneyAccount& acc) + MyMoneyMoney cycleVariation; + + if (forecastMethod() == eHistoric) { +- for(int t_day = 1; t_day <= accountsCycle() ; ++t_day) { +- cycleVariation += m_accountTrendList[acc.id()][t_day]; ++ switch(historyMethod()) { ++ case 0: ++ case 1: ++ { ++ for(int t_day = 1; t_day <= accountsCycle() ; ++t_day) { ++ cycleVariation += m_accountTrendList[acc.id()][t_day]; ++ } ++ } ++ break; ++ ++ case 2: ++ { ++ cycleVariation = m_accountList[acc.id()][TQDate::currentDate().addDays(accountsCycle())] - m_accountList[acc.id()][TQDate::currentDate()]; ++ } ++ break; + } + } + return cycleVariation; +diff --git a/kmymoney2/reports/pivottable.cpp b/kmymoney2/reports/pivottable.cpp +index db73062..b75ffb9 100644 +--- a/kmymoney2/reports/pivottable.cpp ++++ b/kmymoney2/reports/pivottable.cpp +@@ -825,9 +825,27 @@ void PivotTable::calculateBudgetMapping( void ) + // + // It will choose the first budget in the list for the start year of the report if no budget is select + MyMoneyBudget budget = MyMoneyBudget(); ++ ++ TQValueList budgets = file->budgetList(); ++ bool validBudget = false; ++ ++ //check that the selected budget is valid ++ if (m_config_f.budget() != "Any") { ++ TQValueList::const_iterator budgets_it = budgets.begin(); ++ while( budgets_it != budgets.end() ) { ++ //pick the budget by id ++ if ((*budgets_it).id() == m_config_f.budget()) { ++ budget = file->budget((*budgets_it).id()); ++ validBudget = true; ++ break; ++ } ++ ++budgets_it; ++ } ++ } ++ + //if no budget has been selected +- if (m_config_f.budget() == "Any" ) { +- TQValueList budgets = file->budgetList(); ++ if (!validBudget ) { ++ + TQValueList::const_iterator budgets_it = budgets.begin(); + while( budgets_it != budgets.end() ) { + //pick the first budget that matches the report start year +@@ -843,9 +861,6 @@ void PivotTable::calculateBudgetMapping( void ) + + //assign the budget to the report + m_config_f.setBudget(budget.id(), m_config_f.isIncludingBudgetActuals()); +- } else { +- //pick the budget selected by the user +- budget = file->budget( m_config_f.budget()); + } + + // Dump the budget +diff --git a/kmymoney2/views/kgloballedgerview.cpp b/kmymoney2/views/kgloballedgerview.cpp +index 8209d3f..e82459a 100644 +--- a/kmymoney2/views/kgloballedgerview.cpp ++++ b/kmymoney2/views/kgloballedgerview.cpp +@@ -485,7 +485,12 @@ void KGlobalLedgerView::loadView(void) + break; + + // for all others, we check if the next payment date is still 'in range' +- s.setNextDueDate(s.nextPayment(s.nextDueDate())); ++ TQDate nextDueDate = s.nextPayment(s.nextDueDate()); ++ if (nextDueDate.isValid()) { ++ s.setNextDueDate(nextDueDate); ++ } else { ++ break; ++ } + } + scheduleList.pop_front(); + } +diff --git a/kmymoney2/views/khomeview.cpp b/kmymoney2/views/khomeview.cpp +index 60bb173..8745d64 100644 +--- a/kmymoney2/views/khomeview.cpp ++++ b/kmymoney2/views/khomeview.cpp +@@ -595,6 +595,13 @@ void KHomeView::showPayments(void) + schedule.remove(it); + continue; + } ++ ++ //if nextPayment returns an invalid date, setNextDueDate will just skip it, resulting in a loop ++ //we check the resulting date and erase the schedule if invalid ++ if(!((*it).nextPayment((*it).nextDueDate())).isValid()) { ++ schedule.remove(it); ++ continue; ++ } + + (*it).setNextDueDate((*it).nextPayment((*it).nextDueDate())); + qBubbleSort(schedule); +diff --git a/kmymoney2/views/kinstitutionsview.cpp b/kmymoney2/views/kinstitutionsview.cpp +index 0b9258f..87c0fc1 100644 +--- a/kmymoney2/views/kinstitutionsview.cpp ++++ b/kmymoney2/views/kinstitutionsview.cpp +@@ -161,6 +161,9 @@ void KInstitutionsView::loadAccounts(void) + + // hide it, if unused + noInstitutionItem->setVisible(noInstitutionItem->childCount() != 0); ++ ++ bool showClosedAccounts = kmymoney2->toggleAction("view_show_all_accounts")->isChecked() ++ || !KMyMoneyGlobalSettings::hideClosedAccounts(); + + TQValueList list = file->institutionList(); + TQValueList::const_iterator it_i; +@@ -168,6 +171,8 @@ void KInstitutionsView::loadAccounts(void) + KMyMoneyAccountTreeItem* item = new KMyMoneyAccountTreeItem(m_accountTree, *it_i); + item->setPixmap(0, none.pixmap()); + loadSubAccounts(item, (*it_i).id()); ++ if(!showClosedAccounts) ++ item->setVisible(item->childCount() != 0); + } + + } catch(MyMoneyException *e) { +@@ -201,7 +206,8 @@ void KInstitutionsView::loadAccounts(void) + + void KInstitutionsView::loadSubAccounts(KMyMoneyAccountTreeItem* parent) + { +- bool showClosedAccounts = kmymoney2->toggleAction("view_show_all_accounts")->isChecked(); ++ bool showClosedAccounts = kmymoney2->toggleAction("view_show_all_accounts")->isChecked() ++ || !KMyMoneyGlobalSettings::hideClosedAccounts(); + const MyMoneyAccount& account = dynamic_cast(parent->itemObject()); + TQValueList::const_iterator it_a; + MyMoneyFile* file = MyMoneyFile::instance(); +@@ -230,7 +236,8 @@ void KInstitutionsView::loadSubAccounts(KMyMoneyAccountTreeItem* parent, const T + + TQMap::const_iterator it_a; + MyMoneyMoney value; +- bool showClosedAccounts = kmymoney2->toggleAction("view_show_all_accounts")->isChecked(); ++ bool showClosedAccounts = kmymoney2->toggleAction("view_show_all_accounts")->isChecked() ++ || !KMyMoneyGlobalSettings::hideClosedAccounts(); + + for(it_a = m_accountMap.begin(); it_a != m_accountMap.end(); ++it_a) { + const MyMoneyAccount& acc = *it_a; +diff --git a/kmymoney2/widgets/stdtransactionmatched.cpp b/kmymoney2/widgets/stdtransactionmatched.cpp +index 833c88e..9900c3c 100644 +--- a/kmymoney2/widgets/stdtransactionmatched.cpp ++++ b/kmymoney2/widgets/stdtransactionmatched.cpp +@@ -179,6 +179,8 @@ + memo = memo.left(pos); + if(memo.endsWith("\n")) + memo = memo.left(pos-1); ++ // replace all new line characters because we only have one line available for the displayed data ++ memo.replace('\n', " "); + } + } + txt = TQString("%1 %2").tqarg(postDate.toString(Qt::ISODate)).tqarg(memo); -- cgit v1.2.1