mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-06-25 12:04:07 +03:00
Implementation of new format for quick reading and writing parts of the documents (sub-set of labels and sub-set of attributes). It consists in writing shapes and all their contents right in the TNaming_NamedShape attribute placement and skipping the shape section. New format 12 for Binary file types is assigned to this version. Added PCDM_ReaderFilter class that could be used in Open methods of TDocStd_Application. If it is defined, it allows to read: - into already opened document in append mode AppendMode_Protect (do not overwrite existing attributes) or AppendMode_Overwrite - only specified sub-trees of the document using AddPath (const TCollection_AsciiString& theEntryToRead) - only specified attributes using AddRead (const TCollection_AsciiString& theRead) where theRead could be "TDataStd_Name", for example - to skip specified attributes read using AddSkipped (const TCollection_AsciiString& theSkipped) where theSkipped could be "TDF_Reference", for example The current limitations: - only in Bin format - if shapes have in the document shared topology, loaded in "append" mode in different "load" operations, they will have no shared topology anymore Modifications: BinLDrivers and BinDrivers packages - modifications related to the quick part tree format flag usage, skipping shape section writing and adding labels sizes into the document to be able to pass labels during the reading quickly. BinObjMgt_Persistent and BinObjMgt_Position - to add possibility to write directly into the stream some data just after the attribute. Before this record a data-size is recorded. BinMXCAFDoc package modifications to write BinMXCAFDoc_LocationDriver location in the same way as shapes write location data right after the attribute (empty) data in this new format. BinTools package: creation of ShapeReader and ShapeWriter classes with same root class ShapeSetBase with ShapeSet class. These classes allows to write/read shapes directly to the stream. If some object is already in the stream, write a reference - relative position of the duplicated object. The old format of documents is still supported by Bin_ToolsShapeSet class. PCDM_ReaderFilter - Allows the user to create a reading filter. It contains algorithm to browse labels tree quickly, without usage of referencing by entry-strings. TDocStd, CDF and some other packages are changed for supporting reading filters API and options. Tests, documentation and upgrade information are also added for both issues: 31839 and 31918 related to this commit.
85 lines
2.7 KiB
C++
85 lines
2.7 KiB
C++
// Created on: 2004-05-20
|
|
// Created by: Sergey ZARITCHNY <szy@opencascade.com>
|
|
// Copyright (c) 2004-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 _BinTools_CurveSet_HeaderFile
|
|
#define _BinTools_CurveSet_HeaderFile
|
|
|
|
#include <Standard.hxx>
|
|
#include <Standard_DefineAlloc.hxx>
|
|
#include <Standard_Handle.hxx>
|
|
|
|
#include <TColStd_IndexedMapOfTransient.hxx>
|
|
#include <Standard_Integer.hxx>
|
|
#include <Standard_OStream.hxx>
|
|
#include <Standard_IStream.hxx>
|
|
|
|
#include <Message_ProgressRange.hxx>
|
|
#include <BinTools_OStream.hxx>
|
|
|
|
class Standard_OutOfRange;
|
|
class Geom_Curve;
|
|
|
|
|
|
//! Stores a set of Curves from Geom in binary format.
|
|
class BinTools_CurveSet
|
|
{
|
|
public:
|
|
|
|
DEFINE_STANDARD_ALLOC
|
|
|
|
|
|
//! Returns an empty set of Curves.
|
|
Standard_EXPORT BinTools_CurveSet();
|
|
|
|
//! Clears the content of the set.
|
|
Standard_EXPORT void Clear();
|
|
|
|
//! Incorporate a new Curve in the set and returns
|
|
//! its index.
|
|
Standard_EXPORT Standard_Integer Add (const Handle(Geom_Curve)& C);
|
|
|
|
//! Returns the Curve of index <I>.
|
|
Standard_EXPORT Handle(Geom_Curve) Curve (const Standard_Integer I) const;
|
|
|
|
//! Returns the index of <L>.
|
|
Standard_EXPORT Standard_Integer Index (const Handle(Geom_Curve)& C) const;
|
|
|
|
//! Writes the content of me on the stream <OS> in a
|
|
//! format that can be read back by Read.
|
|
Standard_EXPORT void Write (Standard_OStream& OS,
|
|
const Message_ProgressRange& theRange = Message_ProgressRange()) const;
|
|
|
|
//! Reads the content of me from the stream <IS>. me
|
|
//! is first cleared.
|
|
Standard_EXPORT void Read (Standard_IStream& IS,
|
|
const Message_ProgressRange& theRange = Message_ProgressRange());
|
|
|
|
//! Dumps the curve on the stream in binary format
|
|
//! that can be read back.
|
|
Standard_EXPORT static void WriteCurve (const Handle(Geom_Curve)& C, BinTools_OStream& OS);
|
|
|
|
//! Reads the curve from the stream. The curve is
|
|
//! assumed to have been written with the Write
|
|
//! method
|
|
Standard_EXPORT static Standard_IStream& ReadCurve (Standard_IStream& IS, Handle(Geom_Curve)& C);
|
|
|
|
private:
|
|
|
|
TColStd_IndexedMapOfTransient myMap;
|
|
|
|
};
|
|
|
|
#endif // _BinTools_CurveSet_HeaderFile
|