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_Solver.h>
12 #include <PlaneGCSSolver_ScalarWrapper.h>
13 #include <SketchSolver_IConstraintWrapper.h>
17 * Wrapper providing operations with PlaneGCS constraints.
19 class PlaneGCSSolver_ConstraintWrapper : public SketchSolver_IConstraintWrapper
22 PlaneGCSSolver_ConstraintWrapper(const GCSConstraintPtr& theConstraint,
23 const SketchSolver_ConstraintType& theType);
24 PlaneGCSSolver_ConstraintWrapper(const std::list<GCSConstraintPtr>& theConstraints,
25 const SketchSolver_ConstraintType& theType);
27 /// \brief Return list of constraints
28 const std::list<GCSConstraintPtr>& constraints() const
29 { return myGCSConstraints; }
30 /// \brief Change list of constraints
31 void setConstraints(const std::list<GCSConstraintPtr>& theConstraints)
32 { myGCSConstraints = theConstraints; }
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; }
53 SketchSolver_ConstraintType myType;
54 ScalarWrapperPtr myValueParam;
55 std::list<GCSConstraintPtr> myGCSConstraints;