1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
3 // File: PlaneGCSSolver_ConstraintWrapper.h
4 // Created: 14 Dec 2015
5 // Author: Artem ZHIDKOV
7 #ifndef PlaneGCSSolver_ConstraintWrapper_H_
8 #define PlaneGCSSolver_ConstraintWrapper_H_
10 #include <PlaneGCSSolver_Defs.h>
11 #include <PlaneGCSSolver_ScalarWrapper.h>
14 * Wrapper providing operations with PlaneGCS constraints.
16 class PlaneGCSSolver_ConstraintWrapper
19 PlaneGCSSolver_ConstraintWrapper(const GCSConstraintPtr& theConstraint,
20 const SketchSolver_ConstraintType& theType);
21 PlaneGCSSolver_ConstraintWrapper(const std::list<GCSConstraintPtr>& theConstraints,
22 const SketchSolver_ConstraintType& theType);
24 /// \brief Return list of constraints
25 const std::list<GCSConstraintPtr>& constraints() const
26 { return myGCSConstraints; }
27 /// \brief Change list of constraints
28 void setConstraints(const std::list<GCSConstraintPtr>& theConstraints)
29 { myGCSConstraints = theConstraints; }
31 /// \brief Return ID of current constraint
32 const ConstraintID& id() const
34 /// \brief Change constraint ID
35 virtual void setId(const ConstraintID& theID);
37 /// \brief Return type of current entity
38 virtual SketchSolver_ConstraintType type() const
41 /// \brief Assign numeric parameter of constraint
42 virtual void setValue(const double& theValue);
43 /// \brief Return numeric parameter of constraint
44 virtual double value() const;
46 /// \brief Change parameter representing the value of constraint
47 void setValueParameter(const ScalarWrapperPtr& theValue);
48 /// \brief Return parametric representation of constraint value
49 const ScalarWrapperPtr& valueParameter() const
50 { return myValueParam; }
54 SketchSolver_ConstraintType myType;
55 ScalarWrapperPtr myValueParam;
56 std::list<GCSConstraintPtr> myGCSConstraints;
59 typedef std::shared_ptr<PlaneGCSSolver_ConstraintWrapper> ConstraintWrapperPtr;