blob: d11633ef5c1587d1f7923825d374021c6414e9b5 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
#include "ledger.h"
#include <sstream>
#include <deque>
namespace ledger {
#ifdef DO_CLEANUP
account_t::~account_t()
{
DEBUG_PRINT("ledger.memory.ctors", "dtor account_t");
//assert(! data);
for (accounts_map::iterator i = accounts.begin();
i != accounts.end();
i++)
delete (*i).second;
}
#endif // DO_CLEANUP
account_t * account_t::find_account(const std::string& name,
const bool auto_create)
{
accounts_map::const_iterator i = accounts.find(name);
if (i != accounts.end())
return (*i).second;
static char buf[256];
std::string::size_type sep = name.find(':');
const char * first, * rest;
if (sep == std::string::npos) {
first = name.c_str();
rest = NULL;
} else {
std::strncpy(buf, name.c_str(), sep);
buf[sep] = '\0';
first = buf;
rest = name.c_str() + sep + 1;
}
account_t * account;
i = accounts.find(first);
if (i == accounts.end()) {
if (! auto_create)
return NULL;
account = new account_t(this, first);
accounts.insert(accounts_pair(first, account));
} else {
account = (*i).second;
}
if (rest)
account = account->find_account(rest, auto_create);
return account;
}
bool account_t::remove_transaction(transaction_t * xact)
{
for (transactions_list::iterator i = transactions.begin();
i != transactions.end();
i++)
if (*i == xact) {
transactions.erase(i);
return true;
}
return false;
}
std::string account_t::fullname() const
{
if (! _fullname.empty()) {
return _fullname;
} else {
const account_t * first = this;
std::string fullname = name;
while (first->parent) {
first = first->parent;
if (! first->name.empty())
fullname = first->name + ":" + fullname;
}
_fullname = fullname;
return fullname;
}
}
} // namespace ledger
|