3m/3mExceptions.h

86 lines
3.4 KiB
C++

#ifndef _3M_EXCEPTIONS_H
#define _3M_EXCEPTIONS_H
#include <string>
#include <exception>
/// \file 3mExceptions.h
/// \brief A header file for all the exception classes for 3m
/// \author Phitherek_
/// \date 2013
/// \version 0.1
/// \namespace mmm
/// \brief A global namespace for 3m
namespace mmm {
/// \class FileException
/// \brief An exception to be thrown when file operation fails.
class FileException: public std::exception {
private:
std::string _filename;
std::string _mode;
std::string _err;
public:
FileException(std::string filename, std::string mode, std::string err); ///< \brief A constructor with parameters
///< \param filename Name of the file that caused an error.
///< \param mode A mode (reading/writing etc.) that the file was opened in.
///< \param err Error message.
~FileException() throw(); /// \brief A destructor, as needed by std::exception.
const char* what() const throw(); ///< \brief A function, that returns the whole error.
///< \return Whole error message.
};
/// \class ParseException
/// \brief An exception to be thrown when parse error occurs.
class ParseException: public std::exception {
private:
std::string _filename;
std::string _err;
public:
ParseException(std::string filename, std::string err); ///< \brief A constructor with parameters
///< \param filename Name of the file that caused an error.
///< \param err Error message.
~ParseException() throw(); /// \brief A destructor, as needed by std::exception.
const char* what() const throw(); ///< \brief A function, that returns the whole error.
///< \return Whole error message.
};
/// \class BadResponseException
/// \brief An exception to be thrown on not 200 HTTP response.
class BadResponseException: public std::exception {
private:
std::string _response;
public:
BadResponseException(std::string response); ///< \brief A constructor with parameters.
///< \param response HTTP response that caused the exception.
~BadResponseException() throw(); ///< A destructor, as needed by std::exception.
const char* what() const throw(); ///< \brief A function returning error message.
/// \return Error message.
};
/// \class NonEditableException
/// \brief An exception to be thrown when trying to write a remotely obtained, non-editable structure.
class NonEditableException: public std::exception {
private:
std::string _what;
public:
NonEditableException(std::string what); ///< \brief A constructor with parameters.
///< \param what Error message.
~NonEditableException() throw(); ///< A destructor, as needed by std::exception.
const char* what() const throw(); ///< \brief A function returning error message.
/// \return Error message.
};
/// \class BadParameterException
/// \brief An exception to be thrown on bad command line parameter.
class BadParameterException: public std::exception {
private:
std::string _action;
std::string _parameter;
public:
BadParameterException(std::string parameter); ///< \brief A constructor with parameter.
///< \param parameter A parameter that caused the exception but is not any action parameter.
BadParameterException(std::string action, std::string parameter); ///< \brief A constructor with parameters.
///< \param action An action where exception occured.
///< \param parameter A parameter that caused the exception.
~BadParameterException() throw(); ///< A destructor, as needed by std::exception.
const char* what() const throw(); ///< \brief A function returning error message.
/// \return Error message.
};
}
#endif