Salome HOME
dumping to py, sip, translations
[modules/hydro.git] / src / HYDROPy / HYDROData_BCPolygon.sip
1 // Copyright (C) 2014-2015  EDF-R&D
2 // This library is free software; you can redistribute it and/or
3 // modify it under the terms of the GNU Lesser General Public
4 // License as published by the Free Software Foundation; either
5 // version 2.1 of the License, or (at your option) any later version.
6 //
7 // This library is distributed in the hope that it will be useful,
8 // but WITHOUT ANY WARRANTY; without even the implied warranty of
9 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
10 // Lesser General Public License for more details.
11 //
12 // You should have received a copy of the GNU Lesser General Public
13 // License along with this library; if not, write to the Free Software
14 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
15 //
16 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
17 //
18
19 %ExportedHeaderCode
20 #include <HYDROData_BCPolygon.h>
21 %End
22
23 class HYDROData_BCPolygon : public HYDROData_Object
24 {
25
26 %TypeHeaderCode
27 #include <HYDROData_BCPolygon.h>
28 %End
29
30 %ConvertToSubClassCode
31     switch ( sipCpp->GetKind() )
32     {
33       case KIND_BC_POLYGON:
34         sipClass = sipClass_HYDROData_BCPolygon;
35         break;
36
37       default:
38         // We don't recognise the type.
39         sipClass = NULL;
40     }
41 %End
42
43 public:      
44
45   /**
46    * Sets reference polyline object for boundary polygon.
47    */
48   void SetPolyline( HYDROData_PolylineXY thePolyline ) [void (const opencascade::handle<HYDROData_PolylineXY>&)];
49   %MethodCode
50
51     Handle(HYDROData_PolylineXY) aRefPolyline =
52       Handle(HYDROData_PolylineXY)::DownCast( createHandle( a0 ) );
53     if ( !aRefPolyline.IsNull() )
54     {
55       Py_BEGIN_ALLOW_THREADS
56       sipSelfWasArg ? sipCpp->HYDROData_BCPolygon::SetPolyline( aRefPolyline ) : 
57                       sipCpp->SetPolyline( aRefPolyline );
58       Py_END_ALLOW_THREADS
59     }
60
61   %End
62
63   /**
64    * Returns reference polyline object of boundary polygon.
65    */
66   HYDROData_PolylineXY GetPolyline() const [opencascade::handle<HYDROData_PolylineXY> ()];
67   %MethodCode
68
69     Handle(HYDROData_PolylineXY) aRefPolyline;
70     
71     Py_BEGIN_ALLOW_THREADS
72     aRefPolyline = sipSelfWasArg ? sipCpp->HYDROData_BCPolygon::GetPolyline() : 
73                                    sipCpp->GetPolyline();
74     Py_END_ALLOW_THREADS
75     
76     sipRes = (HYDROData_PolylineXY*)createPointer( aRefPolyline );
77   
78   %End
79
80   /**
81    * Remove reference polyline object of boundary polygon.
82    */
83   void RemovePolyline();
84
85   /**
86    * Set boundary type for boundary polygon.
87    */
88   void SetBoundaryType( int ) const;
89
90   /**
91    * Get boundary type for boundary polygon.
92    */
93    int GetBoundaryType() const;
94
95 protected:
96
97   /**
98    * Creates new object in the internal data structure. Use higher level objects 
99    * to create objects with real content.
100    */
101   HYDROData_BCPolygon();
102
103   /**
104    * Destructs properties of the object and object itself, removes it from the document.
105    */
106   ~HYDROData_BCPolygon();
107 };
108
109