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-2013 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 #include <string> 00045 00046 using namespace std; 00047 00048 00049 /** 00050 * Base class for exception handling in disko. 00051 * 00052 * Derive your exception class from this one to extend exception handling. 00053 */ 00054 class MMSError { 00055 public: 00056 /** 00057 * Constructor. 00058 * 00059 * @param code error code (currently not used) 00060 * @param message error message which describes the exception more detailed 00061 */ 00062 MMSError(int code, string message) : message(message), code(code) {}; 00063 00064 /** 00065 * Destructor. 00066 */ 00067 ~MMSError() {}; 00068 00069 /** 00070 * Retrieve the error message saved in #message. 00071 * 00072 * @return String containing the error messages of this exception object. 00073 */ 00074 string getMessage(); 00075 00076 /** 00077 * Retrieve the error code saved in #code. 00078 * 00079 * @return Error code of this exception object. 00080 */ 00081 int getCode(); 00082 00083 private: 00084 string message; /**< Explanation of the error that caused this exception object to be thrown. */ 00085 int code; /**< Error code (currently not used). */ 00086 }; 00087 00088 /** 00089 * Macro which defines a new error type. 00090 * 00091 * You may use this shorthand define to derive your own exception class, 00092 * i.e. MMS_CREATEERROR(FooClass). 00093 */ 00094 #define MMS_CREATEERROR(error) class error : public MMSError { public: error(int code, string message) : MMSError(code,message) {};} 00095 00096 #endif /*MMSERROR_H_*/