summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/account.h1
-rw-r--r--src/annotate.h6
-rw-r--r--src/archive.cc86
-rw-r--r--src/archive.h10
-rw-r--r--src/commodity.h10
-rw-r--r--src/scope.h4
-rw-r--r--src/session.cc4
-rw-r--r--src/textual.cc7
-rw-r--r--src/xact.cc2
-rw-r--r--src/xact.h15
10 files changed, 96 insertions, 49 deletions
diff --git a/src/account.h b/src/account.h
index 9dc467bc..ce0a7a66 100644
--- a/src/account.h
+++ b/src/account.h
@@ -50,7 +50,6 @@
namespace ledger {
-class session_t;
class account_t;
class xact_t;
class post_t;
diff --git a/src/annotate.h b/src/annotate.h
index 17c8a637..77dd9372 100644
--- a/src/annotate.h
+++ b/src/annotate.h
@@ -192,7 +192,7 @@ public:
explicit annotated_commodity_t(commodity_t * _ptr,
const annotation_t& _details)
: commodity_t(_ptr->parent_, _ptr->base), ptr(_ptr), details(_details) {
- TRACE_CTOR(annotated_commodity_t, "");
+ TRACE_CTOR(annotated_commodity_t, "commodity_t *, annotation_t");
annotated = true;
}
virtual ~annotated_commodity_t() {
@@ -216,7 +216,9 @@ public:
#if defined(HAVE_BOOST_SERIALIZATION)
private:
- explicit annotated_commodity_t() : ptr(NULL) {}
+ explicit annotated_commodity_t() : ptr(NULL) {
+ TRACE_CTOR(annotated_commodity_t, "");
+ }
/** Serialization. */
diff --git a/src/archive.cc b/src/archive.cc
index a37bad90..b3aff7d7 100644
--- a/src/archive.cc
+++ b/src/archive.cc
@@ -42,7 +42,8 @@
#include "post.h"
#include "xact.h"
-#define ARCHIVE_VERSION 0x03000001
+#define LEDGER_MAGIC 0x4c454447
+#define ARCHIVE_VERSION 0x03000002
//BOOST_IS_ABSTRACT(ledger::scope_t)
BOOST_CLASS_EXPORT(ledger::scope_t)
@@ -63,25 +64,64 @@ template void ledger::journal_t::serialize(boost::archive::binary_iarchive&,
const unsigned int);
namespace ledger {
-void archive_t::read_header()
+namespace {
+ bool read_header_bits(std::istream& in) {
+ uint32_t bytes;
+
+ assert(sizeof(uint32_t) == 4);
+ in.read(reinterpret_cast<char *>(&bytes), sizeof(uint32_t));
+ if (bytes != LEDGER_MAGIC) {
+ DEBUG("archive.journal", "Magic bytes not present");
+ return false;
+ }
+
+ in.read(reinterpret_cast<char *>(&bytes), sizeof(uint32_t));
+ if (bytes != ARCHIVE_VERSION) {
+ DEBUG("archive.journal", "Archive version mismatch");
+ return false;
+ }
+
+ return true;
+ }
+
+ void write_header_bits(std::ostream& out) {
+ uint32_t bytes;
+
+ assert(sizeof(uint32_t) == 4);
+ bytes = LEDGER_MAGIC;
+ out.write(reinterpret_cast<char *>(&bytes), sizeof(uint32_t));
+
+ bytes = ARCHIVE_VERSION;
+ out.write(reinterpret_cast<char *>(&bytes), sizeof(uint32_t));
+ }
+}
+
+bool archive_t::read_header()
{
- if (exists(file)) {
- // Open the stream, read the version number and the list of sources
- ifstream stream(file, std::ios::binary);
- boost::archive::binary_iarchive iarchive(stream);
+ uintmax_t size = file_size(file);
+ if (size < 8)
+ return false;
- DEBUG("archive.journal", "Reading header from archive");
- iarchive >> *this;
+ // Open the stream, read the version number and the list of sources
+ ifstream stream(file, std::ios::binary);
+ if (! read_header_bits(stream))
+ return false;
+
+ boost::archive::binary_iarchive iarchive(stream);
- DEBUG("archive.journal",
- "Version number: " << std::hex << version << std::dec);
- DEBUG("archive.journal", "Number of sources: " << sources.size());
+ DEBUG("archive.journal", "Reading header from archive");
+ iarchive >> *this;
+
+ DEBUG("archive.journal",
+ "Version number: " << std::hex << ARCHIVE_VERSION << std::dec);
+ DEBUG("archive.journal", "Number of sources: " << sources.size());
#if defined(DEBUG_ON)
- foreach (const journal_t::fileinfo_t& i, sources)
- DEBUG("archive.journal", "Loaded source: " << *i.filename);
+ foreach (const journal_t::fileinfo_t& i, sources)
+ DEBUG("archive.journal", "Loaded source: " << *i.filename);
#endif
- }
+
+ return true;
}
bool archive_t::should_load(const std::list<path>& data_files)
@@ -95,8 +135,8 @@ bool archive_t::should_load(const std::list<path>& data_files)
return false;
}
- if (version != ARCHIVE_VERSION) {
- DEBUG("archive.journal", "No, it fails the version check");
+ if (! read_header()) {
+ DEBUG("archive.journal", "No, header failed to read");
return false;
}
@@ -205,10 +245,9 @@ void archive_t::save(shared_ptr<journal_t> journal)
{
INFO_START(archive, "Saved journal file cache");
- ofstream archive(file, std::ios::binary);
- boost::archive::binary_oarchive oa(archive);
+ ofstream stream(file, std::ios::binary);
- version = ARCHIVE_VERSION;
+ write_header_bits(stream);
sources = journal->sources;
#if defined(DEBUG_ON)
@@ -216,8 +255,10 @@ void archive_t::save(shared_ptr<journal_t> journal)
DEBUG("archive.journal", "Saving source: " << *i.filename);
#endif
- DEBUG("archive.journal",
- "Creating archive with version " << std::hex << version << std::dec);
+ boost::archive::binary_oarchive oa(stream);
+
+ DEBUG("archive.journal", "Creating archive with version "
+ << std::hex << ARCHIVE_VERSION << std::dec);
oa << *this;
DEBUG("archive.journal",
@@ -232,6 +273,9 @@ bool archive_t::load(shared_ptr<journal_t> journal)
INFO_START(archive, "Read cached journal file");
ifstream stream(file, std::ios::binary);
+ if (! read_header_bits(stream))
+ return false;
+
boost::archive::binary_iarchive iarchive(stream);
// Skip past the archive header, it was already read in before
diff --git a/src/archive.h b/src/archive.h
index 77272dbe..cd778a03 100644
--- a/src/archive.h
+++ b/src/archive.h
@@ -58,7 +58,6 @@ namespace ledger {
class archive_t
{
path file;
- uint32_t version;
std::list<journal_t::fileinfo_t> sources;
@@ -66,19 +65,17 @@ public:
archive_t() {
TRACE_CTOR(archive_t, "");
}
- archive_t(const path& _file)
- : file(_file), version(0) {
+ archive_t(const path& _file) : file(_file) {
TRACE_CTOR(archive_t, "const path&");
}
- archive_t(const archive_t& ar)
- : file(ar.file), version(0) {
+ archive_t(const archive_t& ar) : file(ar.file) {
TRACE_CTOR(archive_t, "copy");
}
~archive_t() {
TRACE_DTOR(archive_t);
}
- void read_header();
+ bool read_header();
bool should_load(const std::list<path>& data_files);
bool should_save(shared_ptr<journal_t> journal);
@@ -94,7 +91,6 @@ private:
template<class Archive>
void serialize(Archive & ar, const unsigned int /* version */) {
- ar & version;
ar & sources;
}
#endif // HAVE_BOOST_SERIALIZATION
diff --git a/src/commodity.h b/src/commodity.h
index d91fce85..1df1ab18 100644
--- a/src/commodity.h
+++ b/src/commodity.h
@@ -91,7 +91,9 @@ class commodity_t
public:
class base_t : public noncopyable, public supports_flags<uint_least16_t>
{
- base_t() {}
+ base_t() {
+ TRACE_CTOR(base_t, "");
+ }
public:
typedef std::map<const datetime_t, amount_t> history_map;
@@ -236,7 +238,7 @@ public:
const shared_ptr<base_t>& _base)
: delegates_flags<uint_least16_t>(*_base.get()), base(_base),
parent_(_parent), annotated(false) {
- TRACE_CTOR(commodity_t, "");
+ TRACE_CTOR(commodity_t, "commodity_pool_t *, shared_ptr<base_t>");
}
virtual ~commodity_t() {
TRACE_DTOR(commodity_t);
@@ -394,7 +396,9 @@ private:
protected:
explicit commodity_t()
: delegates_flags<uint_least16_t>(temp_flags), parent_(NULL),
- annotated(false) {}
+ annotated(false) {
+ TRACE_CTOR(commodity_t, "");
+ }
private:
/** Serialization. */
diff --git a/src/scope.h b/src/scope.h
index fc330ba0..7f2680d6 100644
--- a/src/scope.h
+++ b/src/scope.h
@@ -219,7 +219,9 @@ public:
#if defined(HAVE_BOOST_SERIALIZATION)
private:
- explicit call_scope_t() {}
+ explicit call_scope_t() {
+ TRACE_CTOR(call_scope_t, "");
+ }
/** Serialization. */
diff --git a/src/session.cc b/src/session.cc
index f3209fe7..3f29716d 100644
--- a/src/session.cc
+++ b/src/session.cc
@@ -130,15 +130,17 @@ std::size_t session_t::read_data(const string& master_account)
price_db_path = resolve_path(HANDLER(price_db_).str());
optional<archive_t> cache;
+#if 1
+ // jww (2009-11-01): The binary caching feature is disabled for now.
if (HANDLED(cache_) && master_account.empty()) {
cache = archive_t(HANDLED(cache_).str());
- cache->read_header();
if (price_db_path) {
HANDLER(file_).data_files.push_back(*price_db_path);
populated_price_db = true;
}
}
+#endif
if (! (cache &&
cache->should_load(HANDLER(file_).data_files) &&
diff --git a/src/textual.cc b/src/textual.cc
index 0eb00292..c2976ee1 100644
--- a/src/textual.cc
+++ b/src/textual.cc
@@ -486,6 +486,7 @@ void instance_t::option_directive(char * line)
*p++ = '\0';
}
+#if 0
if (! process_option(pathname.string(), line + 2, scope, p, line) &&
! dynamic_cast<session_t *>(&scope)) {
if (std::strlen(line + 2) == 1)
@@ -493,6 +494,9 @@ void instance_t::option_directive(char * line)
else
throw_(option_error, _("Illegal option --%1") << line + 2);
}
+#else
+ process_option(pathname.string(), line + 2, scope, p, line);
+#endif
}
void instance_t::automated_xact_directive(char * line)
@@ -520,6 +524,7 @@ void instance_t::automated_xact_directive(char * line)
journal.auto_xacts.push_back(ae.get());
+ ae->journal = &journal;
ae->pos = position_t();
ae->pos->pathname = pathname;
ae->pos->beg_pos = pos;
@@ -555,6 +560,7 @@ void instance_t::period_xact_directive(char * line)
if (parse_posts(account_stack.front(), *pe.get())) {
reveal_context = true;
+ pe->journal = &journal;
if (pe->finalize()) {
extend_xact_base(&journal, *pe.get(), true);
@@ -570,6 +576,7 @@ void instance_t::period_xact_directive(char * line)
pe.release();
} else {
+ pe->journal = NULL;
throw parse_error(_("Period transaction failed to balance"));
}
}
diff --git a/src/xact.cc b/src/xact.cc
index 1ab54bdf..34b8c340 100644
--- a/src/xact.cc
+++ b/src/xact.cc
@@ -457,7 +457,7 @@ bool xact_t::valid() const
DEBUG("ledger.validate", "xact_t: ! _date");
return false;
}
- if (! journal) {
+ if (! has_flags(ITEM_GENERATED | ITEM_TEMP) && ! journal) {
DEBUG("ledger.validate", "xact_t: ! journal");
return false;
}
diff --git a/src/xact.h b/src/xact.h
index b3cad6da..59ddd1bc 100644
--- a/src/xact.h
+++ b/src/xact.h
@@ -79,7 +79,9 @@ public:
virtual bool remove_post(post_t * post);
virtual bool finalize();
- virtual bool valid() const = 0;
+ virtual bool valid() const {
+ return true;
+ }
#if defined(HAVE_BOOST_SERIALIZATION)
private:
@@ -179,9 +181,6 @@ public:
}
virtual void extend_xact(xact_base_t& xact, bool post);
- virtual bool valid() const {
- return true;
- }
#if defined(HAVE_BOOST_SERIALIZATION)
private:
@@ -262,14 +261,6 @@ class period_xact_t : public xact_base_t
TRACE_DTOR(period_xact_t);
}
- virtual bool valid() const {
- if (! period.is_valid()) {
- DEBUG("ledger.validate", "period_xact_t: ! period.is_valid()");
- return false;
- }
- return true;
- }
-
#if defined(HAVE_BOOST_SERIALIZATION)
private:
/** Serialization. */