0024750: Replace instantiations of TCollection generic classes by NCollection templat...
[occt.git] / src / XSControl / XSControl_Vars.cxx
1 // Copyright (c) 1999-2014 OPEN CASCADE SAS
2 //
3 // This file is part of Open CASCADE Technology software library.
4 //
5 // This library is free software; you can redistribute it and/or modify it under
6 // the terms of the GNU Lesser General Public License version 2.1 as published
7 // by the Free Software Foundation, with special exception defined in the file
8 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9 // distribution for complete text of the license and disclaimer of any warranty.
10 //
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
13
14 #include <XSControl_Vars.ixx>
15 #include <Geom_CartesianPoint.hxx>
16 #include <Geom2d_CartesianPoint.hxx>
17 #include <TopoDS_HShape.hxx>
18
19 #include <Interface_Macros.hxx>
20
21
22 XSControl_Vars::XSControl_Vars  ()
23     {  thevars = new Dico_DictionaryOfTransient;  }
24
25 void  XSControl_Vars::Set
26   (const Standard_CString name,
27    const Handle(Standard_Transient)& val)
28 {
29   thevars->SetItem (name,val);
30 }
31
32 Handle(Standard_Transient)  XSControl_Vars::Get ( Standard_CString& name) const
33 {
34   Handle(Standard_Transient) val;
35   if (!thevars->GetItem (name,val)) val.Nullify();
36   return val;
37 }
38
39 Handle(Geom_Geometry)  XSControl_Vars::GetGeom ( Standard_CString& name) const
40 {  return GetCasted(Geom_Geometry,Get(name));  }
41
42 Handle(Geom2d_Curve)  XSControl_Vars::GetCurve2d ( Standard_CString& name) const
43 {  return GetCasted(Geom2d_Curve,Get(name));  }
44
45 Handle(Geom_Curve)  XSControl_Vars::GetCurve ( Standard_CString& name) const
46 {  return GetCasted(Geom_Curve,Get(name));  }
47
48 Handle(Geom_Surface)  XSControl_Vars::GetSurface ( Standard_CString& name) const
49 {  return GetCasted(Geom_Surface,Get(name));  }
50
51
52 void  XSControl_Vars::SetPoint (const Standard_CString name, const gp_Pnt& val)
53 {  Set (name, new Geom_CartesianPoint(val));  }
54
55 Standard_Boolean  XSControl_Vars::GetPoint (Standard_CString& name, gp_Pnt& pnt) const
56 {
57   DeclareAndCast(Geom_CartesianPoint,val,Get(name));
58   if (val.IsNull()) return Standard_False;
59   pnt = val->Pnt();
60   return Standard_True;
61 }
62
63
64 void  XSControl_Vars::SetPoint2d (const Standard_CString name, const gp_Pnt2d& val)
65 {  Set (name, new Geom2d_CartesianPoint(val));  }
66
67 Standard_Boolean  XSControl_Vars::GetPoint2d (Standard_CString& name, gp_Pnt2d& pnt) const
68 {
69   DeclareAndCast(Geom2d_CartesianPoint,val,Get(name));
70   if (val.IsNull()) return Standard_False;
71   pnt = val->Pnt2d();
72   return Standard_True;
73 }
74
75
76 void  XSControl_Vars::SetShape (const Standard_CString name, const TopoDS_Shape& val)
77 {  Set (name, new TopoDS_HShape(val));  }
78
79 TopoDS_Shape  XSControl_Vars::GetShape (Standard_CString& name) const
80 {
81   TopoDS_Shape sh;
82   DeclareAndCast(TopoDS_HShape,val,Get(name));
83   if (!val.IsNull()) sh = val->Shape();
84   return sh;
85 }