--- parser3/src/include/pa_exception.h 2001/09/26 10:32:25 1.13 +++ parser3/src/include/pa_exception.h 2001/11/15 20:26:34 1.22 @@ -2,9 +2,9 @@ Parser: exception decls. Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) - Author: Alexander Petrosyan (http://design.ru/paf) + Author: Alexander Petrosyan (http://paf.design.ru) - $Id: pa_exception.h,v 1.13 2001/09/26 10:32:25 parser Exp $ + $Id: pa_exception.h,v 1.22 2001/11/15 20:26:34 paf Exp $ */ #ifndef PA_EXCEPTION_H @@ -14,23 +14,42 @@ #include "pa_types.h" #include "pa_string.h" +#ifdef XML +#include +#include +#include +#include +#endif + +class Pool; + +// defines + /// Just simple longjump mechanizm dressed in class clothes. use Temp_exception class Exception { public: - /** - address for long jump to jump to - regretfully public: - can't make local unless sure of inlining - for to-die stack frame ruins it all - */ - mutable jmp_buf mark; - - /// throws an exception[really goes to mark-ed position - void _throw( + Exception(); + Exception( const String *atype, const String *acode, const String *aproblem_source, - const char *comment_fmt, ...) const; + const char *comment_fmt, ...); + Exception(const Exception& src); + Exception& operator =(const Exception& src); + ~Exception(); + +#ifdef XML + /// converts XSL exception to parser exception + static void provide_source(Pool& pool, const String *source, const XSLException& e); + /// converts SAX exception to parser exception + static void provide_source(Pool& pool, const String *source, const SAXException& e); + /// converts SAX parse exception to parser exception + static void provide_source(Pool& pool, const String *source, const SAXParseException& e); + /// converts XML exception to parser exception + static void provide_source(Pool& pool, const String *source, const XMLException& e); + /// converts Xalan DOM exception to parser exception + static void provide_source(Pool& pool, const String *source, const XalanDOMException& e); +#endif /// extracts exception type const String *type() const { return ftype; } @@ -39,12 +58,14 @@ public: /// extracts exception problem_source const String *problem_source() const { return fproblem_source; } /// extracts exception comment - const char *comment() const { return fcomment[0]?fcomment:0; } + const char *comment() const { return fcomment; } private: - mutable const String *ftype, *fcode, *fproblem_source; - mutable char fcomment[MAX_STRING]; + const String *ftype, *fcode, *fproblem_source; + bool owns_comment; + char *fcomment; + }; #endif