diff options
Diffstat (limited to 'src/context.h')
-rw-r--r-- | src/context.h | 94 |
1 files changed, 83 insertions, 11 deletions
diff --git a/src/context.h b/src/context.h index 899c9b88..39700746 100644 --- a/src/context.h +++ b/src/context.h @@ -6,7 +6,12 @@ namespace ledger { class context { public: - string context; // ex: 'While parsing file "%R" at line %L' + string description; // ex: 'While parsing file "%R" at line %L' + + explicit context(const string& _description) throw() + : description(_description) {} + + virtual ~context() {} }; class file_context : public context @@ -14,12 +19,25 @@ class file_context : public context public: path pathname; // ex: ledger.dat - optional<long> linenum_beg; // ex: 1010 - optional<long> linenum_end; // ex: 1010 - optional<long> colnum_beg; // ex: 8 - optional<long> colnum_end; // ex: 8 - optional<long> position_beg; - optional<long> position_end; + uint_least32_t linenum_beg; // ex: 1010 + uint_least32_t linenum_end; // ex: 1010 + uint_least32_t position_beg; + uint_least32_t position_end; + + optional<uint_least32_t> colnum_beg; // ex: 8 + optional<uint_least32_t> colnum_end; // ex: 8 + + explicit file_context(const path& _pathname, + const uint_least32_t _linenum_beg, + const uint_least32_t _linenum_end, + const uint_least32_t _position_beg, + const uint_least32_t _position_end) throw() + : context(""), + pathname(_pathname), + linenum_beg(_linenum_beg), + linenum_end(_linenum_end), + position_beg(_position_beg), + position_end(_position_end) {} }; class string_context : public context @@ -27,12 +45,66 @@ class string_context : public context public: string text; // ex: (The multi-line text of an entry) - optional<long> linenum_beg_off; // ex: 2 / none means start at beginning - optional<long> linenum_end_off; // ex: 2 / none means start at beginning - optional<long> colnum_beg_off; // ex: 8 / none means start - optional<long> colnum_end_off; // ex: 8 / none means start + optional<uint_least32_t> linenum_beg_off; // ex: 2 + optional<uint_least32_t> linenum_end_off; // ex: 2 + optional<uint_least32_t> colnum_beg_off; // ex: 8 + optional<uint_least32_t> colnum_end_off; // ex: 8 +}; + +#if 0 + +class file_context : public error_context +{ + protected: + string file; + unsigned long line; + public: + file_context(const string& _file, unsigned long _line, + const string& _desc = "") throw() + : error_context(_desc), file(_file), line(_line) {} + virtual ~file_context() throw() {} + + virtual void describe(std::ostream& out) const throw() { + if (! desc.empty()) + out << desc << " "; + + out << "\"" << file << "\", line " << line << ": "; + } }; +class line_context : public error_context { + public: + string line; + long pos; + + line_context(const string& _line, long _pos, + const string& _desc = "") throw() + : error_context(_desc), line(_line), pos(_pos) {} + virtual ~line_context() throw() {} + + virtual void describe(std::ostream& out) const throw() { + if (! desc.empty()) + out << desc << std::endl; + + out << " " << line << std::endl << " "; + long idx = pos < 0 ? line.length() - 1 : pos; + for (int i = 0; i < idx; i++) + out << " "; + out << "^" << std::endl; + } +}; + +#endif + +extern ptr_list<context> context_stack; + +#define PUSH_CONTEXT() try { +#define POP_CONTEXT(ctxt) \ + } catch (...) { \ + context_stack.push_front(new ctxt); \ + throw; \ + } + } // namespace ledger #endif // _CONTEXT_H |