fixed another memory strangeness (too much destruction)
This commit is contained in:
parent
69bd31b4d0
commit
5f30c790db
3 changed files with 48 additions and 28 deletions
1
value.cc
1
value.cc
|
|
@ -26,6 +26,7 @@ value_t& value_t::operator=(const value_t& value)
|
|||
return *this;
|
||||
|
||||
destroy();
|
||||
|
||||
switch (value.type) {
|
||||
case BOOLEAN:
|
||||
*((bool *) data) = *((bool *) value.data);
|
||||
|
|
|
|||
69
value.h
69
value.h
|
|
@ -37,7 +37,7 @@ class value_t
|
|||
type = INTEGER;
|
||||
}
|
||||
|
||||
value_t(const value_t& value) {
|
||||
value_t(const value_t& value) : type(INTEGER) {
|
||||
DEBUG_PRINT("ledger.memory.ctors", "ctor value_t");
|
||||
*this = value;
|
||||
}
|
||||
|
|
@ -51,20 +51,17 @@ class value_t
|
|||
*((unsigned int *) data) = value;
|
||||
type = INTEGER;
|
||||
}
|
||||
value_t(const amount_t& value) {
|
||||
value_t(const amount_t& value) : type(INTEGER) {
|
||||
DEBUG_PRINT("ledger.memory.ctors", "ctor value_t");
|
||||
new((amount_t *)data) amount_t(value);
|
||||
type = AMOUNT;
|
||||
*this = value;
|
||||
}
|
||||
value_t(const balance_t& value) {
|
||||
value_t(const balance_t& value) : type(INTEGER) {
|
||||
DEBUG_PRINT("ledger.memory.ctors", "ctor value_t");
|
||||
new((balance_t *)data) balance_t(value);
|
||||
type = BALANCE;
|
||||
*this = value;
|
||||
}
|
||||
value_t(const balance_pair_t& value) {
|
||||
value_t(const balance_pair_t& value) : type(INTEGER) {
|
||||
DEBUG_PRINT("ledger.memory.ctors", "ctor value_t");
|
||||
new((balance_pair_t *)data) balance_pair_t(value);
|
||||
type = BALANCE_PAIR;
|
||||
*this = value;
|
||||
}
|
||||
|
||||
~value_t() {
|
||||
|
|
@ -76,33 +73,55 @@ class value_t
|
|||
|
||||
value_t& operator=(const value_t& value);
|
||||
value_t& operator=(const bool value) {
|
||||
destroy();
|
||||
*((bool *) data) = value;
|
||||
type = BOOLEAN;
|
||||
if ((bool *) data != &value) {
|
||||
destroy();
|
||||
*((bool *) data) = value;
|
||||
type = BOOLEAN;
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
value_t& operator=(const unsigned int value) {
|
||||
destroy();
|
||||
*((unsigned int *) data) = value;
|
||||
type = INTEGER;
|
||||
if ((unsigned int *) data != &value) {
|
||||
destroy();
|
||||
*((unsigned int *) data) = value;
|
||||
type = INTEGER;
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
value_t& operator=(const amount_t& value) {
|
||||
destroy();
|
||||
new((amount_t *)data) amount_t(value);
|
||||
type = AMOUNT;
|
||||
if ((amount_t *) data != &value) {
|
||||
if (! value) {
|
||||
return *this = 0U;
|
||||
} else {
|
||||
destroy();
|
||||
new((amount_t *)data) amount_t(value);
|
||||
type = AMOUNT;
|
||||
}
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
value_t& operator=(const balance_t& value) {
|
||||
destroy();
|
||||
new((balance_t *)data) balance_t(value);
|
||||
type = BALANCE;
|
||||
if ((balance_t *) data != &value) {
|
||||
if (value.amounts.size() == 1) {
|
||||
return *this = (*value.amounts.begin()).second;
|
||||
} else {
|
||||
destroy();
|
||||
new((balance_t *)data) balance_t(value);
|
||||
type = BALANCE;
|
||||
}
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
value_t& operator=(const balance_pair_t& value) {
|
||||
destroy();
|
||||
new((balance_pair_t *)data) balance_pair_t(value);
|
||||
type = BALANCE_PAIR;
|
||||
if ((balance_pair_t *) data != &value) {
|
||||
if (! value.cost) {
|
||||
return *this = value.quantity;
|
||||
} else {
|
||||
destroy();
|
||||
new((balance_pair_t *)data) balance_pair_t(value);
|
||||
type = BALANCE_PAIR;
|
||||
}
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
|
|
|
|||
6
walk.h
6
walk.h
|
|
@ -40,6 +40,9 @@ struct item_handler {
|
|||
|
||||
template <typename T>
|
||||
class compare_items {
|
||||
value_t left_result;
|
||||
value_t right_result;
|
||||
|
||||
const value_expr_t * sort_order;
|
||||
|
||||
public:
|
||||
|
|
@ -52,9 +55,6 @@ class compare_items {
|
|||
assert(left);
|
||||
assert(right);
|
||||
|
||||
value_t left_result;
|
||||
value_t right_result;
|
||||
|
||||
sort_order->compute(left_result, details_t(left));
|
||||
sort_order->compute(right_result, details_t(right));
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue