--- parser3/src/include/pa_exception.h 2002/04/29 06:27:29 1.35 +++ parser3/src/include/pa_exception.h 2026/04/25 13:38:46 1.76 @@ -1,19 +1,44 @@ /** @file Parser: exception decls. - Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com) - Author: Alexandr Petrosian (http://paf.design.ru) - - $Id: pa_exception.h,v 1.35 2002/04/29 06:27:29 paf Exp $ + Copyright (c) 2001-2026 Art. Lebedev Studio (https://www.artlebedev.com) + Authors: Konstantin Morshnev , Alexandr Petrosian */ #ifndef PA_EXCEPTION_H #define PA_EXCEPTION_H -#include "pa_types.h" -#include "pa_string.h" +#define IDENT_PA_EXCEPTION_H "$Id: pa_exception.h,v 1.76 2026/04/25 13:38:46 moko Exp $" + +const char* const PARSER_RUNTIME = "parser.runtime"; +const char* const IMAGE_FORMAT = "image.format"; +const char* const PCRE_EXCEPTION_TYPE = "pcre.execute"; +const char* const DATE_RANGE_EXCEPTION_TYPE = "date.range"; +const char* const BASE64_FORMAT = "base64.format"; + +const char* const NAME_MUST_BE_STRING = "name must be string"; +const char* const FILE_NAME_MUST_BE_STRING = "file name must be string"; +const char* const FILE_NAME_MUST_BE_STRING_OR_FILE = "file name must be string or file"; +const char* const FILE_NAME_MUST_BE_NE_STRING = "file name must be not empty string"; +const char* const VALUE_MUST_BE_STRING = "value must be string"; +const char* const PARAMETER_MUST_BE_STRING = "parameter must be string"; +const char* const COLUMN_NAME_MUST_BE_STRING = "column name must be string"; + +const char* const FILE_NAME_MUST_BE_SPECIFIED = "file name must be specified"; +const char* const PARAM_MUST_NOT_BE_CODE = "param must not be code"; +const char* const PARAM_MUST_BE_HASH = "param must be hash"; +const char* const MODE_MUST_BE_STRING = "mode must be string"; +const char* const OPTIONS_MUST_NOT_BE_CODE = "options must not be code"; + +const char* const CALLED_WITH_INVALID_OPTION = "called with invalid option"; -class Pool; +// includes + +#include "pa_memory.h" + +// forwards + +class String; // defines @@ -21,45 +46,55 @@ class Exception { public: Exception(); - Exception( - const char *atype, - const String *aproblem_source, - const char *comment_fmt, ...); + Exception(const char* atype, const String* aproblem_source, const char* comment_fmt, ...); Exception(const Exception& src); - Exception& operator =(const Exception& src); - ~Exception(); -#ifdef XML - Exception( - const String *aproblem_source, - GdomeException& exc); -#endif + operator bool() { return ftype || fproblem_source || fcomment; } + Exception& operator =(const Exception& src); /// extracts exception type - const char *type(bool can_be_empty=false) const { - if(can_be_empty) - return ftype; - else - return ftype?ftype:""; + const char* type(bool can_be_empty=false) const { + return can_be_empty || ftype ? ftype : ""; } + /// extracts exception problem_source - const String *problem_source() const { - return fproblem_source && fproblem_source->size()?fproblem_source:0; - } + const String* problem_source() const; + /// extracts exception comment - const char *comment(bool can_be_empty=false) const { - const char *result=fcomment && *fcomment?fcomment:0; - if(can_be_empty) - return result; - else - return result?result:""; + const char* comment(bool can_be_empty=false) const { + const char* result=fcomment && *fcomment ? fcomment : 0; + return can_be_empty || result ? result : ""; + } + + // modifies exception to fine-tune error reporting + void set_source(const String* aproblem_source) { + if(!problem_source()) + fproblem_source=aproblem_source; + } + + void add_comment(const char* acomment); + +#define ALTER_EXCEPTION_SOURCE(code, source) \ + try { \ + code; \ + } catch (Exception& e) { \ + e.set_source(source); \ + rethrow; \ + } + +#define ALTER_EXCEPTION_COMMENT(code, comment) \ + try { \ + code; \ + } catch (Exception& e) { \ + e.add_comment(comment); \ + rethrow; \ } -private: +protected: - const char *ftype; - const String *fproblem_source; - bool owns_comment; char *fcomment; + const char* ftype; + const String* fproblem_source; + const char* fcomment; };