summaryrefslogtreecommitdiff
path: root/ledger.cc
diff options
context:
space:
mode:
Diffstat (limited to 'ledger.cc')
-rw-r--r--ledger.cc288
1 files changed, 0 insertions, 288 deletions
diff --git a/ledger.cc b/ledger.cc
deleted file mode 100644
index 3a6f1016..00000000
--- a/ledger.cc
+++ /dev/null
@@ -1,288 +0,0 @@
-#include "ledger.h"
-#include "valexpr.h"
-#include "datetime.h"
-#include "acconf.h"
-
-#include <fstream>
-
-namespace ledger {
-
-const std::string version = PACKAGE_VERSION;
-
-bool transaction_t::valid() const
-{
- if (! entry)
- return false;
-
- bool found = false;
- for (transactions_list::const_iterator i = entry->transactions.begin();
- i != entry->transactions.end();
- i++)
- if (*i == this) {
- found = true;
- break;
- }
- if (! found)
- return false;
-
- if (! account)
- return false;
-
- found = false;
- for (transactions_list::const_iterator i = account->transactions.begin();
- i != account->transactions.end();
- i++)
- if (*i == this) {
- found = true;
- break;
- }
- if (! found)
- return false;
-
- if (! amount.valid())
- return false;
-
- if (cost && ! cost->valid())
- return false;
-
- if (flags & ~0x000f)
- return false;
-
- return true;
-}
-
-bool entry_t::valid() const
-{
- if (! date || date == -1)
- return false;
-
- if (state != UNCLEARED && state != CLEARED && state != PENDING)
- return false;
-
- for (transactions_list::const_iterator i = transactions.begin();
- i != transactions.end();
- i++)
- if ((*i)->entry != this || ! (*i)->valid())
- return false;
-
- return true;
-}
-
-void clean_commodity_history(char * item_pool, char * item_pool_end);
-
-journal_t::~journal_t()
-{
- DEBUG_PRINT("ledger.memory.dtors", "dtor journal_t");
-
- delete master;
-
- // Don't bother unhooking each entry's transactions from the
- // accounts they refer to, because all accounts are about to
- // be deleted.
- for (entries_list::iterator i = entries.begin();
- i != entries.end();
- i++)
- if (! item_pool ||
- ((char *) *i) < item_pool || ((char *) *i) >= item_pool_end)
- delete *i;
- else
- (*i)->~entry_t();
-
- // Remove historical prices which were allocated in the item_pool.
- clean_commodity_history(item_pool, item_pool_end);
-
- if (item_pool)
- delete[] item_pool;
-}
-
-bool journal_t::add_entry(entry_t * entry)
-{
- entries.push_back(entry);
-
- for (transactions_list::const_iterator i = entry->transactions.begin();
- i != entry->transactions.end();
- i++) {
- (*i)->account->add_transaction(*i);
-
- if ((*i)->cost) {
- assert((*i)->cost->commodity);
- (*i)->amount.commodity->add_price(entry->date,
- *(*i)->cost / (*i)->amount);
- }
- }
-
- return true;
-}
-
-bool journal_t::remove_entry(entry_t * entry)
-{
- entries.remove(entry);
-
- for (transactions_list::const_iterator i
- = entry->transactions.begin();
- i != entry->transactions.end();
- i++)
- (*i)->account->remove_transaction(*i);
-
- return true;
-}
-
-entry_t * journal_t::derive_entry(strings_list::iterator i,
- strings_list::iterator end) const
-{
- std::auto_ptr<entry_t> added(new entry_t);
-
- entry_t * matching = NULL;
-
- if (! parse_date((*i).c_str(), &added->date)) {
- std::cerr << "Error: Bad entry date: " << *i << std::endl;
- return false;
- }
- ++i;
-
- if (i == end) {
- std::cerr << "Error: Too few arguments to 'entry'." << std::endl;
- return false;
- }
-
- mask_t regexp(*i++);
-
- for (entries_list::const_reverse_iterator j = entries.rbegin();
- j != entries.rend();
- j++)
- if (regexp.match((*j)->payee)) {
- matching = *j;
- break;
- }
-
- added->payee = matching ? matching->payee : regexp.pattern;
-
- if (i == end) {
- std::cerr << "Error: Too few arguments to 'entry'." << std::endl;
- return false;
- }
-
- if ((*i)[0] == '-' || std::isdigit((*i)[0])) {
- if (! matching) {
- std::cerr << "Error: Missing account name for non-matching entry."
- << std::endl;
- return false;
- }
-
- transaction_t * m_xact, * xact, * first;
- m_xact = matching->transactions.front();
-
- amount_t amt(*i++);
- first = xact = new transaction_t(m_xact->account, amt);
- added->add_transaction(xact);
-
- if (xact->amount.commodity->symbol.empty())
- xact->amount.commodity = m_xact->amount.commodity;
-
- m_xact = matching->transactions.back();
-
- xact = new transaction_t(m_xact->account, - first->amount);
- added->add_transaction(xact);
-
- if (i != end && std::string(*i++) == "-from" && i != end)
- if (account_t * acct = find_account(*i))
- added->transactions.back()->account = acct;
- } else {
- while (std::string(*i) != "-from") {
- mask_t acct_regex(*i++);
-
- account_t * acct = NULL;
- commodity_t * cmdty = NULL;
-
- if (matching) {
- for (transactions_list::iterator x
- = matching->transactions.begin();
- x != matching->transactions.end();
- x++) {
- if (acct_regex.match((*x)->account->fullname())) {
- acct = (*x)->account;
- cmdty = (*x)->amount.commodity;
- break;
- }
- }
- }
-
- if (! acct)
- acct = find_account(acct_regex.pattern);
-
- if (! acct) {
- std::cerr << "Error: Could not find account name '"
- << acct_regex.pattern << "'." << std::endl;
- return false;
- }
-
- if (i == end) {
- std::cerr << "Error: Too few arguments to 'entry'." << std::endl;
- return false;
- }
-
- amount_t amt(*i++);
- transaction_t * xact = new transaction_t(acct, amt);
- added->add_transaction(xact);
-
- if (! xact->amount.commodity)
- xact->amount.commodity = cmdty;
- }
-
- if (i != end && std::string(*i++) == "-from" && i != end) {
- if (account_t * acct = find_account(*i++))
- added->add_transaction(new transaction_t(acct));
- } else {
- if (! matching) {
- std::cerr << "Error: Could not figure out the account to draw from."
- << std::endl;
- std::exit(1);
- }
- transaction_t * xact
- = new transaction_t(matching->transactions.back()->account);
- added->add_transaction(xact);
- }
- }
-
- return added.release();
-}
-
-bool journal_t::valid() const
-{
- if (! master->valid())
- return false;
-
- for (entries_list::const_iterator i = entries.begin();
- i != entries.end();
- i++)
- if (! (*i)->valid())
- return false;
-
- for (commodities_map::const_iterator i = commodity_t::commodities.begin();
- i != commodity_t::commodities.end();
- i++)
- if (! (*i).second->valid())
- return false;
-
- return true;
-}
-
-void initialize_amounts();
-void shutdown_amounts();
-
-void initialize_formats();
-void shutdown_formats();
-
-void initialize()
-{
- initialize_amounts();
- initialize_formats();
-}
-
-void shutdown()
-{
- shutdown_amounts();
- shutdown_formats();
-}
-
-} // namespace ledger