summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/output.cc26
-rw-r--r--src/output.h2
2 files changed, 18 insertions, 10 deletions
diff --git a/src/output.cc b/src/output.cc
index 77083450..418140ae 100644
--- a/src/output.cc
+++ b/src/output.cc
@@ -34,6 +34,7 @@
#include "output.h"
#include "xact.h"
#include "post.h"
+#include "item.h"
#include "account.h"
#include "session.h"
#include "report.h"
@@ -329,21 +330,26 @@ void report_tags::flush()
}
}
-void report_tags::operator()(post_t& post)
+void report_tags::gather_metadata(item_t& item)
{
- if (post.metadata) {
- foreach (const item_t::string_map::value_type& data, *post.metadata) {
- string tag=data.first;
- if (report.HANDLED(values) && (data.second).first) {
- tag+=": "+ (data.second).first.get().to_string();
- }
+ if (item.metadata)
+ foreach (const item_t::string_map::value_type& data, *item.metadata) {
+ string tag(data.first);
+ if (report.HANDLED(values) && data.second.first)
+ tag += ": " + data.second.first.get().to_string();
+
std::map<string, std::size_t>::iterator i = tags.find(tag);
if (i == tags.end())
- tags.insert(tags_pair(tag, 1));
+ tags.insert(tags_pair(tag, 1));
else
- (*i).second++;
+ (*i).second++;
}
- }
+}
+
+void report_tags::operator()(post_t& post)
+{
+ gather_metadata(*post.xact);
+ gather_metadata(post);
}
void report_commodities::flush()
diff --git a/src/output.h b/src/output.h
index e8c45337..ea474e2b 100644
--- a/src/output.h
+++ b/src/output.h
@@ -51,6 +51,7 @@ namespace ledger {
class xact_t;
class post_t;
+class item_t;
class report_t;
class format_posts : public item_handler<post_t>
@@ -208,6 +209,7 @@ public:
}
virtual void flush();
+ virtual void gather_metadata(item_t& item);
virtual void operator()(post_t& post);
virtual void clear() {