summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--amount.cc35
-rw-r--r--amount.h2
2 files changed, 20 insertions, 17 deletions
diff --git a/amount.cc b/amount.cc
index 1ec23926..67168ac7 100644
--- a/amount.cc
+++ b/amount.cc
@@ -10,11 +10,24 @@
namespace ledger {
#ifdef DEBUG_ENABLED
-static int ctors = 0;
-static int dtors = 0;
+int bigint_ctors = 0;
+int bigint_dtors = 0;
#endif
-struct amount_t::bigint_t {
+#ifdef DEBUG_ENABLED
+static struct ctor_dtor_info {
+ ~ctor_dtor_info() {
+ DEBUG_CLASS("ledger.amount.bigint");
+ DEBUG_PRINT_("bigint_t ctor count = " << bigint_ctors);
+ DEBUG_PRINT_("bigint_t dtor count = " << bigint_dtors);
+ }
+} __info;
+#endif
+
+class amount_t::bigint_t {
+ bigint_t(const bigint_t&);
+
+ public:
mpz_t val;
unsigned int ref;
unsigned int index;
@@ -22,34 +35,24 @@ struct amount_t::bigint_t {
bigint_t() : ref(1), index(0) {
mpz_init(val);
#ifdef DEBUG_ENABLED
- ctors++;
+ bigint_ctors++;
#endif
}
bigint_t(mpz_t _val) : ref(1), index(0) {
mpz_init_set(val, _val);
#ifdef DEBUG_ENABLED
- ctors++;
+ bigint_ctors++;
#endif
}
~bigint_t() {
assert(ref == 0);
mpz_clear(val);
#ifdef DEBUG_ENABLED
- dtors++;
+ bigint_dtors++;
#endif
}
};
-#ifdef DEBUG_ENABLED
-static struct ctor_dtor_info {
- ~ctor_dtor_info() {
- DEBUG_CLASS("ledger.amount.bigint");
- DEBUG_PRINT_("bigint_t ctor count = " << ctors);
- DEBUG_PRINT_("bigint_t dtor count = " << dtors);
- }
-} __info;
-#endif
-
#define MPZ(x) ((x)->val)
static mpz_t temp;
diff --git a/amount.h b/amount.h
index 8eebdd4e..7fbbb344 100644
--- a/amount.h
+++ b/amount.h
@@ -28,7 +28,7 @@ class amount_t
}
public:
- struct bigint_t;
+ class bigint_t;
bigint_t * quantity; // amount, to MAX_PRECISION
unsigned short precision;