summaryrefslogtreecommitdiff
path: root/src/amount.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/amount.cc')
-rw-r--r--src/amount.cc220
1 files changed, 0 insertions, 220 deletions
diff --git a/src/amount.cc b/src/amount.cc
index e95f6350..1d1a3c36 100644
--- a/src/amount.cc
+++ b/src/amount.cc
@@ -30,7 +30,6 @@
*/
#include "amount.h"
-#include "binary.h"
namespace ledger {
@@ -1021,225 +1020,6 @@ void amount_t::print(std::ostream& _out, bool omit_commodity,
_out << out.str();
}
-void amount_t::read(std::istream& in)
-{
- using namespace ledger::binary;
-
- // Read in the commodity for this amount
-
- commodity_t::ident_t ident;
- read_long(in, ident);
- if (ident == 0xffffffff)
- commodity_ = NULL;
- else if (ident == 0)
- commodity_ = current_pool->null_commodity;
- else {
- commodity_ = current_pool->find(ident);
- assert(commodity_);
- }
-
- // Read in the quantity
-
- char byte;
- in.read(&byte, sizeof(byte));
-
- if (byte < 3) {
- quantity = new bigint_t;
-
- unsigned short len;
- in.read(reinterpret_cast<char *>(&len), sizeof(len));
- assert(len < 4096);
- static char buf[4096];
- in.read(buf, len);
-
- mpz_import(temp, len / sizeof(short), 1, sizeof(short),
- 0, 0, buf);
- mpq_set_num(MP(quantity), temp);
-
- in.read(reinterpret_cast<char *>(&len), sizeof(len));
- assert(len < 4096);
- in.read(buf, len);
- mpz_import(temp, len / sizeof(short), 1, sizeof(short),
- 0, 0, buf);
- mpq_set_den(MP(quantity), temp);
-
- char negative;
- in.read(&negative, sizeof(negative));
- if (negative)
- mpq_neg(MP(quantity), MP(quantity));
-
- in.read(reinterpret_cast<char *>(&quantity->prec), sizeof(quantity->prec));
-
- bigint_t::flags_t tflags;
- in.read(reinterpret_cast<char *>(&tflags), sizeof(tflags));
- quantity->set_flags(tflags);
- }
- else {
- assert(false);
- }
-}
-
-void amount_t::read(const char *& data,
- char ** pool,
- char ** pool_next)
-{
- using namespace ledger::binary;
-
- // Read in the commodity for this amount
-
- commodity_t::ident_t ident;
- read_long(data, ident);
- if (ident == 0xffffffff)
- commodity_ = NULL;
- else if (ident == 0)
- commodity_ = current_pool->null_commodity;
- else {
- commodity_ = current_pool->find(ident);
- assert(commodity_);
- }
-
- // Read in the quantity
-
- char byte = *data++;;
-
- if (byte < 3) {
- if (byte == 2) {
- quantity = new(reinterpret_cast<bigint_t *>(*pool_next)) bigint_t;
- *pool_next += sizeof(bigint_t);
- } else {
- quantity = new bigint_t;
- }
-
- unsigned short len =
- *reinterpret_cast<unsigned short *>(const_cast<char *>(data));
- data += sizeof(unsigned short);
- mpz_init(temp);
- mpz_import(temp, len / sizeof(short), 1, sizeof(short),
- 0, 0, data);
- data += len;
-
- mpq_set_num(MP(quantity), temp);
-
- len = *reinterpret_cast<unsigned short *>(const_cast<char *>(data));
- data += sizeof(unsigned short);
- mpz_init(temp);
- mpz_import(temp, len / sizeof(short), 1, sizeof(short),
- 0, 0, data);
- data += len;
-
- mpq_set_den(MP(quantity), temp);
-
- char negative = *data++;
- if (negative)
- mpq_neg(MP(quantity), MP(quantity));
-
- quantity->prec = *reinterpret_cast<precision_t *>(const_cast<char *>(data));
- data += sizeof(precision_t);
- quantity->set_flags(*reinterpret_cast<bigint_t::flags_t *>(const_cast<char *>(data)));
- data += sizeof(bigint_t::flags_t);
-
- if (byte == 2)
- quantity->add_flags(BIGINT_BULK_ALLOC);
- } else {
- uint_fast32_t index = *reinterpret_cast<uint_fast32_t *>(const_cast<char *>(data));
- data += sizeof(uint_fast32_t);
-
- quantity = reinterpret_cast<bigint_t *>(*pool + (index - 1) * sizeof(bigint_t));
-
- DEBUG("amounts.refs",
- quantity << " ref++, now " << (quantity->ref + 1));
- quantity->ref++;
- }
-}
-
-namespace {
- void write_bytes(std::ostream& out,
- const char * buf,
- const std::size_t size)
- {
- unsigned short len = size * sizeof(short);
- out.write(reinterpret_cast<char *>(&len), sizeof(len));
- if (len) {
- assert(len < 4096);
- out.write(buf, len);
- }
- }
-}
-
-void amount_t::write(std::ostream& out, std::size_t index) const
-{
- using namespace ledger::binary;
-
- // Write out the commodity for this amount
-
- if (! quantity)
- throw_(amount_error, "Cannot serialize an uninitialized amount");
-
- if (commodity_)
- write_long(out, commodity_->ident);
- else
- write_long<commodity_t::ident_t>(out, 0xffffffff);
-
- // Write out the quantity
-
- char byte;
-
- if (index == 0 || quantity->index == 0) {
- if (index != 0) {
- quantity->index = index; // if !optimized, this is garbage
- byte = 2;
- } else {
- byte = 1;
- }
- out.write(&byte, sizeof(byte));
-
- std::size_t size;
- static char buf[4096];
-
- mpq_get_num(temp, MP(quantity));
- mpz_export(buf, &size, 1, sizeof(short), 0, 0, temp);
- write_bytes(out, buf, size);
-
- mpq_get_den(temp, MP(quantity));
- mpz_export(buf, &size, 1, sizeof(short), 0, 0, temp);
- write_bytes(out, buf, size);
-
- byte = mpq_sgn(MP(quantity)) < 0 ? 1 : 0;
- out.write(&byte, sizeof(byte));
-
- out.write(reinterpret_cast<char *>(&quantity->prec), sizeof(quantity->prec));
- bigint_t::flags_t tflags = quantity->flags() & ~BIGINT_BULK_ALLOC;
- assert(sizeof(tflags) == sizeof(bigint_t::flags_t));
- out.write(reinterpret_cast<char *>(&tflags), sizeof(tflags));
- } else {
- assert(quantity->ref > 1);
-
- // Since this value has already been written, we simply write
- // out a reference to which one it was.
- byte = 3;
- out.write(&byte, sizeof(byte));
- out.write(reinterpret_cast<char *>(&quantity->index), sizeof(quantity->index));
- }
-}
-
-void amount_t::read_xml(std::istream& in)
-{
-}
-
-void amount_t::write_xml(std::ostream& out, const int depth) const
-{
- out << xml_str("<amount>\n", depth);
-
- if (has_commodity())
- commodity().write_xml(out, depth + 1);
-
- out << xml_str("<quantity>", depth + 1)
- << quantity_string()
- << "</quantity>\n";
-
- out << xml_str("</amount>\n", depth);
-}
-
bool amount_t::valid() const
{
if (quantity) {