libkcal
exceptions.h
Go to the documentation of this file.00001 /* 00002 This file is part of libkcal. 00003 00004 Copyright (c) 2001-2003 Cornelius Schumacher <schumacher@kde.org> 00005 00006 This library is free software; you can redistribute it and/or 00007 modify it under the terms of the GNU Library General Public 00008 License as published by the Free Software Foundation; either 00009 version 2 of the License, or (at your option) any later version. 00010 00011 This library is distributed in the hope that it will be useful, 00012 but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00014 Library General Public License for more details. 00015 00016 You should have received a copy of the GNU Library General Public License 00017 along with this library; see the file COPYING.LIB. If not, write to 00018 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, 00019 Boston, MA 02110-1301, USA. 00020 */ 00021 00022 #ifndef KCAL_EXCEPTIONS_H 00023 #define KCAL_EXCEPTIONS_H 00024 // 00025 // Exception classes of libkcal. 00026 // 00027 // We don't use actual C++ exceptions right now. These classes are currently 00028 // returned by an error function, but we can build upon them, if we start 00029 // to use C++ exceptions. 00030 00031 #include <qstring.h> 00032 00033 namespace KCal { 00034 00039 class Exception 00040 { 00041 public: 00045 Exception( const QString &message = QString::null ); 00046 virtual ~Exception(); 00047 00051 virtual QString message(); 00052 00053 protected: 00054 QString mMessage; 00055 00056 private: 00057 class Private; 00058 Private *d; 00059 }; 00060 00064 class ErrorFormat : public Exception 00065 { 00066 public: 00067 enum ErrorCodeFormat { LoadError, SaveError, 00068 ParseErrorIcal, ParseErrorKcal, 00069 NoCalendar, 00070 CalVersion1,CalVersion2, 00071 CalVersionUnknown, 00072 Restriction }; 00073 00077 ErrorFormat( ErrorCodeFormat code, const QString &message = QString::null ); 00078 00082 QString message(); 00086 ErrorCodeFormat errorCode(); 00087 00088 private: 00089 ErrorCodeFormat mCode; 00090 00091 class Private; 00092 Private *d; 00093 }; 00094 00095 } 00096 00097 #endif