From f57cd95dbac7e929f0d9fd00ff6fc2840b0c83bb Mon Sep 17 00:00:00 2001 From: "chappuis.daniel" Date: Fri, 9 Jul 2010 10:05:02 +0000 Subject: [PATCH] Throw an exception if the argument to setRestitution() is not between 0 and 1 git-svn-id: https://reactphysics3d.googlecode.com/svn/trunk@350 92aac97c-a6ce-11dd-a772-7fcde58d38e6 --- sources/reactphysics3d/body/RigidBody.h | 38 ++++++++++++++----------- 1 file changed, 22 insertions(+), 16 deletions(-) diff --git a/sources/reactphysics3d/body/RigidBody.h b/sources/reactphysics3d/body/RigidBody.h index d6aebf9f..351a5c9a 100644 --- a/sources/reactphysics3d/body/RigidBody.h +++ b/sources/reactphysics3d/body/RigidBody.h @@ -55,20 +55,20 @@ class RigidBody : public Body { RigidBody(const RigidBody& rigidBody); // Copy-constructor virtual ~RigidBody(); // Destructor - Matrix3x3 getInertiaTensorLocal() const; // Return the local inertia tensor of the body (in body coordinates) - void setInertiaTensorLocal(const Matrix3x3& inertiaTensorLocal); // Set the local inertia tensor of the body (in body coordinates) - Matrix3x3 getInertiaTensorWorld() const; // Return the inertia tensor in world coordinates - Matrix3x3 getInertiaTensorInverseWorld() const; // Return the inverse of the inertia tensor in world coordinates - BodyState& getCurrentBodyState(); // Return a reference to the current state of the body - BodyState& getPreviousBodyState(); // TODO : DELETE THIS - void setInterpolationFactor(double factor); // Set the interpolation factor of the body - BodyState getInterpolatedState() const; // Compute and return the interpolated state - void setLinearVelocity(const Vector3D& linearVelocity); // Set the linear velocity of the rigid body - double getRestitution() const; // Get the restitution coefficient - void setRestitution(double restitution); // Set the restitution coefficient - void updatePreviousBodyState(); // Update the previous body state of the body - const OBB* const getOBB() const; // Return the oriented bounding box of the rigid body - void update(); // Update the rigid body in order to reflect a change in the body state + Matrix3x3 getInertiaTensorLocal() const; // Return the local inertia tensor of the body (in body coordinates) + void setInertiaTensorLocal(const Matrix3x3& inertiaTensorLocal); // Set the local inertia tensor of the body (in body coordinates) + Matrix3x3 getInertiaTensorWorld() const; // Return the inertia tensor in world coordinates + Matrix3x3 getInertiaTensorInverseWorld() const; // Return the inverse of the inertia tensor in world coordinates + BodyState& getCurrentBodyState(); // Return a reference to the current state of the body + BodyState& getPreviousBodyState(); // TODO : DELETE THIS + void setInterpolationFactor(double factor); // Set the interpolation factor of the body + BodyState getInterpolatedState() const; // Compute and return the interpolated state + void setLinearVelocity(const Vector3D& linearVelocity); // Set the linear velocity of the rigid body + double getRestitution() const; // Get the restitution coefficient + void setRestitution(double restitution) throw(std::invalid_argument); // Set the restitution coefficient + void updatePreviousBodyState(); // Update the previous body state of the body + const OBB* const getOBB() const; // Return the oriented bounding box of the rigid body + void update(); // Update the rigid body in order to reflect a change in the body state }; // --- Inline functions --- // @@ -139,8 +139,14 @@ inline double RigidBody::getRestitution() const { } // Set the restitution coefficient -inline void RigidBody::setRestitution(double restitution) { - this->restitution = restitution; +inline void RigidBody::setRestitution(double restitution) throw(std::invalid_argument) { + // Check if the restitution coefficient is between 0 and 1 + if (restitution >= 0.0 && restitution <= 1.0) { + this->restitution = restitution; + } + else { + throw std::invalid_argument("Error : the restitution coefficent must be between 0 and 1"); + } } // Update the previous body state of the body