diff options
author | Mike Buland <eichlan@xagasoft.com> | 2006-07-26 19:16:58 +0000 |
---|---|---|
committer | Mike Buland <eichlan@xagasoft.com> | 2006-07-26 19:16:58 +0000 |
commit | 579c3ac445043122b0a702bdb2542d9ea404b62e (patch) | |
tree | a96017529296f52a357e25de37b8c4cd052bebf5 /src | |
parent | 9e27762c2b4c1baf5b2aff003fbc56236fd742e6 (diff) | |
download | libbu++-579c3ac445043122b0a702bdb2542d9ea404b62e.tar.gz libbu++-579c3ac445043122b0a702bdb2542d9ea404b62e.tar.bz2 libbu++-579c3ac445043122b0a702bdb2542d9ea404b62e.tar.xz libbu++-579c3ac445043122b0a702bdb2542d9ea404b62e.zip |
Exceptions have been re-worked, and are easier to use, and don't collide with
system includues anymore.
Diffstat (limited to '')
-rw-r--r-- | src/exceptionbase.cpp | 16 | ||||
-rw-r--r-- | src/exceptionbase.h (renamed from src/exception.h) | 22 | ||||
-rw-r--r-- | src/exceptions.cpp | 5 | ||||
-rw-r--r-- | src/exceptions.h | 9 | ||||
-rw-r--r-- | src/xmlexception.cpp | 31 | ||||
-rw-r--r-- | src/xmlexception.h | 21 | ||||
-rw-r--r-- | src/xmlfilereader.cpp | 2 | ||||
-rw-r--r-- | src/xmlreader.cpp | 2 | ||||
-rw-r--r-- | src/xmlstringreader.cpp | 2 |
9 files changed, 36 insertions, 74 deletions
diff --git a/src/exceptionbase.cpp b/src/exceptionbase.cpp index 3cde134..a9b9820 100644 --- a/src/exceptionbase.cpp +++ b/src/exceptionbase.cpp | |||
@@ -1,7 +1,7 @@ | |||
1 | #include "exception.h" | 1 | #include "exceptionbase.h" |
2 | #include <stdarg.h> | 2 | #include <stdarg.h> |
3 | 3 | ||
4 | Exception::Exception( const char *lpFormat, ... ) throw() : | 4 | ExceptionBase::ExceptionBase( const char *lpFormat, ... ) throw() : |
5 | nErrorCode( 0 ), | 5 | nErrorCode( 0 ), |
6 | sWhat( NULL ) | 6 | sWhat( NULL ) |
7 | { | 7 | { |
@@ -12,7 +12,7 @@ Exception::Exception( const char *lpFormat, ... ) throw() : | |||
12 | va_end(ap); | 12 | va_end(ap); |
13 | } | 13 | } |
14 | 14 | ||
15 | Exception::Exception( int nCode, const char *lpFormat, ... ) throw() : | 15 | ExceptionBase::ExceptionBase( int nCode, const char *lpFormat, ... ) throw() : |
16 | nErrorCode( nCode ), | 16 | nErrorCode( nCode ), |
17 | sWhat( NULL ) | 17 | sWhat( NULL ) |
18 | { | 18 | { |
@@ -23,13 +23,13 @@ Exception::Exception( int nCode, const char *lpFormat, ... ) throw() : | |||
23 | va_end(ap); | 23 | va_end(ap); |
24 | } | 24 | } |
25 | 25 | ||
26 | Exception::Exception( int nCode ) throw() : | 26 | ExceptionBase::ExceptionBase( int nCode ) throw() : |
27 | nErrorCode( nCode ), | 27 | nErrorCode( nCode ), |
28 | sWhat( NULL ) | 28 | sWhat( NULL ) |
29 | { | 29 | { |
30 | } | 30 | } |
31 | 31 | ||
32 | Exception::~Exception() throw() | 32 | ExceptionBase::~ExceptionBase() throw() |
33 | { | 33 | { |
34 | if( sWhat ) | 34 | if( sWhat ) |
35 | { | 35 | { |
@@ -38,7 +38,7 @@ Exception::~Exception() throw() | |||
38 | } | 38 | } |
39 | } | 39 | } |
40 | 40 | ||
41 | void Exception::setWhat( const char *lpFormat, va_list &vargs ) | 41 | void ExceptionBase::setWhat( const char *lpFormat, va_list &vargs ) |
42 | { | 42 | { |
43 | if( sWhat ) delete[] sWhat; | 43 | if( sWhat ) delete[] sWhat; |
44 | int nSize; | 44 | int nSize; |
@@ -48,12 +48,12 @@ void Exception::setWhat( const char *lpFormat, va_list &vargs ) | |||
48 | vsnprintf( sWhat, nSize+1, lpFormat, vargs ); | 48 | vsnprintf( sWhat, nSize+1, lpFormat, vargs ); |
49 | } | 49 | } |
50 | 50 | ||
51 | const char *Exception::what() const throw() | 51 | const char *ExceptionBase::what() const throw() |
52 | { | 52 | { |
53 | return sWhat; | 53 | return sWhat; |
54 | } | 54 | } |
55 | 55 | ||
56 | int Exception::getErrorCode() | 56 | int ExceptionBase::getErrorCode() |
57 | { | 57 | { |
58 | return nErrorCode; | 58 | return nErrorCode; |
59 | } | 59 | } |
diff --git a/src/exception.h b/src/exceptionbase.h index 1234bef..c0ced37 100644 --- a/src/exception.h +++ b/src/exceptionbase.h | |||
@@ -1,5 +1,5 @@ | |||
1 | #ifndef EXCEPTION_H | 1 | #ifndef EXCEPTION_BASE_H |
2 | #define EXCEPTION_H | 2 | #define EXCEPTION_BASE_H |
3 | 3 | ||
4 | #include <string> | 4 | #include <string> |
5 | #include <exception> | 5 | #include <exception> |
@@ -9,7 +9,7 @@ | |||
9 | * A generalized Exception base class. This is nice for making general and | 9 | * A generalized Exception base class. This is nice for making general and |
10 | * flexible child classes that can create new error code classes. | 10 | * flexible child classes that can create new error code classes. |
11 | */ | 11 | */ |
12 | class Exception : public std::exception | 12 | class ExceptionBase : public std::exception |
13 | { | 13 | { |
14 | public: | 14 | public: |
15 | /** | 15 | /** |
@@ -19,27 +19,27 @@ public: | |||
19 | * program can handle the exception in a better way. | 19 | * program can handle the exception in a better way. |
20 | * @param sFormat The format of the text. See printf for more info. | 20 | * @param sFormat The format of the text. See printf for more info. |
21 | */ | 21 | */ |
22 | Exception( const char *sFormat, ... ) throw(); | 22 | ExceptionBase( const char *sFormat, ... ) throw(); |
23 | 23 | ||
24 | /** | 24 | /** |
25 | * | 25 | * |
26 | * @param nCode | 26 | * @param nCode |
27 | * @param sFormat | 27 | * @param sFormat |
28 | */ | 28 | */ |
29 | Exception( int nCode, const char *sFormat, ... ) throw(); | 29 | ExceptionBase( int nCode, const char *sFormat, ... ) throw(); |
30 | 30 | ||
31 | /** | 31 | /** |
32 | * | 32 | * |
33 | * @param nCode | 33 | * @param nCode |
34 | * @return | 34 | * @return |
35 | */ | 35 | */ |
36 | Exception( int nCode=0 ) throw(); | 36 | ExceptionBase( int nCode=0 ) throw(); |
37 | 37 | ||
38 | /** | 38 | /** |
39 | * | 39 | * |
40 | * @return | 40 | * @return |
41 | */ | 41 | */ |
42 | virtual ~Exception() throw(); | 42 | virtual ~ExceptionBase() throw(); |
43 | 43 | ||
44 | /** | 44 | /** |
45 | * | 45 | * |
@@ -66,7 +66,7 @@ private: | |||
66 | }; | 66 | }; |
67 | 67 | ||
68 | #define subExceptionDecl( name ) \ | 68 | #define subExceptionDecl( name ) \ |
69 | class name : public Exception \ | 69 | class name : public ExceptionBase \ |
70 | { \ | 70 | { \ |
71 | public: \ | 71 | public: \ |
72 | name( const char *sFormat, ... ) throw (); \ | 72 | name( const char *sFormat, ... ) throw (); \ |
@@ -76,7 +76,7 @@ class name : public Exception \ | |||
76 | 76 | ||
77 | #define subExceptionDef( name ) \ | 77 | #define subExceptionDef( name ) \ |
78 | name::name( const char *lpFormat, ... ) throw() : \ | 78 | name::name( const char *lpFormat, ... ) throw() : \ |
79 | Exception( 0 ) \ | 79 | ExceptionBase( 0 ) \ |
80 | { \ | 80 | { \ |
81 | va_list ap; \ | 81 | va_list ap; \ |
82 | va_start( ap, lpFormat ); \ | 82 | va_start( ap, lpFormat ); \ |
@@ -84,7 +84,7 @@ name::name( const char *lpFormat, ... ) throw() : \ | |||
84 | va_end( ap ); \ | 84 | va_end( ap ); \ |
85 | } \ | 85 | } \ |
86 | name::name( int nCode, const char *lpFormat, ... ) throw() : \ | 86 | name::name( int nCode, const char *lpFormat, ... ) throw() : \ |
87 | Exception( nCode ) \ | 87 | ExceptionBase( nCode ) \ |
88 | { \ | 88 | { \ |
89 | va_list ap; \ | 89 | va_list ap; \ |
90 | va_start( ap, lpFormat ); \ | 90 | va_start( ap, lpFormat ); \ |
@@ -92,7 +92,7 @@ name::name( int nCode, const char *lpFormat, ... ) throw() : \ | |||
92 | va_end( ap ); \ | 92 | va_end( ap ); \ |
93 | } \ | 93 | } \ |
94 | name::name( int nCode ) throw() : \ | 94 | name::name( int nCode ) throw() : \ |
95 | Exception( nCode ) \ | 95 | ExceptionBase( nCode ) \ |
96 | { \ | 96 | { \ |
97 | } | 97 | } |
98 | 98 | ||
diff --git a/src/exceptions.cpp b/src/exceptions.cpp new file mode 100644 index 0000000..441075d --- /dev/null +++ b/src/exceptions.cpp | |||
@@ -0,0 +1,5 @@ | |||
1 | #include "exceptions.h" | ||
2 | #include <stdarg.h> | ||
3 | |||
4 | subExceptionDef( XmlException ) | ||
5 | |||
diff --git a/src/exceptions.h b/src/exceptions.h new file mode 100644 index 0000000..1cc891d --- /dev/null +++ b/src/exceptions.h | |||
@@ -0,0 +1,9 @@ | |||
1 | #ifndef EXCEPTIONS_H | ||
2 | #define EXCEPTIONS_H | ||
3 | |||
4 | #include "exceptionbase.h" | ||
5 | #include <stdarg.h> | ||
6 | |||
7 | subExceptionDecl( XmlException ) | ||
8 | |||
9 | #endif | ||
diff --git a/src/xmlexception.cpp b/src/xmlexception.cpp deleted file mode 100644 index 9f38844..0000000 --- a/src/xmlexception.cpp +++ /dev/null | |||
@@ -1,31 +0,0 @@ | |||
1 | #include "xmlexception.h" | ||
2 | #include <stdarg.h> | ||
3 | |||
4 | subExceptionDef( XmlException ) | ||
5 | |||
6 | /* | ||
7 | XmlException::XmlException( const char *lpFormat, ... ) throw() : | ||
8 | Exception( 0 ) | ||
9 | { | ||
10 | va_list ap; | ||
11 | |||
12 | va_start(ap, lpFormat); | ||
13 | setWhat( lpFormat, ap ); | ||
14 | va_end(ap); | ||
15 | } | ||
16 | |||
17 | XmlException::XmlException( int nCode, const char *lpFormat, ... ) throw() : | ||
18 | Exception( nCode ) | ||
19 | { | ||
20 | va_list ap; | ||
21 | |||
22 | va_start(ap, lpFormat); | ||
23 | setWhat( lpFormat, ap ); | ||
24 | va_end(ap); | ||
25 | } | ||
26 | |||
27 | XmlException::XmlException( int nCode ) throw() : | ||
28 | Exception( nCode ) | ||
29 | { | ||
30 | } | ||
31 | */ | ||
diff --git a/src/xmlexception.h b/src/xmlexception.h deleted file mode 100644 index 5cbeda7..0000000 --- a/src/xmlexception.h +++ /dev/null | |||
@@ -1,21 +0,0 @@ | |||
1 | #ifndef XML_EXCEPTION_H | ||
2 | #define XML_EXCEPTION_H | ||
3 | |||
4 | #include <string> | ||
5 | #include "exception.h" | ||
6 | #include <stdarg.h> | ||
7 | |||
8 | subExceptionDecl( XmlException ) | ||
9 | |||
10 | /* | ||
11 | class XmlException : public Exception | ||
12 | { | ||
13 | public: | ||
14 | XmlException( const char *sFormat, ... ) throw(); | ||
15 | |||
16 | XmlException( int nCode, const char *sFormat, ... ) throw(); | ||
17 | |||
18 | XmlException( int nCode=0 ) throw(); | ||
19 | };*/ | ||
20 | |||
21 | #endif | ||
diff --git a/src/xmlfilereader.cpp b/src/xmlfilereader.cpp index eb0ff9c..ed674a8 100644 --- a/src/xmlfilereader.cpp +++ b/src/xmlfilereader.cpp | |||
@@ -1,5 +1,5 @@ | |||
1 | #include "xmlfilereader.h" | 1 | #include "xmlfilereader.h" |
2 | #include "xmlexception.h" | 2 | #include "exceptions.h" |
3 | #include <string.h> | 3 | #include <string.h> |
4 | 4 | ||
5 | XmlFileReader::XmlFileReader( const char *sFile, bool bStrip ) | 5 | XmlFileReader::XmlFileReader( const char *sFile, bool bStrip ) |
diff --git a/src/xmlreader.cpp b/src/xmlreader.cpp index 2a5f63f..d51568c 100644 --- a/src/xmlreader.cpp +++ b/src/xmlreader.cpp | |||
@@ -1,5 +1,5 @@ | |||
1 | #include "xmlreader.h" | 1 | #include "xmlreader.h" |
2 | #include "xmlexception.h" | 2 | #include "exceptions.h" |
3 | #include <string.h> | 3 | #include <string.h> |
4 | #include "hashfunctionstring.h" | 4 | #include "hashfunctionstring.h" |
5 | 5 | ||
diff --git a/src/xmlstringreader.cpp b/src/xmlstringreader.cpp index 211df78..3956ff3 100644 --- a/src/xmlstringreader.cpp +++ b/src/xmlstringreader.cpp | |||
@@ -1,5 +1,5 @@ | |||
1 | #include "xmlstringreader.h" | 1 | #include "xmlstringreader.h" |
2 | #include "xmlexception.h" | 2 | #include "exceptions.h" |
3 | #include <string.h> | 3 | #include <string.h> |
4 | 4 | ||
5 | XmlStringReader::XmlStringReader( const char *sString, bool bStrip ) | 5 | XmlStringReader::XmlStringReader( const char *sString, bool bStrip ) |