+// 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, 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
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
#include "HYDROData_Iterator.h"
#include "HYDROData_CalculationCase.h"
#include "HYDROData_Channel.h"
#include "HYDROData_Confluence.h"
+#include "HYDROData_DummyObject3D.h"
#include "HYDROData_Digue.h"
+#include "HYDROData_ShapesGroup.h"
#include "HYDROData_Image.h"
#include "HYDROData_ImmersibleZone.h"
#include "HYDROData_Obstacle.h"
-#include "HYDROData_Polyline.h"
+#include "HYDROData_ObstacleAltitude.h"
+#include "HYDROData_ChannelAltitude.h"
+#include "HYDROData_Polyline3D.h"
+#include "HYDROData_PolylineXY.h"
#include "HYDROData_Profile.h"
#include "HYDROData_ProfileUZ.h"
#include "HYDROData_VisualState.h"
#include "HYDROData_Region.h"
#include "HYDROData_River.h"
+#include "HYDROData_SplittedShapesGroup.h"
#include "HYDROData_Stream.h"
+#include "HYDROData_StreamAltitude.h"
#include "HYDROData_Zone.h"
+#include "HYDROData_StricklerTable.h"
+#include "HYDROData_LandCover.h"
#include <TDataStd_Name.hxx>
#include <TDataStd_NamedData.hxx>
#include <NCollection_DataMap.hxx>
+#define _DEVDEBUG_
+#include "HYDRO_trace.hxx"
+
//! Returns label by root objects kind and the kind of the object
static TDF_Label GetLabelByKind(TDF_Label theRoot, ObjectKind theKind)
{
return theRoot.FindChild(theKind);
}
-HYDROData_Iterator::HYDROData_Iterator(Handle(HYDROData_Document) theDoc, ObjectKind theKind)
- : myIter(GetLabelByKind(theDoc->LabelOfObjects(), theKind),
- TDataStd_Name::GetID(), theKind == KIND_UNKNOWN) // iterate all sub-objects for unknown kind
+HYDROData_Iterator::HYDROData_Iterator( const Handle(HYDROData_Document)& theDoc,
+ const ObjectKind theKind )
+: myIter( GetLabelByKind( theDoc->LabelOfObjects(), theKind ),
+ TDataStd_Name::GetID(), theKind == KIND_UNKNOWN ) // iterate all sub-objects for unknown kind
{
}
switch( aKind )
{
- case KIND_IMAGE:
- aResult = new HYDROData_Image();
- break;
- case KIND_POLYLINE:
- aResult = new HYDROData_Polyline();
- break;
- case KIND_BATHYMETRY:
- aResult = new HYDROData_Bathymetry();
- break;
- case KIND_ALTITUDE:
- aResult = new HYDROData_AltitudeObject();
- break;
- case KIND_IMMERSIBLE_ZONE:
- aResult = new HYDROData_ImmersibleZone();
- break;
- case KIND_RIVER:
- aResult = new HYDROData_River();
- break;
- case KIND_STREAM:
- aResult = new HYDROData_Stream();
- break;
- case KIND_CONFLUENCE:
- aResult = new HYDROData_Confluence();
- break;
- case KIND_CHANNEL:
- aResult = new HYDROData_Channel();
- break;
- case KIND_OBSTACLE:
- aResult = new HYDROData_Obstacle();
- break;
- case KIND_DIGUE:
- aResult = new HYDROData_Digue();
- break;
- case KIND_PROFILE:
- aResult = new HYDROData_Profile();
- break;
- case KIND_PROFILEUZ:
- aResult = new HYDROData_ProfileUZ();
- break;
- case KIND_CALCULATION:
- aResult = new HYDROData_CalculationCase();
- break;
- case KIND_REGION:
- aResult = new HYDROData_Region();
- break;
- case KIND_ZONE:
- aResult = new HYDROData_Zone();
- break;
- case KIND_VISUAL_STATE:
- aResult = new HYDROData_VisualState();
- break;
- default:
- break;
+ DEBTRACE("HYDROData_Iterator::Object " << aKind);
+ case KIND_IMAGE: aResult = new HYDROData_Image(); break;
+ case KIND_POLYLINE: aResult = new HYDROData_Polyline3D(); break;
+ case KIND_BATHYMETRY: aResult = new HYDROData_Bathymetry(); break;
+ case KIND_ALTITUDE: aResult = new HYDROData_AltitudeObject(); break;
+ case KIND_IMMERSIBLE_ZONE: aResult = new HYDROData_ImmersibleZone(); break;
+ case KIND_RIVER: aResult = new HYDROData_River(); break;
+ case KIND_STREAM: aResult = new HYDROData_Stream(); break;
+ case KIND_CONFLUENCE: aResult = new HYDROData_Confluence(); break;
+ case KIND_CHANNEL: aResult = new HYDROData_Channel(); break;
+ case KIND_OBSTACLE: aResult = new HYDROData_Obstacle(); break;
+ case KIND_DIGUE: aResult = new HYDROData_Digue(); break;
+ case KIND_PROFILE: aResult = new HYDROData_Profile(); break;
+ case KIND_PROFILEUZ: aResult = new HYDROData_ProfileUZ(); break;
+ case KIND_POLYLINEXY: aResult = new HYDROData_PolylineXY(); break;
+ case KIND_CALCULATION: aResult = new HYDROData_CalculationCase(); break;
+ case KIND_REGION: aResult = new HYDROData_Region(); break;
+ case KIND_ZONE: aResult = new HYDROData_Zone(); break;
+ case KIND_VISUAL_STATE: aResult = new HYDROData_VisualState(); break;
+ case KIND_DUMMY_3D: aResult = new HYDROData_DummyObject3D(); break;
+ case KIND_SHAPES_GROUP: aResult = new HYDROData_ShapesGroup(); break;
+ case KIND_SPLITTED_GROUP: aResult = new HYDROData_SplittedShapesGroup(); break;
+ case KIND_STREAM_ALTITUDE: aResult = new HYDROData_StreamAltitude(); break;
+ case KIND_OBSTACLE_ALTITUDE: aResult = new HYDROData_ObstacleAltitude(); break;
+ case KIND_STRICKLER_TABLE: aResult = new HYDROData_StricklerTable(); break;
+ case KIND_LAND_COVER: aResult = new HYDROData_LandCover(); break;
+ case KIND_CHANNEL_ALTITUDE: aResult = new HYDROData_ChannelAltitude(); break;
+ default: break;
}
if ( !aResult.IsNull() )