// Created on: 1994-12-16 // Created by: Frederic MAUPAS // Copyright (c) 1994-1999 Matra Datavision // Copyright (c) 1999-2014 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #ifndef _StepToTopoDS_Builder_HeaderFile #define _StepToTopoDS_Builder_HeaderFile #include #include #include #include #include #include #include class StepShape_ManifoldSolidBrep; class Transfer_TransientProcess; class StepShape_BrepWithVoids; class StepShape_FacetedBrep; class StepShape_FacetedBrepAndBrepWithVoids; class StepShape_ShellBasedSurfaceModel; class StepToTopoDS_NMTool; class StepShape_GeometricSet; class StepShape_EdgeBasedWireframeModel; class StepShape_FaceBasedSurfaceModel; class StepVisual_TessellatedFace; class StepVisual_TessellatedShell; class StepVisual_TessellatedSolid; class StepVisual_TessellatedSurfaceSet; class Transfer_ActorOfTransientProcess; class StepToTopoDS_Builder : public StepToTopoDS_Root { public: DEFINE_STANDARD_ALLOC Standard_EXPORT StepToTopoDS_Builder(); Standard_EXPORT void Init (const Handle(StepShape_ManifoldSolidBrep)& theManifoldSolid, const Handle(Transfer_TransientProcess)& theTP, const StepData_Factors& theLocalFactors, const Message_ProgressRange& theProgress = Message_ProgressRange()); Standard_EXPORT void Init (const Handle(StepShape_BrepWithVoids)& theBRepWithVoids, const Handle(Transfer_TransientProcess)& theTP, const StepData_Factors& theLocalFactors, const Message_ProgressRange& theProgress = Message_ProgressRange()); Standard_EXPORT void Init (const Handle(StepShape_FacetedBrep)& theFB, const Handle(Transfer_TransientProcess)& theTP, const StepData_Factors& theLocalFactors, const Message_ProgressRange& theProgress = Message_ProgressRange()); Standard_EXPORT void Init (const Handle(StepShape_FacetedBrepAndBrepWithVoids)& theFBABWV, const Handle(Transfer_TransientProcess)& theTP, const StepData_Factors& theLocalFactors, const Message_ProgressRange& theProgress = Message_ProgressRange()); Standard_EXPORT void Init (const Handle(StepShape_ShellBasedSurfaceModel)& S, const Handle(Transfer_TransientProcess)& TP, StepToTopoDS_NMTool& NMTool, const StepData_Factors& theLocalFactors, const Message_ProgressRange& theProgress = Message_ProgressRange()); Standard_EXPORT void Init (const Handle(StepShape_EdgeBasedWireframeModel)& S, const Handle(Transfer_TransientProcess)& TP, const StepData_Factors& theLocalFactors); Standard_EXPORT void Init (const Handle(StepShape_FaceBasedSurfaceModel)& S, const Handle(Transfer_TransientProcess)& TP, const StepData_Factors& theLocalFactors); Standard_EXPORT void Init (const Handle(StepShape_GeometricSet)& S, const Handle(Transfer_TransientProcess)& TP, const StepData_Factors& theLocalFactors, const Handle(Transfer_ActorOfTransientProcess)& RA = NULL, const Standard_Boolean isManifold = Standard_False, const Message_ProgressRange& theProgress = Message_ProgressRange()); Standard_EXPORT void Init (const Handle(StepVisual_TessellatedSolid)& theTSo, const Handle(Transfer_TransientProcess)& theTP, const Standard_Boolean theReadTessellatedWhenNoBRepOnly, Standard_Boolean& theHasGeom, const StepData_Factors& theLocalFactors, const Message_ProgressRange& theProgress = Message_ProgressRange()); Standard_EXPORT void Init (const Handle(StepVisual_TessellatedShell)& theTSh, const Handle(Transfer_TransientProcess)& theTP, const Standard_Boolean theReadTessellatedWhenNoBRepOnly, Standard_Boolean& theHasGeom, const StepData_Factors& theLocalFactors, const Message_ProgressRange& theProgress = Message_ProgressRange()); Standard_EXPORT void Init (const Handle(StepVisual_TessellatedFace)& theTF, const Handle(Transfer_TransientProcess)& theTP, const Standard_Boolean theReadTessellatedWhenNoBRepOnly, Standard_Boolean& theHasGeom, const StepData_Factors& theLocalFactors); Standard_EXPORT void Init (const Handle(StepVisual_TessellatedSurfaceSet)& theTSS, const Handle(Transfer_TransientProcess)& theTP, const StepData_Factors& theLocalFactors, Standard_Boolean& theHasGeom); Standard_EXPORT const TopoDS_Shape& Value() const; Standard_EXPORT StepToTopoDS_BuilderError Error() const; protected: private: StepToTopoDS_BuilderError myError; TopoDS_Shape myResult; }; #endif // _StepToTopoDS_Builder_HeaderFile