summaryrefslogtreecommitdiffabout
path: root/include
authorMichael Krelin <hacker@klever.net>2006-12-12 12:59:26 (UTC)
committer Michael Krelin <hacker@klever.net>2006-12-12 12:59:26 (UTC)
commit4c22006b8012bafccf955c0d077971e67107ac35 (patch) (side-by-side diff)
tree0a2c5748204a701576b8951e7658066e8e1c9c2b /include
parent08868f34ee339540ca392bb19e9c537d6e769464 (diff)
downloadkonforka-4c22006b8012bafccf955c0d077971e67107ac35.zip
konforka-4c22006b8012bafccf955c0d077971e67107ac35.tar.gz
konforka-4c22006b8012bafccf955c0d077971e67107ac35.tar.bz2
a few exception-handling convenience definitions
Diffstat (limited to 'include') (more/less context) (show whitespace changes)
-rw-r--r--include/konforka/exception.h31
1 files changed, 31 insertions, 0 deletions
diff --git a/include/konforka/exception.h b/include/konforka/exception.h
index 5e0bf96..dbfe27c 100644
--- a/include/konforka/exception.h
+++ b/include/konforka/exception.h
@@ -17,24 +17,55 @@
* the convenience definition of the parameters passed to the
* konforka::code_point constructor.
*/
#define CODEPOINT __FILE__,__PRETTY_FUNCTION__,__LINE__
/**
* @def NOCODEPOINT
* the convenience definition for the codepoint denoting no particular point in
* code.
*/
#define NOCODEPOINT "no information"
/**
+ * @def KONFORKA_RETHROW
+ * the convenience definition for seeing the exception and rethrowing it further.
+ */
+#define KONFORKA_RETHROW catch(konforka::exception& e) { e.see(CODEPOINT); throw; }
+
+/**
+ * @def KONFORKA_E_ARGS
+ * the convenience definition for naming codepoint parameters
+ */
+#define KONFORKA_E_PARS const string& fi,const string& fu,int l,const string& w
+
+/**
+ * @def KONFORKA_E_CONS
+ * the convenience definition for passing parameters to constructor
+ */
+#define KONFORKA_E_CONS fi,fu,l,w
+
+/**
+ * @def KONFORKA_E_SUBCLASS
+ * the convenience definition for subclassing konforka exceptions
+ * @param base base class
+ * @param derived derived class
+ */
+#define KONFORKA_E_SUBCLASS(derived,base) \
+ class derived : public base { \
+ public: \
+ explicit derived(KONFORKA_E_PARS) \
+ : base(KONFORKA_E_CONS) { } \
+ }
+
+/**
* @brief The main konforka namespace.
*/
namespace konforka {
using std::string;
using std::list;
/**
* @brief Pinpoint the code context.
*
* Class, holding the point in code, for instance, where the exception
* occured.
*/