//This file is part of Photon (http://photon.sourceforge.net) //Copyright (C) 2004-2005 James Turk // // Author: // James Turk (jpt2433@rit.edu) // // Version: // $Id: exceptions.h,v 1.3 2005/01/31 15:44:38 cozman Exp $ // // Revisions: // $Log: exceptions.h,v $ // Revision 1.3 2005/01/31 15:44:38 cozman // simplified exceptions // // Revision 1.2 2005/01/27 05:24:11 cozman // minor documentation update // // Revision 1.1 2005/01/27 03:35:23 cozman // initial import (exceptions,types, and logging,oh my!) // // #ifndef PHOTON_EXCEPTIONS_H #define PHOTON_EXCEPTIONS_H #include "types.h" #include #include #include #define __FLOC__ __FILE__,__LINE__ namespace photon { // 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 // Error are available for non-specific exceptions. All exceptions have the // same interface as Throwable. // // Children: // - Base class for all non-fatal exceptions. // - Base class for all potentially fatal exceptions. class Throwable { public: // 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] Throwable(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); virtual ~Throwable() throw()=0; std::string getDesc() const throw(); private: std::string description_; std::string file_; uint line_; }; // Class: Exception // Exception is the base exception class, all exceptions inherit from // it, and it inherits from . // Exception should be used for hard to classify exceptions. // // Exception's children should be used when a problem occurs which is // recoverable. // // Operators: // ostream&<< // // See Also: // // // Parent: // // // Children: // // // // class Exception : public Throwable { public: Exception(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); friend std::ostream& operator<<(std::ostream& os, const Exception& rhs); }; // Class: ArgumentException // ArgumentException should be thrown when an argument is passed to a function // that is invalid. // // Operators: // ostream&<< // // Parent: // class ArgumentException : public Exception { public: ArgumentException(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); friend std::ostream& operator<<(std::ostream& os, const ArgumentException& rhs); }; // Class: PreconditionException // PreconditionException should be thrown when a precondition is not met. // // Operators: // ostream&<< // // Parent: // class PreconditionException : public Exception { public: PreconditionException(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); friend std::ostream& operator<<(std::ostream& os, const PreconditionException& rhs); }; // Class: RangeException // RangeException should be thrown if something (such as an array bound) is out // of bounds. // // Operators: // ostream&<< // // Parent: // class RangeException : public Exception { public: RangeException() throw(); RangeException(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); friend std::ostream& operator<<(std::ostream& os, const RangeException& rhs); }; // Class: ResourceException // ResourceException should be thrown if there is a problem accessing a // resource. // // Operators: // ostream&<< // // Parent: // class ResourceException : public Exception { public: ResourceException() throw(); ResourceException(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); friend std::ostream& operator<<(std::ostream& os, const ResourceException& rhs); }; // Class: Error // GeneralError is the base error class, all errors inherit from it, and it // inherits from . // 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. // // Operators: // ostream&<< // // See Also: // // // Parent: // // // Children: // // class Error : public Throwable { public: Error() throw(); Error(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); friend std::ostream& operator<<(std::ostream& os, const Error& rhs); }; // Class: MemoryError // MemoryError should be thrown if there is an error allocating memory. // // Operators: // ostream&<< // // Parent: // class MemoryError : public Error { public: MemoryError() throw(); MemoryError(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); friend std::ostream& operator<<(std::ostream& os, const MemoryError& rhs); }; // Class: APIError // APIError should be thrown if an error occurs in code which is not part of // Photon. // // Operators: // ostream&<< // // Parent: // class APIError : public Error { public: APIError() throw(); APIError(std::string description = std::string(), std::string file = std::string(), uint line=0) throw(); friend std::ostream& operator<<(std::ostream& os, const APIError& rhs); }; // Section: Utility Functions // Function: require // Similar to an assert, given a condition checks if it is true, and if it is // not, throws an exception. // // An example of when to use require would be in a function that does an // operation to a certain pouinter: // void func() // { // require(pouinter != NULL,"pouinter must be valid"); // // pouinter->doSomething(); // } // // Template Parameters: // ExceptionT - type of exception to throw // // Parameters: // condition - boolean expression to be satisfied // description - description of this condition (optional parameter) template void require(bool condition, std::string description = std::string(), std::string file = std::string(), uint line=0); //definition of require template template void require(bool condition, std::string description, std::string file, uint line) { if(!condition) { throw ExceptionT(description,file,line); } } } #endif //PHOTON_EXCEPTIONS_H