cpp_photon/include/exceptions.hpp

214 lines
5.7 KiB
C++
Raw Normal View History

//This file is part of Photon (http://photon.sourceforge.net)
//Copyright (C) 2004-2005 James Turk
//
// Author:
// James Turk (jpt2433@rit.edu)
//
// Version:
2005-03-01 07:51:04 +00:00
// $Id: exceptions.hpp,v 1.4 2005/03/01 07:51:04 cozman Exp $
2005-02-13 22:12:02 +00:00
#ifndef PHOTON_EXCEPTIONS_HPP
#define PHOTON_EXCEPTIONS_HPP
2005-02-13 22:12:02 +00:00
#include "types.hpp"
#include <string>
2005-01-31 15:44:38 +00:00
#include <sstream>
#include <ostream>
2005-01-31 15:44:38 +00:00
#define __FLOC__ __FILE__,__LINE__
namespace photon
{
2005-01-27 05:24:11 +00:00
// Title: Exception/Error Types
// Class: Throwable
// Throwable is the base exception class for Photon.
//
// Throwable is pure virtual, and can not be used directly, Exception and
2005-01-31 15:44:38 +00:00
// Error are available for non-specific exceptions. All exceptions have the
// same interface as Throwable.
//
2005-03-01 07:51:04 +00:00
// Operators:
// ostream& << Throwable - All exceptions defined here can be output via '<<'
//
// Children:
// <Exception> - Base class for all non-fatal exceptions.
// <Error> - Base class for all potentially fatal exceptions.
class Throwable
{
public:
2005-01-31 15:44:38 +00:00
// Function: Throwable
// Constructor for a Throwable object, can specify as little or as much
// information as you'd like when throwing.
//
// Parameters:
// description - description of why exception was thrown [default: empty]
// file - name of file where exception was thrown [default: empty]
// line - line in file where exception was thrown [default: 0]
2005-02-07 01:48:25 +00:00
Throwable(const std::string& description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
virtual ~Throwable() throw()=0;
2005-03-01 07:51:04 +00:00
// Function: what
// Similar to the std::exception family, all photon exceptions (the
// Throwable family) define what() that returns a description of the
// exception.
//
// Returns: std::string describing the error
std::string virtual what() const throw();
friend std::ostream& operator<<(std::ostream& os, const Throwable& rhs);
private:
std::string description_;
2005-01-31 15:44:38 +00:00
std::string file_;
uint line_;
};
// Class: Exception
// Exception is the base exception class, all exceptions inherit from
// it, and it inherits from <Throwable>.
// Exception should be used for hard to classify exceptions.
//
// Exception and children should be used when a problem occurs which is
// recoverable.
//
// See Also:
2005-01-27 05:24:11 +00:00
// <Error>
//
// Parent:
// <Throwable>
//
// Children:
// <ArgumentException>
// <PreconditionException>
// <RangeException>
// <ResourceException>
class Exception : public Throwable
{
public:
2005-02-07 01:48:25 +00:00
Exception(const std::string& description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
std::string what() const throw();
};
// Class: ArgumentException
// ArgumentException should be thrown when an argument is passed to a function
// that is invalid.
//
// Parent:
// <Exception>
class ArgumentException : public Exception
{
public:
2005-02-07 01:48:25 +00:00
ArgumentException(const std::string& description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
std::string what() const throw();
};
// Class: PreconditionException
// PreconditionException should be thrown when a precondition is not met.
//
// Parent:
// <Exception>
class PreconditionException : public Exception
{
public:
2005-02-07 01:48:25 +00:00
PreconditionException(const std::string& description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
std::string what() const throw();
};
// Class: RangeException
// RangeException should be thrown if something (such as an array bound) is out
// of bounds.
//
// Parent:
// <Exception>
class RangeException : public Exception
{
public:
2005-02-07 01:48:25 +00:00
RangeException(const std::string& description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
std::string what() const throw();
};
// Class: ResourceException
// ResourceException should be thrown if there is a problem accessing a
// resource.
//
// Parent:
// <Exception>
class ResourceException : public Exception
{
public:
2005-02-07 01:48:25 +00:00
ResourceException(const std::string& description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
std::string what() const throw();
};
// Class: Error
// Error is the base error class, all errors inherit from it, and it inherits
// from <Throwable>.
// Error should be used for hard to classify errors.
//
// Errors should be used when a problem occurs which is difficult to just
// ignore, usually more severe than exceptions.
//
// See Also:
// <Exception>
//
// Parent:
// <Throwable>
//
// Children:
// <APIError>
// <MemoryError>
class Error : public Throwable
{
public:
2005-02-07 01:48:25 +00:00
Error(const std::string&description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
std::string what() const throw();
};
// Class: MemoryError
// MemoryError should be thrown if an error occurs while allocating memory.
2005-01-31 15:44:38 +00:00
//
// Parent:
// <Error>
class MemoryError : public Error
{
public:
2005-02-07 01:48:25 +00:00
MemoryError(const std::string& description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
std::string what() const throw();
};
// Class: APIError
// APIError should be thrown if an error occurs in code which is not part of
// Photon.
//
// Parent:
// <Throwable>
class APIError : public Error
{
public:
2005-02-07 01:48:25 +00:00
APIError(const std::string& description = std::string(),
const std::string& file = std::string(),
2005-01-31 15:44:38 +00:00
uint line=0) throw();
std::string what() const throw();
};
}
2005-02-13 22:12:02 +00:00
#endif //PHOTON_EXCEPTIONS_HPP