-\r
-// Copyright (C) 2007-2011 CEA/DEN, EDF R&D, OPEN CASCADE\r
-//\r
-// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,\r
-// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS\r
-//\r
-// This library is free software; you can redistribute it and/or\r
-// modify it under the terms of the GNU Lesser General Public\r
-// License as published by the Free Software Foundation; either\r
-// version 2.1 of the License.\r
-//\r
-// This library is distributed in the hope that it will be useful,\r
-// but WITHOUT ANY WARRANTY; without even the implied warranty of\r
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\r
-// Lesser General Public License for more details.\r
-//\r
-// You should have received a copy of the GNU Lesser General Public\r
-// License along with this library; if not, write to the Free Software\r
-// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\r
-//\r
-// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com\r
-//\r
-\r
-// File: GEOMAlgo_Gluer.hxx\r
-// Created: Sat Dec 04 12:45:53 2004\r
-// Author: Peter KURNEV\r
-// <peter@PREFEX>\r
-//\r
-#ifndef _GEOMAlgo_Gluer_HeaderFile\r
-#define _GEOMAlgo_Gluer_HeaderFile\r
-\r
-#include <Standard.hxx>\r
-#include <Standard_Macro.hxx>\r
-#include <Standard_Boolean.hxx>\r
-#include <Standard_Real.hxx>\r
-#include <TopTools_DataMapOfShapeListOfShape.hxx>\r
-#include <TopTools_DataMapOfShapeShape.hxx>\r
-#include <Standard_Integer.hxx>\r
-#include <TopTools_ListOfShape.hxx>\r
-#include <GEOMAlgo_ShapeAlgo.hxx>\r
-#include <TopAbs_ShapeEnum.hxx>\r
-#include <TopoDS_Shape.hxx>\r
-#include <TopoDS_Edge.hxx>\r
-#include <TopoDS_Face.hxx>\r
-#include <TopoDS_Vertex.hxx>\r
-#include <GEOMAlgo_PassKeyShape.hxx>\r
-#include <TopTools_MapOfShape.hxx>\r
-#include <TopoDS_Compound.hxx>\r
-\r
-//=======================================================================\r
-//class : GEOMAlgo_Gluer\r
-//purpose : \r
-//=======================================================================\r
-class GEOMAlgo_Gluer : public GEOMAlgo_ShapeAlgo {\r
-public:\r
- Standard_EXPORT\r
- GEOMAlgo_Gluer();\r
-\r
- Standard_EXPORT\r
- virtual ~GEOMAlgo_Gluer();\r
- \r
- Standard_EXPORT\r
- void SetCheckGeometry(const Standard_Boolean aFlag) ;\r
- \r
- Standard_EXPORT\r
- Standard_Boolean CheckGeometry() const;\r
- \r
- Standard_EXPORT\r
- void SetKeepNonSolids(const Standard_Boolean aFlag) ;\r
- \r
- Standard_EXPORT\r
- Standard_Boolean KeepNonSolids() const;\r
- \r
- Standard_EXPORT\r
- virtual void Perform() ;\r
- \r
- Standard_EXPORT\r
- Standard_Integer AloneShapes() const;\r
- \r
- Standard_EXPORT\r
- const TopTools_ListOfShape& Modified(const TopoDS_Shape& S) ;\r
- \r
- Standard_EXPORT\r
- const TopTools_ListOfShape& Generated(const TopoDS_Shape& S) ;\r
- \r
- Standard_EXPORT\r
- Standard_Boolean IsDeleted(const TopoDS_Shape& S) ;\r
- \r
- Standard_EXPORT\r
- const TopTools_DataMapOfShapeListOfShape& Images() const;\r
- \r
- Standard_EXPORT\r
- const TopTools_DataMapOfShapeShape& Origins() const;\r
-\r
- protected:\r
- Standard_EXPORT\r
- virtual void CheckData() ;\r
- \r
- Standard_EXPORT\r
- virtual void CheckResult() ;\r
- \r
- Standard_EXPORT\r
- void MakeVertices() ;\r
- \r
- Standard_EXPORT\r
- void MakeEdges() ;\r
- \r
- Standard_EXPORT\r
- void MakeFaces() ;\r
- \r
- Standard_EXPORT\r
- void MakeShapes(const TopAbs_ShapeEnum aType) ;\r
- \r
- Standard_EXPORT\r
- void MakeShells() ;\r
- \r
- Standard_EXPORT\r
- void MakeSolids() ;\r
- \r
- Standard_EXPORT\r
- void InnerTolerance() ;\r
- \r
- Standard_EXPORT\r
- void EdgePassKey(const TopoDS_Edge& aE,\r
- GEOMAlgo_PassKeyShape& aPK) ;\r
- \r
- Standard_EXPORT\r
- void FacePassKey(const TopoDS_Face& aF,\r
- GEOMAlgo_PassKeyShape& aPK) ;\r
- \r
- Standard_EXPORT\r
- void MakeVertex(const TopTools_ListOfShape& aLV,\r
- TopoDS_Vertex& aNewV) ;\r
- \r
- Standard_EXPORT\r
- void MakeEdge(const TopoDS_Edge& aEdge,\r
- TopoDS_Edge& aNewEdge) ;\r
- \r
- Standard_EXPORT\r
- void MakeFace(const TopoDS_Face& aFace,\r
- TopoDS_Face& aNewEdge) ;\r
- \r
- Standard_EXPORT\r
- Standard_Boolean IsToReverse(const TopoDS_Face& aFR,\r
- const TopoDS_Face& aF) ;\r
- \r
- Standard_EXPORT\r
- Standard_Boolean HasNewSubShape(const TopoDS_Shape& aS) const;\r
- \r
- Standard_EXPORT\r
- void MakeSubShapes(const TopoDS_Shape& aS,\r
- TopTools_MapOfShape& aM,\r
- TopoDS_Compound& aC) ;\r
-\r
-\r
- Standard_Boolean myCheckGeometry;\r
- Standard_Boolean myKeepNonSolids;\r
- Standard_Real myTol;\r
- TopTools_DataMapOfShapeListOfShape myImages;\r
- TopTools_DataMapOfShapeShape myOrigins;\r
- Standard_Integer myNbAlone;\r
- TopTools_ListOfShape myGenerated;\r
-};\r
-#endif\r
+
+// Copyright (C) 2007-2012 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
+//
+// 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.
+//
+// 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
+//
+
+// File: GEOMAlgo_Gluer.hxx
+// Created: Sat Dec 04 12:45:53 2004
+// Author: Peter KURNEV
+// <peter@PREFEX>
+//
+#ifndef _GEOMAlgo_Gluer_HeaderFile
+#define _GEOMAlgo_Gluer_HeaderFile
+
+#include <Standard.hxx>
+#include <Standard_Macro.hxx>
+#include <Standard_Boolean.hxx>
+#include <Standard_Real.hxx>
+#include <TopTools_DataMapOfShapeListOfShape.hxx>
+#include <TopTools_DataMapOfShapeShape.hxx>
+#include <Standard_Integer.hxx>
+#include <TopTools_ListOfShape.hxx>
+#include <GEOMAlgo_ShapeAlgo.hxx>
+#include <TopAbs_ShapeEnum.hxx>
+#include <TopoDS_Shape.hxx>
+#include <TopoDS_Edge.hxx>
+#include <TopoDS_Face.hxx>
+#include <TopoDS_Vertex.hxx>
+#include <GEOMAlgo_PassKeyShape.hxx>
+#include <TopTools_MapOfShape.hxx>
+#include <TopoDS_Compound.hxx>
+
+//=======================================================================
+//class : GEOMAlgo_Gluer
+//purpose :
+//=======================================================================
+class GEOMAlgo_Gluer : public GEOMAlgo_ShapeAlgo {
+public:
+ Standard_EXPORT
+ GEOMAlgo_Gluer();
+
+ Standard_EXPORT
+ virtual ~GEOMAlgo_Gluer();
+
+ Standard_EXPORT
+ void SetCheckGeometry(const Standard_Boolean aFlag) ;
+
+ Standard_EXPORT
+ Standard_Boolean CheckGeometry() const;
+
+ Standard_EXPORT
+ void SetKeepNonSolids(const Standard_Boolean aFlag) ;
+
+ Standard_EXPORT
+ Standard_Boolean KeepNonSolids() const;
+
+ Standard_EXPORT
+ virtual void Perform() ;
+
+ Standard_EXPORT
+ Standard_Integer AloneShapes() const;
+
+ Standard_EXPORT
+ const TopTools_ListOfShape& Modified(const TopoDS_Shape& S) ;
+
+ Standard_EXPORT
+ const TopTools_ListOfShape& Generated(const TopoDS_Shape& S) ;
+
+ Standard_EXPORT
+ Standard_Boolean IsDeleted(const TopoDS_Shape& S) ;
+
+ Standard_EXPORT
+ const TopTools_DataMapOfShapeListOfShape& Images() const;
+
+ Standard_EXPORT
+ const TopTools_DataMapOfShapeShape& Origins() const;
+
+ protected:
+ Standard_EXPORT
+ virtual void CheckData() ;
+
+ Standard_EXPORT
+ virtual void CheckResult() ;
+
+ Standard_EXPORT
+ void MakeVertices() ;
+
+ Standard_EXPORT
+ void MakeEdges() ;
+
+ Standard_EXPORT
+ void MakeFaces() ;
+
+ Standard_EXPORT
+ void MakeShapes(const TopAbs_ShapeEnum aType) ;
+
+ Standard_EXPORT
+ void MakeShells() ;
+
+ Standard_EXPORT
+ void MakeSolids() ;
+
+ Standard_EXPORT
+ void InnerTolerance() ;
+
+ Standard_EXPORT
+ void EdgePassKey(const TopoDS_Edge& aE,
+ GEOMAlgo_PassKeyShape& aPK) ;
+
+ Standard_EXPORT
+ void FacePassKey(const TopoDS_Face& aF,
+ GEOMAlgo_PassKeyShape& aPK) ;
+
+ Standard_EXPORT
+ void MakeVertex(const TopTools_ListOfShape& aLV,
+ TopoDS_Vertex& aNewV) ;
+
+ Standard_EXPORT
+ void MakeEdge(const TopoDS_Edge& aEdge,
+ TopoDS_Edge& aNewEdge) ;
+
+ Standard_EXPORT
+ void MakeFace(const TopoDS_Face& aFace,
+ TopoDS_Face& aNewEdge) ;
+
+ Standard_EXPORT
+ Standard_Boolean IsToReverse(const TopoDS_Face& aFR,
+ const TopoDS_Face& aF) ;
+
+ Standard_EXPORT
+ Standard_Boolean HasNewSubShape(const TopoDS_Shape& aS) const;
+
+ Standard_EXPORT
+ void MakeSubShapes(const TopoDS_Shape& aS,
+ TopTools_MapOfShape& aM,
+ TopoDS_Compound& aC) ;
+
+
+ Standard_Boolean myCheckGeometry;
+ Standard_Boolean myKeepNonSolids;
+ Standard_Real myTol;
+ TopTools_DataMapOfShapeListOfShape myImages;
+ TopTools_DataMapOfShapeShape myOrigins;
+ Standard_Integer myNbAlone;
+ TopTools_ListOfShape myGenerated;
+};
+#endif