#define PlaneGCSSolver_ConstraintWrapper_H_
#include <PlaneGCSSolver_Defs.h>
-#include <PlaneGCSSolver_Solver.h>
-#include <SketchSolver_IConstraintWrapper.h>
-
+#include <PlaneGCSSolver_ScalarWrapper.h>
/**
- * Wrapper providing operations with SovleSpace constraints.
+ * Wrapper providing operations with PlaneGCS constraints.
*/
-class PlaneGCSSolver_ConstraintWrapper : public SketchSolver_IConstraintWrapper
+class PlaneGCSSolver_ConstraintWrapper
{
public:
- PlaneGCSSolver_ConstraintWrapper(const ConstraintPtr& theOriginal,
- const GCSConstraintPtr& theConstraint,
+ PlaneGCSSolver_ConstraintWrapper(const GCSConstraintPtr& theConstraint,
const SketchSolver_ConstraintType& theType);
- PlaneGCSSolver_ConstraintWrapper(const ConstraintPtr& theOriginal,
- const std::list<GCSConstraintPtr>& theConstraints,
+ PlaneGCSSolver_ConstraintWrapper(const std::list<GCSConstraintPtr>& theConstraints,
const SketchSolver_ConstraintType& theType);
/// \brief Return list of constraints
const std::list<GCSConstraintPtr>& constraints() const
{ return myGCSConstraints; }
+ /// \brief Change list of constraints
+ void setConstraints(const std::list<GCSConstraintPtr>& theConstraints)
+ { myGCSConstraints = theConstraints; }
- /// \brief Return ID of current entity
- virtual ConstraintID id() const
+ /// \brief Return ID of current constraint
+ const ConstraintID& id() const
{ return myID; }
/// \brief Change constraint ID
- void setId( const ConstraintID& theID);
-
- /// \brief Change group for the constraint
- virtual void setGroup(const GroupID& theGroup);
- /// \brief Return identifier of the group the constraint belongs to
- virtual GroupID group() const
- { return myGroup; }
+ virtual void setId(const ConstraintID& theID);
/// \brief Return type of current entity
virtual SketchSolver_ConstraintType type() const
/// \brief Assign numeric parameter of constraint
virtual void setValue(const double& theValue);
+ /// \brief Return numeric parameter of constraint
+ virtual double value() const;
/// \brief Change parameter representing the value of constraint
- void setValueParameter(const ParameterWrapperPtr& theValue);
+ void setValueParameter(const ScalarWrapperPtr& theValue);
/// \brief Return parametric representation of constraint value
- const ParameterWrapperPtr& valueParameter() const
+ const ScalarWrapperPtr& valueParameter() const
{ return myValueParam; }
- /// \brief Verify the feature is used in the constraint
- virtual bool isUsed(FeaturePtr theFeature) const;
- /// \brief Verify the attribute is used in the constraint
- virtual bool isUsed(AttributePtr theAttribute) const;
-
- /// \brief Compare current constraint with other
- virtual bool isEqual(const ConstraintWrapperPtr& theOther);
-
- /// \brief Update values of parameters of this constraint by the parameters of given one
- /// \return \c true if some parameters change their values
- virtual bool update(const std::shared_ptr<SketchSolver_IConstraintWrapper>& theOther);
-
private:
- ConstraintID myID;
- GroupID myGroup;
+ ConstraintID myID;
SketchSolver_ConstraintType myType;
- ParameterWrapperPtr myValueParam;
+ ScalarWrapperPtr myValueParam;
std::list<GCSConstraintPtr> myGCSConstraints;
};
+typedef std::shared_ptr<PlaneGCSSolver_ConstraintWrapper> ConstraintWrapperPtr;
+
#endif