00001 /*************************************************************************** 00002 * Copyright (C) 2005-2007 Stefan Schwarzer, Jens Schneider, * 00003 * Matthias Hardt, Guido Madaus * 00004 * * 00005 * Copyright (C) 2007-2008 BerLinux Solutions GbR * 00006 * Stefan Schwarzer & Guido Madaus * 00007 * * 00008 * Copyright (C) 2009-2012 BerLinux Solutions GmbH * 00009 * * 00010 * Authors: * 00011 * Stefan Schwarzer <stefan.schwarzer@diskohq.org>, * 00012 * Matthias Hardt <matthias.hardt@diskohq.org>, * 00013 * Jens Schneider <jens.schneider@diskohq.org>, * 00014 * Guido Madaus <guido.madaus@diskohq.org>, * 00015 * Patrick Helterhoff <patrick.helterhoff@diskohq.org>, * 00016 * René Bählkow <rene.baehlkow@diskohq.org> * 00017 * * 00018 * This library is free software; you can redistribute it and/or * 00019 * modify it under the terms of the GNU Lesser General Public * 00020 * License version 2.1 as published by the Free Software Foundation. * 00021 * * 00022 * This library is distributed in the hope that it will be useful, * 00023 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00024 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 00025 * Lesser General Public License for more details. * 00026 * * 00027 * You should have received a copy of the GNU Lesser General Public * 00028 * License along with this library; if not, write to the * 00029 * Free Software Foundation, Inc., * 00030 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * 00031 **************************************************************************/ 00032 00033 #ifndef MMSERROR_H_ 00034 #define MMSERROR_H_ 00035 00036 /** 00037 * @file mmserror.h 00038 * 00039 * Header file for MMSError class. 00040 * 00041 * @ingroup mmstools 00042 */ 00043 00044 using namespace std; 00045 00046 #include <string> 00047 00048 /** 00049 * Base class for exception handling in disko. 00050 * 00051 * Derive your exception class from this one to extend exception handling. 00052 */ 00053 class MMSError { 00054 public: 00055 /** 00056 * Constructor. 00057 * 00058 * @param code error code (currently not used) 00059 * @param message error message which describes the exception more detailed 00060 */ 00061 MMSError(int code, string message) : message(message), code(code) {}; 00062 00063 /** 00064 * Destructor. 00065 */ 00066 ~MMSError() {}; 00067 00068 /** 00069 * Retrieve the error message saved in #message. 00070 * 00071 * @return String containing the error messages of this exception object. 00072 */ 00073 string getMessage(); 00074 00075 /** 00076 * Retrieve the error code saved in #code. 00077 * 00078 * @return Error code of this exception object. 00079 */ 00080 int getCode(); 00081 00082 private: 00083 string message; /**< Explanation of the error that caused this exception object to be thrown. */ 00084 int code; /**< Error code (currently not used). */ 00085 }; 00086 00087 /** 00088 * Macro which defines a new error type. 00089 * 00090 * You may use this shorthand define to derive your own exception class, 00091 * i.e. MMS_CREATEERROR(FooClass). 00092 */ 00093 #define MMS_CREATEERROR(error) class error : public MMSError { public: error(int code, string message) : MMSError(code,message) {};} 00094 00095 #endif /*MMSERROR_H_*/