/src/contrib/geom-5.1.2.7/inc/GEOMAlgo_WireSplitter.hxx

http://pythonocc.googlecode.com/ · C++ Header · 143 lines · 62 code · 45 blank · 36 comment · 1 complexity · c1c9c562745ffd1601873efccf9bab8d MD5 · raw file

  1. // Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE
  2. //
  3. // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
  4. // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
  5. //
  6. // This library is free software; you can redistribute it and/or
  7. // modify it under the terms of the GNU Lesser General Public
  8. // License as published by the Free Software Foundation; either
  9. // version 2.1 of the License.
  10. //
  11. // This library is distributed in the hope that it will be useful,
  12. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. // Lesser General Public License for more details.
  15. //
  16. // You should have received a copy of the GNU Lesser General Public
  17. // License along with this library; if not, write to the Free Software
  18. // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  19. //
  20. // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
  21. //
  22. #ifndef _GEOMAlgo_WireSplitter_HeaderFile
  23. #define _GEOMAlgo_WireSplitter_HeaderFile
  24. #ifndef _TopoDS_Face_HeaderFile
  25. #include <TopoDS_Face.hxx>
  26. #endif
  27. #ifndef _Standard_Boolean_HeaderFile
  28. #include <Standard_Boolean.hxx>
  29. #endif
  30. #ifndef _BOPTColStd_ListOfListOfShape_HeaderFile
  31. #include <BOPTColStd_ListOfListOfShape.hxx>
  32. #endif
  33. #ifndef _BOP_IndexedDataMapOfVertexListEdgeInfo_HeaderFile
  34. #include <BOP_IndexedDataMapOfVertexListEdgeInfo.hxx>
  35. #endif
  36. #ifndef _TopTools_ListOfShape_HeaderFile
  37. #include <TopTools_ListOfShape.hxx>
  38. #endif
  39. #ifndef _GEOMAlgo_Algo_HeaderFile
  40. #include <GEOMAlgo_Algo.hxx>
  41. #endif
  42. class TopoDS_Face;
  43. class TopTools_ListOfShape;
  44. class BOPTColStd_ListOfListOfShape;
  45. #ifndef _Standard_HeaderFile
  46. #include <Standard.hxx>
  47. #endif
  48. #ifndef _Standard_Macro_HeaderFile
  49. #include <Standard_Macro.hxx>
  50. #endif
  51. //! the algorithm to split multiconnexed set of edges <br>
  52. //! wires on a face onto simple connexed wires <br>
  53. //! . <br>
  54. class GEOMAlgo_WireSplitter : public GEOMAlgo_Algo {
  55. public:
  56. void* operator new(size_t,void* anAddress)
  57. {
  58. return anAddress;
  59. }
  60. void* operator new(size_t size)
  61. {
  62. return Standard::Allocate(size);
  63. }
  64. void operator delete(void *anAddress)
  65. {
  66. if (anAddress) Standard::Free((Standard_Address&)anAddress);
  67. }
  68. // Methods PUBLIC
  69. //
  70. Standard_EXPORT GEOMAlgo_WireSplitter();
  71. Standard_EXPORT virtual ~GEOMAlgo_WireSplitter();
  72. Standard_EXPORT void SetFace(const TopoDS_Face& aF) ;
  73. Standard_EXPORT void SetEdges(const TopTools_ListOfShape& aLE) ;
  74. Standard_EXPORT const TopTools_ListOfShape& Edges() const;
  75. Standard_EXPORT virtual void Perform() ;
  76. Standard_EXPORT Standard_Boolean IsNothingToDo() const;
  77. Standard_EXPORT const TopoDS_Face& Face() const;
  78. Standard_EXPORT const BOPTColStd_ListOfListOfShape& Shapes() const;
  79. protected:
  80. // Methods PROTECTED
  81. //
  82. // Fields PROTECTED
  83. //
  84. TopoDS_Face myFace;
  85. Standard_Boolean myIsDone;
  86. Standard_Boolean myNothingToDo;
  87. BOPTColStd_ListOfListOfShape myShapes;
  88. BOP_IndexedDataMapOfVertexListEdgeInfo mySmartMap;
  89. TopTools_ListOfShape myEdges;
  90. private:
  91. // Methods PRIVATE
  92. //
  93. // Fields PRIVATE
  94. //
  95. };
  96. // other Inline functions and methods (like "C++: function call" methods)
  97. //
  98. #endif