summaryrefslogtreecommitdiff
path: root/src/derive.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/derive.cc')
-rw-r--r--src/derive.cc59
1 files changed, 36 insertions, 23 deletions
diff --git a/src/derive.cc b/src/derive.cc
index dd261ed6..ec9b1ed8 100644
--- a/src/derive.cc
+++ b/src/derive.cc
@@ -29,15 +29,27 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
-#include "derive.h"
-#include "session.h"
-#include "iterators.h"
+#include "report.h"
+#include "output.h"
namespace ledger {
-entry_t * derive_new_entry(report_t& report,
- strings_list::iterator i,
- strings_list::iterator end)
+value_t entry_command(call_scope_t& args)
+{
+ report_t& report(find_scope<report_t>(args));
+ scoped_ptr<entry_t> entry(derive_new_entry(report, args.begin(),
+ args.end()));
+ xact_handler_ptr handler
+ (new format_xacts(report, report.HANDLER(print_format_).str()));
+
+ report.entry_report(handler, *entry.get());
+
+ return true;
+}
+
+entry_t * derive_new_entry(report_t& report,
+ value_t::sequence_t::const_iterator i,
+ value_t::sequence_t::const_iterator end)
{
session_t& session(report.session);
@@ -45,11 +57,11 @@ entry_t * derive_new_entry(report_t& report,
entry_t * matching = NULL;
- added->_date = parse_date(*i++);
+ added->_date = parse_date((*i++).to_string());
if (i == end)
throw std::runtime_error("Too few arguments to 'entry'");
- mask_t regexp(*i++);
+ mask_t regexp((*i++).to_string());
entries_list::reverse_iterator j;
@@ -64,15 +76,16 @@ entry_t * derive_new_entry(report_t& report,
added->payee = matching ? matching->payee : regexp.expr.str();
+ string arg = (*i).to_string();
if (! matching) {
account_t * acct;
- if (i == end || ((*i)[0] == '-' || std::isdigit((*i)[0]))) {
+ if (i == end || (arg[0] == '-' || std::isdigit(arg[0]))) {
acct = session.master->find_account("Expenses");
}
else if (i != end) {
- acct = session.master->find_account_re(*i);
+ acct = session.master->find_account_re(arg);
if (! acct)
- acct = session.master->find_account(*i);
+ acct = session.master->find_account(arg);
assert(acct);
i++;
}
@@ -80,7 +93,7 @@ entry_t * derive_new_entry(report_t& report,
if (i == end) {
added->add_xact(new xact_t(acct));
} else {
- xact_t * xact = new xact_t(acct, amount_t(*i++));
+ xact_t * xact = new xact_t(acct, amount_t((*i++).to_string()));
added->add_xact(xact);
if (! xact->amount.commodity()) {
@@ -102,9 +115,9 @@ entry_t * derive_new_entry(report_t& report,
if (i != end) {
if (! acct)
- acct = session.master->find_account_re(*i);
+ acct = session.master->find_account_re((*i).to_string());
if (! acct)
- acct = session.master->find_account(*i);
+ acct = session.master->find_account((*i).to_string());
}
if (! acct) {
@@ -124,11 +137,11 @@ entry_t * derive_new_entry(report_t& report,
foreach (xact_t * xact, matching->xacts)
added->add_xact(new xact_t(*xact));
}
- else if ((*i)[0] == '-' || std::isdigit((*i)[0])) {
+ else if (arg[0] == '-' || std::isdigit(arg[0])) {
xact_t * m_xact, * xact, * first;
m_xact = matching->xacts.front();
- first = xact = new xact_t(m_xact->account, amount_t(*i++));
+ first = xact = new xact_t(m_xact->account, amount_t((*i++).to_string()));
added->add_xact(xact);
if (! xact->amount.commodity())
@@ -140,9 +153,9 @@ entry_t * derive_new_entry(report_t& report,
added->add_xact(xact);
if (i != end) {
- account_t * acct = session.master->find_account_re(*i);
+ account_t * acct = session.master->find_account_re((*i).to_string());
if (! acct)
- acct = session.master->find_account(*i);
+ acct = session.master->find_account((*i).to_string());
assert(acct);
added->xacts.back()->account = acct;
}
@@ -151,7 +164,7 @@ entry_t * derive_new_entry(report_t& report,
account_t * draw_acct = NULL;
while (i != end) {
- string& re_pat(*i++);
+ string re_pat((*i++).to_string());
account_t * acct = NULL;
amount_t * amt = NULL;
@@ -177,13 +190,13 @@ entry_t * derive_new_entry(report_t& report,
else
xact = new xact_t(acct);
} else {
- amount_t amount(*i++);
+ amount_t amount((*i++).to_string());
- strings_list::iterator x = i;
+ value_t::sequence_t::const_iterator x = i;
if (i != end && ++x == end) {
- draw_acct = session.master->find_account_re(*i);
+ draw_acct = session.master->find_account_re((*i).to_string());
if (! draw_acct)
- draw_acct = session.master->find_account(*i);
+ draw_acct = session.master->find_account((*i).to_string());
i++;
}