summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/report.cc29
-rw-r--r--src/report.h42
2 files changed, 53 insertions, 18 deletions
diff --git a/src/report.cc b/src/report.cc
index c6f9b214..ff2f9e41 100644
--- a/src/report.cc
+++ b/src/report.cc
@@ -517,12 +517,18 @@ expr_t::ptr_op_t report_t::lookup(const string& name)
case 'a':
if (std::strcmp(p, "amount_") == 0)
return MAKE_FUNCTOR(report_t::option_amount_);
+ else if (std::strcmp(p, "ansi") == 0)
+ return MAKE_FUNCTOR(report_t::option_ansi);
+ else if (std::strcmp(p, "ansi-invert") == 0)
+ return MAKE_FUNCTOR(report_t::option_ansi_invert);
break;
case 'b':
if (std::strcmp(p, "b_") == 0 ||
std::strcmp(p, "begin_") == 0)
return MAKE_FUNCTOR(report_t::option_begin_);
+ else if (std::strcmp(p, "base") == 0)
+ return MAKE_FUNCTOR(report_t::option_base);
else if (std::strcmp(p, "by-payee") == 0)
return MAKE_FUNCTOR(report_t::option_by_payee);
break;
@@ -534,6 +540,8 @@ expr_t::ptr_op_t report_t::lookup(const string& name)
return MAKE_FUNCTOR(report_t::option_collapse);
else if (std::strcmp(p, "cleared") == 0)
return MAKE_FUNCTOR(report_t::option_cleared);
+ else if (std::strcmp(p, "cost") == 0)
+ return MAKE_FUNCTOR(report_t::option_cost);
else if (std::strcmp(p, "comm-as-payee") == 0)
return MAKE_FUNCTOR(report_t::option_comm_as_payee);
else if (std::strcmp(p, "code-as-payee") == 0)
@@ -601,11 +609,17 @@ expr_t::ptr_op_t report_t::lookup(const string& name)
return MAKE_FUNCTOR(report_t::option_period_);
else if (std::strcmp(p, "period_sort_") == 0)
return MAKE_FUNCTOR(report_t::option_period_sort_);
+ else if (std::strcmp(p, "price") == 0)
+ return MAKE_FUNCTOR(report_t::option_price);
+ else if (std::strcmp(p, "price_db_") == 0)
+ return MAKE_FUNCTOR(report_t::option_price_db_);
break;
case 'q':
if (std::strcmp(p, "quarterly") == 0)
return MAKE_FUNCTOR(report_t::option_quarterly);
+ else if (std::strcmp(p, "quantity") == 0)
+ return MAKE_FUNCTOR(report_t::option_quantity);
break;
case 'r':
@@ -659,6 +673,11 @@ expr_t::ptr_op_t report_t::lookup(const string& name)
return MAKE_FUNCTOR(report_t::option_date_format_);
break;
+ case 'B':
+ if (! *(p + 1))
+ return MAKE_FUNCTOR(report_t::option_cost);
+ break;
+
case 'C':
if (! *(p + 1))
return MAKE_FUNCTOR(report_t::option_cleared);
@@ -674,6 +693,11 @@ expr_t::ptr_op_t report_t::lookup(const string& name)
return MAKE_FUNCTOR(report_t::option_format_);
break;
+ case 'I':
+ if (! *(p + 1))
+ return MAKE_FUNCTOR(report_t::option_price);
+ break;
+
case 'J':
if (! *(p + 1))
return MAKE_FUNCTOR(report_t::option_total_data);
@@ -684,6 +708,11 @@ expr_t::ptr_op_t report_t::lookup(const string& name)
return MAKE_FUNCTOR(report_t::option_monthly);
break;
+ case 'O':
+ if (! *(p + 1))
+ return MAKE_FUNCTOR(report_t::option_quantity);
+ break;
+
case 'P':
if (! *(p + 1))
return MAKE_FUNCTOR(report_t::option_by_payee);
diff --git a/src/report.h b/src/report.h
index c78144e2..26535622 100644
--- a/src/report.h
+++ b/src/report.h
@@ -691,15 +691,16 @@ public:
return true;
}
-#if 0
value_t option_ansi(call_scope_t& args) {
format_t::ansi_codes = true;
format_t::ansi_invert = false;
+ return true;
}
value_t option_ansi_invert(call_scope_t& args) {
format_t::ansi_codes =
format_t::ansi_invert = true;
+ return true;
}
//////////////////////////////////////////////////////////////////////
@@ -708,40 +709,46 @@ public:
value_t option_base(call_scope_t& args) { // :
amount_t::keep_base = true;
+ return true;
}
- value_t option_price_db(call_scope_t& args) { // :
- config->price_db = optarg;
+ value_t option_price_db_(call_scope_t& args) { // :
+ session.price_db = args[0].as_string();
+ return true;
}
- value_t option_price_exp(call_scope_t& args) { // Z:
- config->pricing_leeway = std::atol(optarg) * 60;
+ value_t option_price_exp_(call_scope_t& args) { // Z:
+ session.pricing_leeway = lexical_cast<long>(args[0].as_string()) * 60;
+ return true;
}
value_t option_download(call_scope_t& args) { // Q
- config->download_quotes = true;
+ session.download_quotes = true;
+ return true;
}
value_t option_quantity(call_scope_t& args) { // O
- ledger::amount_expr = "amount";
- ledger::total_expr = "total";
+ amount_expr = "amount";
+ total_expr = "total";
+ return true;
}
- value_t option_basis(call_scope_t& args) { // B
- ledger::amount_expr = "b";
- ledger::total_expr = "B";
+ value_t option_cost(call_scope_t& args) { // B
+ amount_expr = "cost";
+ total_expr = "total_cost";
+ return true;
}
value_t option_price(call_scope_t& args) { // I
- ledger::amount_expr = "i";
- ledger::total_expr = "I";
+ amount_expr = "price";
+ total_expr = "price_total";
+ return true;
}
value_t option_market(call_scope_t& args) { // V
- report->show_revalued = true;
-
- ledger::amount_expr = "v";
- ledger::total_expr = "V";
+ show_revalued = true;
+ display_total = "market_value(total_expr)";
+ return true;
}
#if 0
@@ -769,7 +776,6 @@ public:
}
}
#endif
-#endif
//
// Scope members