Salome HOME
updated copyright message
[modules/geom.git] / src / GEOMAlgo / GEOMAlgo_FinderShapeOn1.hxx
index 267f191e17d8a5187b7eb2cc0fead84c443eb63b..f6b9547ac8a725a2d1395c98f04c640b86f402fb 100644 (file)
-// Copyright (C) 2005  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
+// Copyright (C) 2007-2023  CEA, EDF, 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 
+// 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 
+// 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_FinderShapeOn1.hxx
+// Created:     Fri Mar  4 10:31:06 2005
+// Author:      Peter KURNEV
 
 #ifndef _GEOMAlgo_FinderShapeOn1_HeaderFile
 #define _GEOMAlgo_FinderShapeOn1_HeaderFile
 
-#ifndef _Handle_Geom_Surface_HeaderFile
-#include <Handle_Geom_Surface.hxx>
-#endif
-#ifndef _TopAbs_ShapeEnum_HeaderFile
-#include <TopAbs_ShapeEnum.hxx>
-#endif
-#ifndef _GEOMAlgo_State_HeaderFile
 #include <GEOMAlgo_State.hxx>
-#endif
-#ifndef _Standard_Integer_HeaderFile
-#include <Standard_Integer.hxx>
-#endif
-#ifndef _GeomAdaptor_Surface_HeaderFile
-#include <GeomAdaptor_Surface.hxx>
-#endif
-#ifndef _TopTools_ListOfShape_HeaderFile
-#include <TopTools_ListOfShape.hxx>
-#endif
-#ifndef _GEOMAlgo_IndexedDataMapOfShapeState_HeaderFile
 #include <GEOMAlgo_IndexedDataMapOfShapeState.hxx>
-#endif
-#ifndef _GEOMAlgo_ShapeAlgo_HeaderFile
 #include <GEOMAlgo_ShapeAlgo.hxx>
-#endif
-class Geom_Surface;
-class TopTools_ListOfShape;
-class TopoDS_Face;
-class GEOMAlgo_ListOfPnt;
-class TopoDS_Edge;
-class GEOMAlgo_IndexedDataMapOfShapeState;
+#include <GEOMAlgo_ListOfPnt.hxx>
 
+#include <TopAbs_State.hxx>
+#include <TopAbs_ShapeEnum.hxx>
+#include <TopoDS_Face.hxx>
+#include <TopoDS_Edge.hxx>
+#include <TopTools_ListOfShape.hxx>
+
+#include <Geom_Surface.hxx>
+#include <GeomAdaptor_Surface.hxx>
+
+#include <gp_Pnt.hxx>
 
-#ifndef _Standard_HeaderFile
 #include <Standard.hxx>
-#endif
-#ifndef _Standard_Macro_HeaderFile
 #include <Standard_Macro.hxx>
-#endif
+#include <Standard_Integer.hxx>
 
-class GEOMAlgo_FinderShapeOn1  : public GEOMAlgo_ShapeAlgo {
-
-public:
-
-    void* operator new(size_t,void* anAddress) 
-      {
-        return anAddress;
-      }
-    void* operator new(size_t size) 
-      { 
-        return Standard::Allocate(size); 
-      }
-    void  operator delete(void *anAddress) 
-      { 
-        if (anAddress) Standard::Free((Standard_Address&)anAddress); 
-      }
- // Methods PUBLIC
- // 
-Standard_EXPORT GEOMAlgo_FinderShapeOn1();
-Standard_EXPORT virtual ~GEOMAlgo_FinderShapeOn1();
-Standard_EXPORT   void SetSurface(const Handle(Geom_Surface)& aS) ;
-Standard_EXPORT   void SetShapeType(const TopAbs_ShapeEnum aST) ;
-Standard_EXPORT   void SetState(const GEOMAlgo_State aSF) ;
-Standard_EXPORT   void SetNbPntsMin(const Standard_Integer aNb) ;
-Standard_EXPORT   Standard_Integer NbPntsMin() const;
-Standard_EXPORT   void SetNbPntsMax(const Standard_Integer aNb) ;
-Standard_EXPORT   Standard_Integer NbPntsMax() const;
-Standard_EXPORT  const Handle_Geom_Surface& Surface() const;
-Standard_EXPORT   TopAbs_ShapeEnum ShapeType() const;
-Standard_EXPORT   GEOMAlgo_State State() const;
-Standard_EXPORT virtual  void Perform() ;
-Standard_EXPORT  const TopTools_ListOfShape& Shapes() const;
-Standard_EXPORT  const GEOMAlgo_IndexedDataMapOfShapeState& MSS() const;
-
-
-
-
-
-protected:
-
- // Methods PROTECTED
- // 
-Standard_EXPORT virtual  void CheckData() ;
-Standard_EXPORT   void ProcessVertices() ;
-Standard_EXPORT   void ProcessEdges() ;
-Standard_EXPORT   void ProcessFaces() ;
-Standard_EXPORT   void ProcessSolids() ;
-Standard_EXPORT   void InnerPoints(const TopoDS_Face& aF,GEOMAlgo_ListOfPnt& aLP) ;
-Standard_EXPORT   void InnerPoints(const TopoDS_Edge& aE,GEOMAlgo_ListOfPnt& aLP) ;
-Standard_EXPORT   void InnerPoints(const TopoDS_Edge& aE,const Standard_Integer aNbPnts,GEOMAlgo_ListOfPnt& aLP) ;
-Standard_EXPORT virtual TopAbs_State GetPointState(const gp_Pnt& aP) ;
-
-
- // Fields PROTECTED
- //
-Handle_Geom_Surface mySurface;
-TopAbs_ShapeEnum myShapeType;
-GEOMAlgo_State myState;
-Standard_Integer myNbPntsMin;
-Standard_Integer myNbPntsMax;
-GeomAdaptor_Surface myGAS;
-TopTools_ListOfShape myLS;
-GEOMAlgo_IndexedDataMapOfShapeState myMSS;
-
-
-private: 
-
- // Methods PRIVATE
- // 
-
-
- // Fields PRIVATE
- //
+//=======================================================================
+//function : GEOMAlgo_FinderShapeOn1
+//purpose  :
+//=======================================================================
+class GEOMAlgo_FinderShapeOn1  : public GEOMAlgo_ShapeAlgo
+{
+ public:
+  Standard_EXPORT
+    GEOMAlgo_FinderShapeOn1();
 
+  Standard_EXPORT
+    virtual ~GEOMAlgo_FinderShapeOn1();
 
-};
+  Standard_EXPORT
+    void SetSurface(const Handle(Geom_Surface)& aS) ;
 
+  Standard_EXPORT
+    void SetShapeType(const TopAbs_ShapeEnum aST) ;
 
+  Standard_EXPORT
+    void SetState(const GEOMAlgo_State aSF) ;
 
+  Standard_EXPORT
+    void SetNbPntsMin(const Standard_Integer aNb) ;
 
+  Standard_EXPORT
+    Standard_Integer NbPntsMin() const;
 
-// other Inline functions and methods (like "C++: function call" methods)
-//
+  Standard_EXPORT
+    void SetNbPntsMax(const Standard_Integer aNb) ;
+
+  Standard_EXPORT
+    Standard_Integer NbPntsMax() const;
+
+  Standard_EXPORT
+    const Handle(Geom_Surface)& Surface() const;
+
+  Standard_EXPORT
+    TopAbs_ShapeEnum ShapeType() const;
+
+  Standard_EXPORT
+    GEOMAlgo_State State() const;
+
+  Standard_EXPORT
+    virtual  void Perform() ;
+
+  Standard_EXPORT
+    const TopTools_ListOfShape& Shapes() const;
+
+  Standard_EXPORT
+    const GEOMAlgo_IndexedDataMapOfShapeState& MSS() const;
 
+ protected:
+  Standard_EXPORT
+    virtual  void CheckData() ;
+
+  Standard_EXPORT
+    void ProcessVertices() ;
+
+  Standard_EXPORT
+    void ProcessEdges() ;
+
+  Standard_EXPORT
+    void ProcessFaces() ;
+
+  Standard_EXPORT
+    void ProcessSolids() ;
+
+  Standard_EXPORT
+    void InnerPoints(const TopoDS_Face& aF,
+                     GEOMAlgo_ListOfPnt& aLP) ;
+
+  Standard_EXPORT
+    void InnerPoints(const TopoDS_Edge& aE,
+                     GEOMAlgo_ListOfPnt& aLP) ;
+
+  Standard_EXPORT
+    void InnerPoints(const TopoDS_Edge& aE,
+                     const Standard_Integer aNbPnts,
+                     GEOMAlgo_ListOfPnt& aLP) ;
+
+  Standard_EXPORT
+    virtual  TopAbs_State GetPointState(const gp_Pnt& aP) ;
+
+
+  Handle(Geom_Surface) mySurface;
+  TopAbs_ShapeEnum myShapeType;
+  GEOMAlgo_State myState;
+  Standard_Integer myNbPntsMin;
+  Standard_Integer myNbPntsMax;
+  GeomAdaptor_Surface myGAS;
+  TopTools_ListOfShape myLS;
+  GEOMAlgo_IndexedDataMapOfShapeState myMSS;
+};
 
 #endif