forked from bartvdbraak/blender
246 lines
9.3 KiB
C++
246 lines
9.3 KiB
C++
/***************************************************************************
|
|
tag: Erwin Aertbelien Mon Jan 10 16:38:38 CET 2005 error.h
|
|
|
|
error.h - description
|
|
-------------------
|
|
begin : Mon January 10 2005
|
|
copyright : (C) 2005 Erwin Aertbelien
|
|
email : erwin.aertbelien@mech.kuleuven.ac.be
|
|
|
|
***************************************************************************
|
|
* This library is free software; you can redistribute it and/or *
|
|
* modify it under the terms of the GNU Lesser General Public *
|
|
* License as published by the Free Software Foundation; either *
|
|
* version 2.1 of the License, or (at your option) any later version. *
|
|
* *
|
|
* This library is distributed in the hope that it will be useful, *
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
|
|
* Lesser General Public License for more details. *
|
|
* *
|
|
* You should have received a copy of the GNU Lesser General Public *
|
|
* License along with this library; if not, write to the Free Software *
|
|
* Foundation, Inc., 51 Franklin Street, *
|
|
* Fifth Floor, Boston, MA 02110-1301, USA. *
|
|
* *
|
|
***************************************************************************/
|
|
|
|
|
|
/*****************************************************************************
|
|
* \file
|
|
* Defines the exception classes that can be thrown
|
|
* \author
|
|
* Erwin Aertbelien, Div. PMA, Dep. of Mech. Eng., K.U.Leuven
|
|
*
|
|
* \version
|
|
* ORO_Geometry V0.2
|
|
*
|
|
* \par History
|
|
* - $log$
|
|
*
|
|
* \par Release
|
|
* $Id$
|
|
* $Name: $
|
|
****************************************************************************/
|
|
#ifndef ERROR_H_84822 // to make it unique, a random number
|
|
#define ERROR_H_84822
|
|
|
|
#include "utility.h"
|
|
#include <string>
|
|
|
|
namespace KDL {
|
|
|
|
/**
|
|
* Base class for errors generated by ORO_Geometry
|
|
*/
|
|
class Error {
|
|
public:
|
|
/** Returns a description string describing the error.
|
|
* the returned pointer only garanteed to exists as long as
|
|
* the Error object exists.
|
|
*/
|
|
virtual ~Error() {}
|
|
virtual const char* Description() const {return "Unspecified Error\n";}
|
|
|
|
virtual int GetType() const {return 0;}
|
|
};
|
|
|
|
|
|
class Error_IO : public Error {
|
|
std::string msg;
|
|
int typenr;
|
|
public:
|
|
Error_IO(const std::string& _msg="Unspecified I/O Error",int typenr=0):msg(_msg) {}
|
|
virtual const char* Description() const {return msg.c_str();}
|
|
virtual int GetType() const {return typenr;}
|
|
};
|
|
class Error_BasicIO : public Error_IO {};
|
|
class Error_BasicIO_File : public Error_BasicIO {
|
|
public:
|
|
virtual const char* Description() const {return "Error while reading stream";}
|
|
virtual int GetType() const {return 1;}
|
|
};
|
|
class Error_BasicIO_Exp_Delim : public Error_BasicIO {
|
|
public:
|
|
virtual const char* Description() const {return "Expected Delimiter not encountered";}
|
|
virtual int GetType() const {return 2;}
|
|
};
|
|
class Error_BasicIO_Not_A_Space : public Error_BasicIO {
|
|
public:
|
|
virtual const char* Description() const {return "Expected space,tab or newline not encountered";}
|
|
virtual int GetType() const {return 3;}
|
|
};
|
|
class Error_BasicIO_Unexpected : public Error_BasicIO {
|
|
public:
|
|
virtual const char* Description() const {return "Unexpected character";}
|
|
virtual int GetType() const {return 4;}
|
|
};
|
|
|
|
class Error_BasicIO_ToBig : public Error_BasicIO {
|
|
public:
|
|
virtual const char* Description() const {return "Word that is read out of stream is bigger than maxsize";}
|
|
virtual int GetType() const {return 5;}
|
|
};
|
|
|
|
class Error_BasicIO_Not_Opened : public Error_BasicIO {
|
|
public:
|
|
virtual const char* Description() const {return "File cannot be opened";}
|
|
virtual int GetType() const {return 6;}
|
|
};
|
|
class Error_FrameIO : public Error_IO {};
|
|
class Error_Frame_Vector_Unexpected_id : public Error_FrameIO {
|
|
public:
|
|
virtual const char* Description() const {return "Unexpected identifier, expecting a vector (explicit or ZERO)";}
|
|
virtual int GetType() const {return 101;}
|
|
};
|
|
class Error_Frame_Frame_Unexpected_id : public Error_FrameIO {
|
|
public:
|
|
virtual const char* Description() const {return "Unexpected identifier, expecting a Frame (explicit or DH)";}
|
|
virtual int GetType() const {return 102;}
|
|
};
|
|
class Error_Frame_Rotation_Unexpected_id : public Error_FrameIO {
|
|
public:
|
|
virtual const char* Description() const {return "Unexpected identifier, expecting a Rotation (explicit or EULERZYX, EULERZYZ, RPY,ROT,IDENTITY)";}
|
|
virtual int GetType() const {return 103;}
|
|
};
|
|
class Error_ChainIO : public Error {};
|
|
class Error_Chain_Unexpected_id : public Error_ChainIO {
|
|
public:
|
|
virtual const char* Description() const {return "Unexpected identifier, expecting TRANS or ROT";}
|
|
virtual int GetType() const {return 201;}
|
|
};
|
|
//! Error_Redundancy indicates an error that occured during solving for redundancy.
|
|
class Error_RedundancyIO:public Error_IO {};
|
|
class Error_Redundancy_Illegal_Resolutiontype : public Error_RedundancyIO {
|
|
public:
|
|
virtual const char* Description() const {return "Illegal Resolutiontype is used in I/O with ResolutionTask";}
|
|
virtual int GetType() const {return 301;}
|
|
};
|
|
class Error_Redundancy:public Error {};
|
|
class Error_Redundancy_Unavoidable : public Error_Redundancy {
|
|
public:
|
|
virtual const char* Description() const {return "Joint limits cannot be avoided";}
|
|
virtual int GetType() const {return 1002;}
|
|
};
|
|
class Error_Redundancy_Low_Manip: public Error_Redundancy {
|
|
public:
|
|
virtual const char* Description() const {return "Manipulability is very low";}
|
|
virtual int GetType() const {return 1003;}
|
|
};
|
|
class Error_MotionIO : public Error {};
|
|
class Error_MotionIO_Unexpected_MotProf : public Error_MotionIO {
|
|
public:
|
|
virtual const char* Description() const { return "Wrong keyword while reading motion profile";}
|
|
virtual int GetType() const {return 2001;}
|
|
};
|
|
class Error_MotionIO_Unexpected_Traj : public Error_MotionIO {
|
|
public:
|
|
virtual const char* Description() const { return "Trajectory type keyword not known";}
|
|
virtual int GetType() const {return 2002;}
|
|
};
|
|
|
|
class Error_MotionPlanning : public Error {};
|
|
|
|
class Error_MotionPlanning_Circle_ToSmall : public Error_MotionPlanning {
|
|
public:
|
|
virtual const char* Description() const { return "Circle : radius is to small";}
|
|
virtual int GetType() const {return 3001;}
|
|
};
|
|
|
|
class Error_MotionPlanning_Circle_No_Plane : public Error_MotionPlanning {
|
|
public:
|
|
virtual const char* Description() const { return "Circle : Plane for motion is not properly defined";}
|
|
virtual int GetType() const {return 3002;}
|
|
};
|
|
|
|
class Error_MotionPlanning_Incompatible: public Error_MotionPlanning {
|
|
public:
|
|
virtual const char* Description() const { return "Acceleration of a rectangular velocityprofile cannot be used";}
|
|
virtual int GetType() const {return 3003;}
|
|
};
|
|
|
|
class Error_MotionPlanning_Not_Feasible: public Error_MotionPlanning {
|
|
public:
|
|
virtual const char* Description() const { return "Motion Profile with requested parameters is not feasible";}
|
|
virtual int GetType() const {return 3004;}
|
|
};
|
|
|
|
class Error_MotionPlanning_Not_Applicable: public Error_MotionPlanning {
|
|
public:
|
|
virtual const char* Description() const { return "Method is not applicable for this derived object";}
|
|
virtual int GetType() const {return 3004;}
|
|
};
|
|
//! Abstract subclass of all errors that can be thrown by Adaptive_Integrator
|
|
class Error_Integrator : public Error {};
|
|
|
|
//! Error_Stepsize_Underflow is thrown if the stepsize becomes to small
|
|
class Error_Stepsize_Underflow : public Error_Integrator {
|
|
public:
|
|
virtual const char* Description() const { return "Stepsize Underflow";}
|
|
virtual int GetType() const {return 4001;}
|
|
};
|
|
|
|
//! Error_To_Many_Steps is thrown if the number of steps needed to
|
|
//! integrate to the desired accuracy becomes to big.
|
|
class Error_To_Many_Steps : public Error_Integrator {
|
|
public:
|
|
virtual const char* Description() const { return "To many steps"; }
|
|
virtual int GetType() const {return 4002;}
|
|
};
|
|
|
|
//! Error_Stepsize_To_Small is thrown if the stepsize becomes to small
|
|
class Error_Stepsize_To_Small : public Error_Integrator {
|
|
public:
|
|
virtual const char* Description() const { return "Stepsize to small"; }
|
|
virtual int GetType() const {return 4003;}
|
|
};
|
|
|
|
class Error_Criterium : public Error {};
|
|
|
|
class Error_Criterium_Unexpected_id: public Error_Criterium {
|
|
public:
|
|
virtual const char* Description() const { return "Unexpected identifier while reading a criterium"; }
|
|
virtual int GetType() const {return 5001;}
|
|
};
|
|
|
|
class Error_Limits : public Error {};
|
|
|
|
class Error_Limits_Unexpected_id: public Error_Limits {
|
|
public:
|
|
virtual const char* Description() const { return "Unexpected identifier while reading a jointlimits"; }
|
|
virtual int GetType() const {return 6001;}
|
|
};
|
|
|
|
|
|
class Error_Not_Implemented: public Error {
|
|
public:
|
|
virtual const char* Description() const { return "The requested object/method/function is not implemented"; }
|
|
virtual int GetType() const {return 7000;}
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|