// Created on: 2002-10-29 // Created by: Michael SAZONOV // Copyright (c) 2002-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. #include #include #include #include #include #include #include #include #include #include IMPLEMENT_STANDARD_RTTIEXT(BinDrivers_DocumentStorageDriver, BinLDrivers_DocumentStorageDriver) //================================================================================================= BinDrivers_DocumentStorageDriver::BinDrivers_DocumentStorageDriver() {} //================================================================================================= Handle(BinMDF_ADriverTable) BinDrivers_DocumentStorageDriver::AttributeDrivers( const Handle(Message_Messenger)& theMessageDriver) { return BinDrivers::AttributeDrivers(theMessageDriver); } //================================================================================================= Standard_Boolean BinDrivers_DocumentStorageDriver::IsWithTriangles() const { if (myDrivers.IsNull()) { return Standard_False; } Handle(BinMDF_ADriver) aDriver; myDrivers->GetDriver(STANDARD_TYPE(TNaming_NamedShape), aDriver); Handle(BinMNaming_NamedShapeDriver) aShapesDriver = Handle(BinMNaming_NamedShapeDriver)::DownCast(aDriver); return !aShapesDriver.IsNull() && aShapesDriver->IsWithTriangles(); } //================================================================================================= void BinDrivers_DocumentStorageDriver::SetWithTriangles( const Handle(Message_Messenger)& theMessageDriver, const Standard_Boolean theWithTriangulation) { if (myDrivers.IsNull()) { myDrivers = AttributeDrivers(theMessageDriver); } if (myDrivers.IsNull()) { return; } Handle(BinMDF_ADriver) aDriver; myDrivers->GetDriver(STANDARD_TYPE(TNaming_NamedShape), aDriver); Handle(BinMNaming_NamedShapeDriver) aShapesDriver = Handle(BinMNaming_NamedShapeDriver)::DownCast(aDriver); if (aShapesDriver.IsNull()) { throw Standard_NotImplemented("Internal Error - TNaming_NamedShape is not found!"); } aShapesDriver->SetWithTriangles(theWithTriangulation); } void BinDrivers_DocumentStorageDriver::EnableQuickPartWriting( const Handle(Message_Messenger)& theMessageDriver, const Standard_Boolean theValue) { if (myDrivers.IsNull()) { myDrivers = AttributeDrivers(theMessageDriver); } if (myDrivers.IsNull()) { return; } Handle(BinMDF_ADriver) aDriver; myDrivers->GetDriver(STANDARD_TYPE(TNaming_NamedShape), aDriver); Handle(BinMNaming_NamedShapeDriver) aShapesDriver = Handle(BinMNaming_NamedShapeDriver)::DownCast(aDriver); if (aShapesDriver.IsNull()) { throw Standard_NotImplemented("Internal Error - TNaming_NamedShape is not found!"); } aShapesDriver->EnableQuickPart(theValue); } //================================================================================================= void BinDrivers_DocumentStorageDriver::Clear() { // Clear NamedShape driver Handle(BinMDF_ADriver) aDriver; if (myDrivers->GetDriver(STANDARD_TYPE(TNaming_NamedShape), aDriver)) { Handle(BinMNaming_NamedShapeDriver) aNamedShapeDriver = Handle(BinMNaming_NamedShapeDriver)::DownCast(aDriver); aNamedShapeDriver->Clear(); } BinLDrivers_DocumentStorageDriver::Clear(); } //================================================================================================= Standard_Boolean BinDrivers_DocumentStorageDriver::IsWithNormals() const { if (myDrivers.IsNull()) { return Standard_False; } Handle(BinMDF_ADriver) aDriver; myDrivers->GetDriver(STANDARD_TYPE(TNaming_NamedShape), aDriver); Handle(BinMNaming_NamedShapeDriver) aShapesDriver = Handle(BinMNaming_NamedShapeDriver)::DownCast(aDriver); return !aShapesDriver.IsNull() && aShapesDriver->IsWithNormals(); } //================================================================================================= void BinDrivers_DocumentStorageDriver::SetWithNormals( const Handle(Message_Messenger)& theMessageDriver, const Standard_Boolean theWithNormals) { if (myDrivers.IsNull()) { myDrivers = AttributeDrivers(theMessageDriver); } if (myDrivers.IsNull()) { return; } Handle(BinMDF_ADriver) aDriver; myDrivers->GetDriver(STANDARD_TYPE(TNaming_NamedShape), aDriver); Handle(BinMNaming_NamedShapeDriver) aShapesDriver = Handle(BinMNaming_NamedShapeDriver)::DownCast(aDriver); if (aShapesDriver.IsNull()) { throw Standard_NotImplemented("Internal Error - TNaming_NamedShape is not found!"); } aShapesDriver->SetWithNormals(theWithNormals); } //======================================================================= // function : WriteShapeSection // purpose : Implements WriteShapeSection //======================================================================= void BinDrivers_DocumentStorageDriver::WriteShapeSection(BinLDrivers_DocumentSection& theSection, Standard_OStream& theOS, const TDocStd_FormatVersion theDocVer, const Message_ProgressRange& theRange) { const Standard_Size aShapesSectionOffset = (Standard_Size)theOS.tellp(); Handle(BinMDF_ADriver) aDriver; if (myDrivers->GetDriver(STANDARD_TYPE(TNaming_NamedShape), aDriver)) { try { OCC_CATCH_SIGNALS Handle(BinMNaming_NamedShapeDriver) aNamedShapeDriver = Handle(BinMNaming_NamedShapeDriver)::DownCast(aDriver); aNamedShapeDriver->WriteShapeSection(theOS, theDocVer, theRange); } catch (Standard_Failure const& anException) { TCollection_ExtendedString anErrorStr("BinDrivers_DocumentStorageDriver, Shape Section :"); myMsgDriver->Send(anErrorStr + anException.GetMessageString(), Message_Fail); } } // Write the section info in the TOC. theSection.Write(theOS, aShapesSectionOffset, theDocVer); }