summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--balance.cc21
-rw-r--r--balance.h29
-rw-r--r--walk.cc13
3 files changed, 34 insertions, 29 deletions
diff --git a/balance.cc b/balance.cc
index c3fec87c..edda552a 100644
--- a/balance.cc
+++ b/balance.cc
@@ -166,7 +166,26 @@ balance_pair_t& balance_pair_t::operator/=(const balance_pair_t& bal_pair)
*cost /= bal_pair.cost ? *bal_pair.cost : bal_pair.quantity;
if (bal_pair.price && *bal_pair.price && price)
- *price /= *bal_pair.price;
+ *price /= *bal_pair.price;
+ return *this;
+}
+
+balance_pair_t& balance_pair_t::add(const amount_t& amount,
+ const amount_t * a_price,
+ const amount_t * a_cost)
+{
+ if (a_cost && ! cost)
+ cost = new balance_t(quantity);
+ quantity += amount;
+ if (cost)
+ *cost += a_cost ? *a_cost : amount;
+
+ if (a_price) {
+ if (! price)
+ price = new balance_t(*a_price);
+ else
+ *price += *a_price;
+ }
return *this;
}
diff --git a/balance.h b/balance.h
index f131d631..d258e622 100644
--- a/balance.h
+++ b/balance.h
@@ -541,7 +541,7 @@ class balance_pair_t
if (! price)
price = new balance_t(*bal_pair.price);
else
- price += *bal_pair.price;
+ *price += *bal_pair.price;
}
return *this;
}
@@ -574,7 +574,7 @@ class balance_pair_t
price = new balance_t(*bal_pair.price);
price->negate();
} else {
- price -= *bal_pair.price;
+ *price -= *bal_pair.price;
}
}
return *this;
@@ -827,7 +827,7 @@ class balance_pair_t
void negate() {
quantity.negate();
if (price) price->negate();
- if (cost) cost->negate();
+ if (cost) cost->negate();
}
balance_pair_t negated() const {
balance_pair_t temp = *this;
@@ -852,7 +852,7 @@ class balance_pair_t
void abs() {
quantity.abs();
if (price) price->abs();
- if (cost) cost->abs();
+ if (cost) cost->abs();
}
amount_t amount(const commodity_t& commodity) const {
@@ -861,29 +861,14 @@ class balance_pair_t
balance_t value(const std::time_t moment) const {
return quantity.value(moment);
}
- void write(std::ostream& out,
- const int first_width,
- const int latter_width = -1) const {
+ void write(std::ostream& out, const int first_width,
+ const int latter_width = -1) const {
quantity.write(out, first_width, latter_width);
}
balance_pair_t& add(const amount_t& amount,
const amount_t * a_price = NULL,
- const amount_t * a_cost = NULL) {
- if (a_cost && ! cost)
- cost = new balance_t(quantity);
- quantity += amount;
- if (cost)
- *cost += a_cost ? *a_cost : amount;
-
- if (a_price) {
- if (! price)
- price = new balance_t(*a_price);
- else
- price += *a_price;
- }
- return *this;
- }
+ const amount_t * a_cost = NULL);
bool valid() {
return (quantity.valid() &&
diff --git a/walk.cc b/walk.cc
index 9f7ee8b1..c6ea3254 100644
--- a/walk.cc
+++ b/walk.cc
@@ -45,12 +45,13 @@ void add_transaction_to(const transaction_t& xact, value_t& value)
value += transaction_xdata_(xact).composite_amount;
}
else if (xact.cost || xact.amount.commodity().price || value) {
- std::auto_ptr<amount_t> price;
- amount_t * cost = xact.cost;
- if (xact.amount.commodity().price)
- price.reset(new amount_t(*xact.amount.commodity().price *
- xact.amount));
- value.add(base_amount(xact.amount), price.get(), cost);
+ if (xact.amount.commodity().price) {
+ amount_t price(*xact.amount.commodity().price);
+ price *= xact.amount;
+ value.add(base_amount(xact.amount), &price, xact.cost);
+ } else {
+ value.add(base_amount(xact.amount), NULL, xact.cost);
+ }
}
else {
value = xact.amount;