/* * Copyright (c) 2003-2009, John Wiegley. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * - Neither the name of New Artisans LLC nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /** * @addtogroup report */ /** * @file output.h * @author John Wiegley * * @ingroup report * * @brief Brief * * Long. */ #ifndef _OUTPUT_H #define _OUTPUT_H #include "report.h" #include "format.h" namespace ledger { /** * @brief Brief * * Long. */ class format_xacts : public item_handler { protected: report_t& report; format_t first_line_format; format_t next_lines_format; format_t between_format; entry_t * last_entry; xact_t * last_xact; public: format_xacts(report_t& _report, const string& format); virtual ~format_xacts() { TRACE_DTOR(format_xacts); } virtual void flush() { report.output_stream.flush(); } virtual void operator()(xact_t& xact); }; /** * @brief Brief * * Long. */ class gather_statistics : public item_handler { protected: report_t& report; entry_t * last_entry; xact_t * last_xact; struct statistics_t { std::set filenames; std::size_t total_entries; std::size_t total_xacts; std::size_t total_uncleared_xacts; std::size_t total_last_7_days; std::size_t total_last_30_days; std::size_t total_this_month; date_t earliest_xact; date_t latest_xact; std::set accounts_referenced; std::set payees_referenced; std::set unique_dates; statistics_t() : total_entries(0), total_xacts(0), total_uncleared_xacts(0), total_last_7_days(0), total_last_30_days(0), total_this_month(0) {} } statistics; public: gather_statistics(report_t& _report) : report(_report), last_entry(NULL), last_xact(NULL) { TRACE_CTOR(gather_statistics, "report&"); } virtual ~gather_statistics() { TRACE_DTOR(gather_statistics); } virtual void flush(); virtual void operator()(xact_t& xact); }; /** * @brief Brief * * Long. */ class format_entries : public format_xacts { public: format_entries(report_t& _report, const string& format) : format_xacts(_report, format) { TRACE_CTOR(format_entries, "report_t&, const string&"); } virtual ~format_entries() { TRACE_DTOR(format_entries); } virtual void format_last_entry(); virtual void flush() { if (last_entry) { format_last_entry(); last_entry = NULL; } format_xacts::flush(); } virtual void operator()(xact_t& xact); }; /** * @brief Brief * * Long. */ class format_accounts : public item_handler { protected: report_t& report; format_t format; item_predicate disp_pred; bool print_final_total; bool disp_subaccounts_p(account_t& account, account_t *& to_show); bool display_account(account_t& account); public: format_accounts(report_t& _report, const string& _format = "", const bool _print_final_total = true) : report(_report), format(_format), disp_pred(), print_final_total(_print_final_total) { TRACE_CTOR(format_accounts, "report&, const string&, const bool"); } virtual ~format_accounts() { TRACE_DTOR(format_accounts); } bool should_display(account_t& account) { if (! disp_pred.predicate && report.HANDLED(display_)) disp_pred.predicate.parse(report.HANDLER(display_).str()); bind_scope_t bound_scope(report, account); return disp_pred(bound_scope); } virtual void flush(); virtual void operator()(account_t& account); }; /** * @brief Brief * * Long. */ class format_equity : public format_accounts { format_t first_line_format; format_t next_lines_format; mutable value_t total; public: format_equity(report_t& _report, const string& _format); virtual ~format_equity() { TRACE_DTOR(format_equity); } virtual void flush(); virtual void operator()(account_t& account); }; } // namespace ledger #endif // _OUTPUT_H