// Created on: 1993-10-14 // Created by: Christian CAILLET // Copyright (c) 1993-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 _IGESGeom_ToolBoundary_HeaderFile #define _IGESGeom_ToolBoundary_HeaderFile #include #include #include #include #include class Standard_DomainError; class IGESGeom_Boundary; class IGESData_IGESReaderData; class IGESData_ParamReader; class IGESData_IGESWriter; class Interface_EntityIterator; class IGESData_DirChecker; class Interface_ShareTool; class Interface_Check; class Interface_CopyTool; class IGESData_IGESDumper; //! Tool to work on a Boundary. Called by various Modules //! (ReadWriteModule, GeneralModule, SpecificModule) class IGESGeom_ToolBoundary { public: DEFINE_STANDARD_ALLOC //! Returns a ToolBoundary, ready to work Standard_EXPORT IGESGeom_ToolBoundary(); //! Reads own parameters from file. gives access to them, //! detains parameter types and values Standard_EXPORT void ReadOwnParams (const Handle(IGESGeom_Boundary)& ent, const Handle(IGESData_IGESReaderData)& IR, IGESData_ParamReader& PR) const; //! Writes own parameters to IGESWriter Standard_EXPORT void WriteOwnParams (const Handle(IGESGeom_Boundary)& ent, IGESData_IGESWriter& IW) const; //! Lists the Entities shared by a Boundary , from //! its specific (own) parameters Standard_EXPORT void OwnShared (const Handle(IGESGeom_Boundary)& ent, Interface_EntityIterator& iter) const; //! Sets automatic unambiguous Correction on a Boundary //! (if BoundaryType = 0, Nullify all ParameterCurves) Standard_EXPORT Standard_Boolean OwnCorrect (const Handle(IGESGeom_Boundary)& ent) const; //! Returns specific DirChecker Standard_EXPORT IGESData_DirChecker DirChecker (const Handle(IGESGeom_Boundary)& ent) const; //! Performs Specific Semantic Check Standard_EXPORT void OwnCheck (const Handle(IGESGeom_Boundary)& ent, const Interface_ShareTool& shares, Handle(Interface_Check)& ach) const; //! Copies Specific Parameters Standard_EXPORT void OwnCopy (const Handle(IGESGeom_Boundary)& entfrom, const Handle(IGESGeom_Boundary)& entto, Interface_CopyTool& TC) const; //! Dump of Specific Parameters Standard_EXPORT void OwnDump (const Handle(IGESGeom_Boundary)& ent, const IGESData_IGESDumper& dumper, Standard_OStream& S, const Standard_Integer own) const; protected: private: }; #endif // _IGESGeom_ToolBoundary_HeaderFile