1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198
|
// File generated by CPPExt (Transient)
//
//
// Copyright (C) 1991 - 2000 by
// Matra Datavision SA. All rights reserved.
//
// Copyright (C) 2001 - 2004 by
// Open CASCADE SA. All rights reserved.
//
// This file is part of the Open CASCADE Technology software.
//
// This software may be distributed and/or modified under the terms and
// conditions of the Open CASCADE Public License as defined by Open CASCADE SA
// and appearing in the file LICENSE included in the packaging of this file.
//
// This software is distributed on an "AS IS" basis, without warranty of any
// kind, and Open CASCADE SA hereby disclaims all such warranties,
// including without limitation, any warranties of merchantability, fitness
// for a particular purpose or non-infringement. Please see the License for
// the specific terms and conditions governing rights and limitations under the
// License.
#ifndef _Transfer_TransientProcess_HeaderFile
#define _Transfer_TransientProcess_HeaderFile
#ifndef _Standard_HeaderFile
#include <Standard.hxx>
#endif
#ifndef _Handle_Transfer_TransientProcess_HeaderFile
#include <Handle_Transfer_TransientProcess.hxx>
#endif
#ifndef _Handle_Interface_InterfaceModel_HeaderFile
#include <Handle_Interface_InterfaceModel.hxx>
#endif
#ifndef _Handle_Interface_HGraph_HeaderFile
#include <Handle_Interface_HGraph.hxx>
#endif
#ifndef _Handle_Dico_DictionaryOfTransient_HeaderFile
#include <Handle_Dico_DictionaryOfTransient.hxx>
#endif
#ifndef _Handle_TColStd_HSequenceOfTransient_HeaderFile
#include <Handle_TColStd_HSequenceOfTransient.hxx>
#endif
#ifndef _Transfer_ProcessForTransient_HeaderFile
#include <Transfer_ProcessForTransient.hxx>
#endif
#ifndef _Standard_Integer_HeaderFile
#include <Standard_Integer.hxx>
#endif
#ifndef _Standard_Boolean_HeaderFile
#include <Standard_Boolean.hxx>
#endif
#ifndef _Standard_CString_HeaderFile
#include <Standard_CString.hxx>
#endif
#ifndef _Handle_Standard_Transient_HeaderFile
#include <Handle_Standard_Transient.hxx>
#endif
#ifndef _Handle_Standard_Type_HeaderFile
#include <Handle_Standard_Type.hxx>
#endif
#ifndef _Standard_OStream_HeaderFile
#include <Standard_OStream.hxx>
#endif
class Interface_InterfaceModel;
class Interface_HGraph;
class Dico_DictionaryOfTransient;
class TColStd_HSequenceOfTransient;
class Interface_Graph;
class Standard_Transient;
class Standard_Type;
class Interface_EntityIterator;
//! Adds specific features to the generic definition : <br>
//! TransientProcess is intended to work from an InterfaceModel <br>
//! to a set of application objects. <br>
//! <br>
//! Hence, some informations about starting entities can be gotten <br>
//! from the model : for Trace, CheckList, Integrity Status <br>
class Transfer_TransientProcess : public Transfer_ProcessForTransient {
public:
// Methods PUBLIC
//
//! Sets TransientProcess at initial state, with an initial size <br>
Standard_EXPORT Transfer_TransientProcess(const Standard_Integer nb = 10000);
//! Sets an InterfaceModel, used by StartTrace, CheckList, queries <br>
//! on Integrity, to give informations significant for each norm. <br>
Standard_EXPORT void SetModel(const Handle(Interface_InterfaceModel)& model) ;
//! Returns the Model used for StartTrace <br>
Standard_EXPORT Handle_Interface_InterfaceModel Model() const;
//! Sets a Graph : superseedes SetModel if already done <br>
Standard_EXPORT void SetGraph(const Handle(Interface_HGraph)& HG) ;
Standard_EXPORT Standard_Boolean HasGraph() const;
Standard_EXPORT Handle_Interface_HGraph HGraph() const;
Standard_EXPORT const Interface_Graph& Graph() const;
//! Sets a Context : according to receiving appli, to be <br>
//! interpreted by the Actor <br>
Standard_EXPORT void SetContext(const Standard_CString name,const Handle(Standard_Transient)& ctx) ;
//! Returns the Context attached to a name, if set and if it is <br>
//! Kind of the type, else a Null Handle <br>
//! Returns True if OK, False if no Context <br>
Standard_EXPORT Standard_Boolean GetContext(const Standard_CString name,const Handle(Standard_Type)& type,Handle(Standard_Transient)& ctx) const;
//! Returns (modifiable) the whole definition of Context <br>
//! Rather for internal use (ex.: preparing and setting in once) <br>
Standard_EXPORT Handle_Dico_DictionaryOfTransient& Context() ;
//! Specific printing to trace an entity : prints label and type <br>
//! (if model is set) <br>
Standard_EXPORT virtual void PrintTrace(const Handle(Standard_Transient)& start,Standard_OStream& S) const;
//! Specific number of a starting object for check-list : Number <br>
//! in model <br>
Standard_EXPORT virtual Standard_Integer CheckNum(const Handle(Standard_Transient)& ent) const;
//! Returns the list of sharings entities, AT ANY LEVEL, which are <br>
//! kind of a given type. Calls TypedSharings from Graph <br>
//! Returns an empty list if the Graph has not been aknowledged <br>
Standard_EXPORT Interface_EntityIterator TypedSharings(const Handle(Standard_Transient)& start,const Handle(Standard_Type)& type) const;
//! Tells if an entity is well loaded from file (even if its data <br>
//! fail on checking, they are present). Mostly often, answers <br>
//! True. Else, there was a syntactic error in the file. <br>
//! A non-loaded entity MAY NOT BE transferred, unless its Report <br>
//! (in the model) is interpreted <br>
Standard_EXPORT Standard_Boolean IsDataLoaded(const Handle(Standard_Transient)& ent) const;
//! Tells if an entity fails on data checking (load time, <br>
//! syntactic, or semantic check). Normally, should answer False. <br>
//! It is not prudent to try transferring an entity which fails on <br>
//! data checking <br>
Standard_EXPORT Standard_Boolean IsDataFail(const Handle(Standard_Transient)& ent) const;
//! Prints statistics on a given output, according mode <br>
Standard_EXPORT void PrintStats(const Standard_Integer mode,Standard_OStream& S) const;
Standard_EXPORT Handle_TColStd_HSequenceOfTransient RootsForTransfer() ;
//Standard_EXPORT ~Transfer_TransientProcess();
// Type management
//
Standard_EXPORT const Handle(Standard_Type)& DynamicType() const;
//Standard_EXPORT Standard_Boolean IsKind(const Handle(Standard_Type)&) const;
protected:
// Methods PROTECTED
//
// Fields PROTECTED
//
private:
// Methods PRIVATE
//
// Fields PRIVATE
//
Handle_Interface_InterfaceModel themodel;
Handle_Interface_HGraph thegraph;
Handle_Dico_DictionaryOfTransient thectx;
Handle_TColStd_HSequenceOfTransient thetrroots;
};
// other Inline functions and methods (like "C++: function call" methods)
//
#endif
|