Back to index

salome-kernel  6.5.0
SALOMEDSImpl_ChildNodeIterator.hxx
Go to the documentation of this file.
00001 // Copyright (C) 2007-2012  CEA/DEN, EDF R&D, OPEN CASCADE
00002 //
00003 // Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
00004 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
00005 //
00006 // This library is free software; you can redistribute it and/or
00007 // modify it under the terms of the GNU Lesser General Public
00008 // License as published by the Free Software Foundation; either
00009 // version 2.1 of the License.
00010 //
00011 // This library is distributed in the hope that it will be useful,
00012 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00013 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00014 // Lesser General Public License for more details.
00015 //
00016 // You should have received a copy of the GNU Lesser General Public
00017 // License along with this library; if not, write to the Free Software
00018 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
00019 //
00020 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
00021 //
00022 
00023 #ifndef _SALOMEDSImpl_ChildNodeIterator_HeaderFile
00024 #define _SALOMEDSImpl_ChildNodeIterator_HeaderFile
00025 
00026 #include "SALOMEDSImpl_Defines.hxx"
00027 #include "SALOMEDSImpl_AttributeTreeNode.hxx"
00028 
00029 class SALOMEDSIMPL_EXPORT SALOMEDSImpl_ChildNodeIterator  
00030 {
00031 
00032 public:
00033 
00034   SALOMEDSImpl_ChildNodeIterator();
00035   SALOMEDSImpl_ChildNodeIterator(const SALOMEDSImpl_AttributeTreeNode* aTreeNode,
00036     const bool allLevels = false);
00037   void Initialize(const SALOMEDSImpl_AttributeTreeNode* aTreeNode,
00038     const bool allLevels = false) ;
00039   bool More() const { return (myNode); }
00040   void Next() ;
00041   void NextBrother() ;
00042   SALOMEDSImpl_AttributeTreeNode* Value() const { return myNode; }
00043 
00044 private: 
00045 
00046   SALOMEDSImpl_AttributeTreeNode* myNode;
00047   int myFirstLevel;
00048 
00049 };
00050 
00051 
00052 #endif