X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROPy%2FHYDROData_Document.sip;h=882fe167ab7cd1444c472ad7bcc15896a8810877;hb=58bb6b7459bebeeb089c9ed486c4683a8bae7288;hp=57f60e9bb7dc2cb06f3034b83af3b0b6f597074c;hpb=d0413fc6f8d2c004c7d2baac5d174c0502417d70;p=modules%2Fhydro.git diff --git a/src/HYDROPy/HYDROData_Document.sip b/src/HYDROPy/HYDROData_Document.sip index 57f60e9b..882fe167 100644 --- a/src/HYDROPy/HYDROData_Document.sip +++ b/src/HYDROPy/HYDROData_Document.sip @@ -1,12 +1,8 @@ -// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE -// -// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, -// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS -// +// Copyright (C) 2014-2015 EDF-R&D // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either -// version 2.1 of the License. +// version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -24,6 +20,12 @@ #include %End +%ModuleHeaderCode +HYDROData_Entity* copyObject( HYDROData_Entity* theObject ); +Handle(HYDROData_Entity) createHandle( HYDROData_Entity* theObject ); +HYDROData_Entity* createPointer( const Handle(HYDROData_Entity)& theObject ); +%End + enum Data_DocError { DocError_OK = 0, ///< success DocError_ResourcesProblem, ///< resources files are invalid or not found @@ -33,34 +35,183 @@ enum Data_DocError { DocError_UnknownProblem ///< problem has unknown nature }; -class HYDROData_Document +class HYDROData_Document { %TypeHeaderCode #include %End %ConvertToSubClassCode - if ( !Handle(HYDROData_Document)::DownCast( sipCpp ).IsNull() ) + HYDROData_Document* aDoc = dynamic_cast< HYDROData_Document*>( sipCpp ); + if ( aDoc ) sipClass = sipClass_HYDROData_Document; else sipClass = NULL; %End +%TypeCode + + HYDROData_Entity* copyObject( HYDROData_Entity* theObject ) + { + HYDROData_Entity* aRes = NULL; + if ( theObject == NULL ) + return aRes; + + switch( theObject->GetKind() ) + { + case KIND_IMAGE: + { + aRes = new HYDROData_Image( *dynamic_cast( theObject ) ); + break; + } + case KIND_POLYLINE: + { + aRes = new HYDROData_Polyline3D( *dynamic_cast( theObject ) ); + break; + } + case KIND_BATHYMETRY: + { + aRes = new HYDROData_Bathymetry( *dynamic_cast( theObject ) ); + break; + } + case KIND_ALTITUDE: + { + aRes = new HYDROData_AltitudeObject( *dynamic_cast( theObject ) ); + break; + } + case KIND_IMMERSIBLE_ZONE: + { + aRes = new HYDROData_ImmersibleZone( *dynamic_cast( theObject ) ); + break; + } + case KIND_RIVER: + { + aRes = new HYDROData_River( *dynamic_cast( theObject ) ); + break; + } + case KIND_STREAM: + { + aRes = new HYDROData_Stream( *dynamic_cast( theObject ) ); + break; + } + case KIND_CONFLUENCE: + { + aRes = new HYDROData_Confluence( *dynamic_cast( theObject ) ); + break; + } + case KIND_CHANNEL: + { + aRes = new HYDROData_Channel( *dynamic_cast( theObject ) ); + break; + } + case KIND_OBSTACLE: + { + aRes = new HYDROData_Obstacle( *dynamic_cast( theObject ) ); + break; + } + case KIND_DIGUE: + { + aRes = new HYDROData_Digue( *dynamic_cast( theObject ) ); + break; + } + case KIND_PROFILE: + { + aRes = new HYDROData_Profile( *dynamic_cast( theObject ) ); + break; + } + case KIND_PROFILEUZ: + { + aRes = new HYDROData_ProfileUZ( *dynamic_cast( theObject ) ); + break; + } + case KIND_POLYLINEXY: + { + aRes = new HYDROData_PolylineXY( *dynamic_cast( theObject ) ); + break; + } + case KIND_CALCULATION: + { + aRes = new HYDROData_CalculationCase( *dynamic_cast( theObject ) ); + break; + } + case KIND_REGION: + { + aRes = new HYDROData_Region( *dynamic_cast( theObject ) ); + break; + } + case KIND_ZONE: + { + aRes = new HYDROData_Zone( *dynamic_cast( theObject ) ); + break; + } + case KIND_SHAPES_GROUP: + { + aRes = new HYDROData_ShapesGroup( *dynamic_cast( theObject ) ); + break; + } + case KIND_SPLIT_GROUP: + { + aRes = new HYDROData_SplitShapesGroup( *dynamic_cast( theObject ) ); + break; + } + case KIND_OBSTACLE_ALTITUDE: + { + aRes = new HYDROData_ObstacleAltitude( *dynamic_cast( theObject ) ); + break; + } + case KIND_STREAM_ALTITUDE: + { + aRes = new HYDROData_StreamAltitude( *dynamic_cast( theObject ) ); + break; + } + case KIND_STRICKLER_TABLE: + { + aRes = new HYDROData_StricklerTable( *dynamic_cast( theObject ) ); + break; + } + case KIND_LAND_COVER_MAP: + { + aRes = new HYDROData_LandCoverMap( *dynamic_cast( theObject ) ); + break; + } + } + + return aRes; + } + + Handle(HYDROData_Entity) createHandle( HYDROData_Entity* theObject ) + { + Handle(HYDROData_Entity) aRes = copyObject( theObject ); + return aRes; + } + + HYDROData_Entity* createPointer( const Handle(HYDROData_Entity)& theObject ) + { + HYDROData_Entity* aRes = NULL; + + if ( !theObject.IsNull() ) + aRes = copyObject( theObject.operator->() ); + + return aRes; + } + +%End + public: //! Returns the existing document or creates new if it is not exist - static HYDROData_Document Document( const int theStudyID ) [Handle_HYDROData_Document (const int)] ; + static HYDROData_Document Document( const int theStudyID ) [opencascade::handle (const int)] ; %MethodCode + Handle(HYDROData_Document) aDocument; + Py_BEGIN_ALLOW_THREADS - Handle(HYDROData_Document) aDocument = HYDROData_Document::Document( a0 ); + aDocument = HYDROData_Document::Document( a0 ); + Py_END_ALLOW_THREADS + if ( !aDocument.IsNull() ) - { sipRes = aDocument.operator->(); - } - - Py_END_ALLOW_THREADS - + %End //! Returns true if data model contains document for this study @@ -123,35 +274,46 @@ public: //! Creates and locates in the document a new object //! \param theKind kind of the created object, can not be UNKNOWN //! \returns the created object - HYDROData_Object CreateObject( const ObjectKind theKind ) [Handle_HYDROData_Object (const ObjectKind)] ; + HYDROData_Entity CreateObject( const ObjectKind theKind ) [opencascade::handle (const ObjectKind)] ; %MethodCode + Handle(HYDROData_Entity) anObject; Py_BEGIN_ALLOW_THREADS + anObject = sipSelfWasArg ? sipCpp->HYDROData_Document::CreateObject( a0 ) : + sipCpp->CreateObject( a0 ); + Py_END_ALLOW_THREADS + + sipRes = createPointer( anObject ); - Handle(HYDROData_Object) anObject = - sipSelfWasArg ? sipCpp->HYDROData_Document::CreateObject( a0 ) : sipCpp->CreateObject( a0 ); - if ( !anObject.IsNull() ) - { - switch( anObject->GetKind() ) - { - case KIND_BATHYMETRY: - { - Handle(HYDROData_Bathymetry) aBathymetry = - Handle(HYDROData_Bathymetry)::DownCast( anObject ); - sipRes = new HYDROData_Bathymetry( *aBathymetry.operator->() ); - break; - } - } - } - + %End + + HYDROData_Entity FindObjectByName( const QString& theName, + const ObjectKind theKind = KIND_UNKNOWN ) + [opencascade::handle (const QString&, const ObjectKind)] ; + %MethodCode + + Handle(HYDROData_Entity) anObject; + Py_BEGIN_ALLOW_THREADS + anObject = sipSelfWasArg ? sipCpp->HYDROData_Document::FindObjectByName( *a0, a1 ) : + sipCpp->FindObjectByName( *a0, a1 ); Py_END_ALLOW_THREADS + + sipRes = createPointer( anObject ); %End -protected: + HYDROData_SequenceOfObjects FindObjectsByNames( const QStringList& theNames, + const ObjectKind theKind = KIND_UNKNOWN ); + + void SetLocalCS( double, double ); + + //! Get the appropriate interpolator by the name. + HYDROData_IProfilesInterpolator* GetInterpolator( const TCollection_AsciiString& theName ) const; - //friend class HYDROData_Iterator; - //friend class test_HYDROData_Document; + //! Get list of registered interpolator names. + NCollection_Sequence GetInterpolatorNames() const; + +protected: //! Creates new document: private because "Document" method must be used instead of direct creation. HYDROData_Document();