Annotation of parser3/src/include/pa_exception.h, revision 1.48
1.10 paf 1: /** @file
1.11 paf 2: Parser: exception decls.
3:
1.45 paf 4: Copyright (c) 2001-2005 ArtLebedev Group (http://www.artlebedev.com)
1.31 paf 5: Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
1.1 paf 6: */
7:
8: #ifndef PA_EXCEPTION_H
9: #define PA_EXCEPTION_H
1.36 paf 10:
1.48 ! misha 11: static const char * const IDENT_EXCEPTION_H="$Date: 2007/04/24 08:39:28 $";
1.46 misha 12:
1.47 misha 13: const char* const PARSER_RUNTIME = "parser.runtime";
1.1 paf 14:
1.48 ! misha 15: const char* const NAME_MUST_BE_STRING = "name must be string";
! 16: const char* const FILE_NAME_MUST_BE_STRING = "file name must be string";
! 17: const char* const NAMESPACEURI_MUST_BE_STRING = "namespaceURI must be string";
! 18: const char* const LOCALNAME_MUST_BE_STRING = "localName must be string";
! 19: const char* const VALUE_MUST_BE_STRING = "value must be string";
! 20:
! 21: const char* const FILE_NAME_MUST_NOT_BE_CODE = "file name must not be code";
! 22: const char* const COORDINATES_MUST_NOT_BE_CODE = "coordinates must not be code";
! 23:
1.39 paf 24: // includes
1.14 parser 25:
1.39 paf 26: #include "pa_memory.h"
27:
28: // forwards
29:
30: class String;
1.14 parser 31:
1.22 paf 32: // defines
33:
1.1 paf 34: class Exception {
35: public:
36:
1.19 paf 37: Exception();
1.15 parser 38: Exception(
1.39 paf 39: const char* atype,
40: const String* aproblem_source,
41: const char* comment_fmt, ...);
1.22 paf 42: Exception(const Exception& src);
1.44 paf 43: operator bool() { return ftype || fproblem_source || fcomment; }
1.22 paf 44: Exception& operator =(const Exception& src);
1.1 paf 45:
1.10 paf 46: /// extracts exception type
1.39 paf 47: const char* type(bool can_be_empty=false) const {
1.35 paf 48: if(can_be_empty)
49: return ftype;
50: else
51: return ftype?ftype:"<no type>";
52: }
1.10 paf 53: /// extracts exception problem_source
1.39 paf 54: const String* problem_source() const;
1.10 paf 55: /// extracts exception comment
1.39 paf 56: const char* comment(bool can_be_empty=false) const {
57: const char* result=fcomment && *fcomment?fcomment:0;
1.35 paf 58: if(can_be_empty)
59: return result;
60: else
61: return result?result:"<no comment>";
62: }
1.1 paf 63:
1.40 paf 64: protected:
1.1 paf 65:
1.39 paf 66: const char* ftype;
67: const String* fproblem_source;
68: char* fcomment;
1.15 parser 69:
1.1 paf 70: };
71:
72: #endif
E-mail: