Open CASCADE Technology 7.8.2.dev
|
This class defines services which permit to access Data issued from a File, in a form which does not depend of physical format : thus, each Record has an attached ParamList (to be managed) and resulting Entity. More...
#include <Interface_FileReaderData.hxx>
Public Member Functions | |
virtual Standard_Integer | NbRecords () const |
Returns the count of registered records That is, value given for Initialization (can be redefined) | |
virtual Standard_Integer | NbEntities () const |
Returns the count of entities. Depending of each norm, records can be Entities or SubParts (SubList in STEP, SubGroup in SET ...). NbEntities counts only Entities, not Subs Used for memory reservation in InterfaceModel Default implementation uses FindNextRecord Can be redefined into a more performant way. | |
virtual Standard_Integer | FindNextRecord (const Standard_Integer num) const =0 |
Determines the record number defining an Entity following a given record number. Specific to each sub-class of FileReaderData. Returning zero means no record found. | |
void | InitParams (const Standard_Integer num) |
attaches an empty ParamList to a Record | |
void | AddParam (const Standard_Integer num, const Standard_CString aval, const Interface_ParamType atype, const Standard_Integer nument=0) |
Adds a parameter to record no "num" and fills its fields (EntityNumber is optional) Warning : <aval> is assumed to be memory-managed elsewhere : it is NOT copied. This gives a best speed : strings remain stored in pages of characters. | |
void | AddParam (const Standard_Integer num, const TCollection_AsciiString &aval, const Interface_ParamType atype, const Standard_Integer nument=0) |
Same as above, but gets a AsciiString from TCollection Remark that the content of the AsciiString is locally copied (because its content is most often lost after using) | |
void | AddParam (const Standard_Integer num, const Interface_FileParameter &FP) |
Same as above, but gets a complete FileParameter Warning : Content of <FP> is NOT copied : its original address and space in memory are assumed to be managed elsewhere (see ParamSet) | |
void | SetParam (const Standard_Integer num, const Standard_Integer nump, const Interface_FileParameter &FP) |
Sets a new value for a parameter of a record, given by : num : record number; nump : parameter number in the record. | |
Standard_Integer | NbParams (const Standard_Integer num) const |
Returns count of parameters attached to record "num" If <num> = 0, returns the total recorded count of parameters. | |
Handle< Interface_ParamList > | Params (const Standard_Integer num) const |
Returns the complete ParamList of a record (read only) num = 0 to return the whole param list for the file. | |
const Interface_FileParameter & | Param (const Standard_Integer num, const Standard_Integer nump) const |
Returns parameter "nump" of record "num", as a complete FileParameter. | |
Interface_FileParameter & | ChangeParam (const Standard_Integer num, const Standard_Integer nump) |
Same as above, but in order to be modified on place. | |
Interface_ParamType | ParamType (const Standard_Integer num, const Standard_Integer nump) const |
Returns type of parameter "nump" of record "num" Returns literal value of parameter "nump" of record "num" was C++ : return const &. | |
Standard_CString | ParamCValue (const Standard_Integer num, const Standard_Integer nump) const |
Same as above, but as a CString was C++ : return const. | |
Standard_Boolean | IsParamDefined (const Standard_Integer num, const Standard_Integer nump) const |
Returns True if parameter "nump" of record "num" is defined (it is not if its type is ParamVoid) | |
Standard_Integer | ParamNumber (const Standard_Integer num, const Standard_Integer nump) const |
Returns record number of an entity referenced by a parameter of type Ident; 0 if no EntityNumber has been determined Note that it is used to reference Entities but also Sublists (sublists are not objects, but internal descriptions) | |
const Handle< Standard_Transient > & | ParamEntity (const Standard_Integer num, const Standard_Integer nump) const |
Returns the StepEntity referenced by a parameter Error if none. | |
Standard_Integer | ParamFirstRank (const Standard_Integer num) const |
Returns the absolute rank of the beginning of a record (its list is from ParamFirstRank+1 to ParamFirstRank+NbParams) | |
const Handle< Standard_Transient > & | BoundEntity (const Standard_Integer num) const |
Returns the entity bound to a record, set by SetEntities. | |
void | BindEntity (const Standard_Integer num, const Handle< Standard_Transient > &ent) |
Binds an entity to a record. | |
void | SetErrorLoad (const Standard_Boolean val) |
Sets the status "Error Load" on, to overside check fails <val> True : declares unloaded <val> False : declares loaded If not called before loading (see FileReaderTool), check fails give the status IsErrorLoad says if SetErrorLoad has been called by user ResetErrorLoad resets it (called by FileReaderTool) This allows to specify that the currently loaded entity remains unloaded (because of syntactic fail) | |
Standard_Boolean | IsErrorLoad () const |
Returns True if the status "Error Load" has been set (to True or False) | |
Standard_Boolean | ResetErrorLoad () |
Returns the former value of status "Error Load" then resets it Used to read the status then ensure it is reset. | |
void | Destroy () |
Destructor (waiting for memory management) | |
~Interface_FileReaderData () | |
Public Member Functions inherited from Standard_Transient | |
Standard_Transient () | |
Empty constructor. | |
Standard_Transient (const Standard_Transient &) | |
Copy constructor – does nothing. | |
Standard_Transient & | operator= (const Standard_Transient &) |
Assignment operator, needed to avoid copying reference counter. | |
virtual | ~Standard_Transient () |
Destructor must be virtual. | |
virtual const opencascade::handle< Standard_Type > & | DynamicType () const |
Returns a type descriptor about this object. | |
Standard_Boolean | IsInstance (const opencascade::handle< Standard_Type > &theType) const |
Returns a true value if this is an instance of Type. | |
Standard_Boolean | IsInstance (const Standard_CString theTypeName) const |
Returns a true value if this is an instance of TypeName. | |
Standard_Boolean | IsKind (const opencascade::handle< Standard_Type > &theType) const |
Returns true if this is an instance of Type or an instance of any class that inherits from Type. Note that multiple inheritance is not supported by OCCT RTTI mechanism. | |
Standard_Boolean | IsKind (const Standard_CString theTypeName) const |
Returns true if this is an instance of TypeName or an instance of any class that inherits from TypeName. Note that multiple inheritance is not supported by OCCT RTTI mechanism. | |
Standard_Transient * | This () const |
Returns non-const pointer to this object (like const_cast). For protection against creating handle to objects allocated in stack or call from constructor, it will raise exception Standard_ProgramError if reference counter is zero. | |
Standard_Integer | GetRefCount () const noexcept |
Get the reference counter of this object. | |
void | IncrementRefCounter () noexcept |
Increments the reference counter of this object. | |
Standard_Integer | DecrementRefCounter () noexcept |
Decrements the reference counter of this object; returns the decremented value. | |
virtual void | Delete () const |
Memory deallocator for transient classes. | |
Static Public Member Functions | |
static Standard_Real | Fastof (const Standard_CString str) |
Same spec.s as standard <atof> but 5 times faster. | |
Static Public Member Functions inherited from Standard_Transient | |
static constexpr const char * | get_type_name () |
Returns a type descriptor about this object. | |
static const opencascade::handle< Standard_Type > & | get_type_descriptor () |
Returns type descriptor of Standard_Transient class. | |
Protected Member Functions | |
Interface_FileReaderData (const Standard_Integer nbr, const Standard_Integer npar) | |
Initializes arrays of Entities and of ParamLists attached to registered records <nbr> must be the maximum number of records to get (no way to extend it at run-time) : count entities and sub-entities ... <npar> is the total count of parameters (if it is not exact, it will be extended as necessary) | |
Interface_FileParameter & | ChangeParameter (const Standard_Integer numpar) |
Returns a parameter given its absolute rank in the file in order to be consulted or modified in specilaized actions. | |
void | ParamPosition (const Standard_Integer numpar, Standard_Integer &num, Standard_Integer &nump) const |
For a given absolute rank of parameter, determines the record to which its belongs, and the parameter number for it. | |
Additional Inherited Members | |
Public Types inherited from Standard_Transient | |
typedef void | base_type |
Returns a type descriptor about this object. | |
This class defines services which permit to access Data issued from a File, in a form which does not depend of physical format : thus, each Record has an attached ParamList (to be managed) and resulting Entity.
Each Interface defines its own FileReaderData : on one hand by defining deferred methods given here, on the other hand by describing literal data and their accesses, with the help of basic classes such as String, Array1OfString, etc...
FileReaderData is used by a FileReaderTool, which is also specific of each Norm, to read an InterfaceModel of the Norm FileReaderData inherits TShared to be accessed by Handle : this allows FileReaderTool to define more easily the specific methods, and improves memory management.
|
inline |
|
protected |
Initializes arrays of Entities and of ParamLists attached to registered records <nbr> must be the maximum number of records to get (no way to extend it at run-time) : count entities and sub-entities ... <npar> is the total count of parameters (if it is not exact, it will be extended as necessary)
Hence, to each record can be bound an Entity and a list of Parameters. Each kind of FileReaderData can add other data, by having them in parallel (other arrays with same sizes) Else, it must manage binding between items and their data
void Interface_FileReaderData::AddParam | ( | const Standard_Integer | num, |
const Interface_FileParameter & | FP ) |
Same as above, but gets a complete FileParameter Warning : Content of <FP> is NOT copied : its original address and space in memory are assumed to be managed elsewhere (see ParamSet)
void Interface_FileReaderData::AddParam | ( | const Standard_Integer | num, |
const Standard_CString | aval, | ||
const Interface_ParamType | atype, | ||
const Standard_Integer | nument = 0 ) |
Adds a parameter to record no "num" and fills its fields (EntityNumber is optional) Warning : <aval> is assumed to be memory-managed elsewhere : it is NOT copied. This gives a best speed : strings remain stored in pages of characters.
void Interface_FileReaderData::AddParam | ( | const Standard_Integer | num, |
const TCollection_AsciiString & | aval, | ||
const Interface_ParamType | atype, | ||
const Standard_Integer | nument = 0 ) |
Same as above, but gets a AsciiString from TCollection Remark that the content of the AsciiString is locally copied (because its content is most often lost after using)
void Interface_FileReaderData::BindEntity | ( | const Standard_Integer | num, |
const Handle< Standard_Transient > & | ent ) |
Binds an entity to a record.
const Handle< Standard_Transient > & Interface_FileReaderData::BoundEntity | ( | const Standard_Integer | num | ) | const |
Returns the entity bound to a record, set by SetEntities.
Interface_FileParameter & Interface_FileReaderData::ChangeParam | ( | const Standard_Integer | num, |
const Standard_Integer | nump ) |
Same as above, but in order to be modified on place.
|
protected |
Returns a parameter given its absolute rank in the file in order to be consulted or modified in specilaized actions.
void Interface_FileReaderData::Destroy | ( | ) |
Destructor (waiting for memory management)
|
static |
Same spec.s as standard <atof> but 5 times faster.
|
pure virtual |
Determines the record number defining an Entity following a given record number. Specific to each sub-class of FileReaderData. Returning zero means no record found.
Implemented in IGESData_IGESReaderData, and StepData_StepReaderData.
void Interface_FileReaderData::InitParams | ( | const Standard_Integer | num | ) |
attaches an empty ParamList to a Record
Standard_Boolean Interface_FileReaderData::IsErrorLoad | ( | ) | const |
Returns True if the status "Error Load" has been set (to True or False)
Standard_Boolean Interface_FileReaderData::IsParamDefined | ( | const Standard_Integer | num, |
const Standard_Integer | nump ) const |
Returns True if parameter "nump" of record "num" is defined (it is not if its type is ParamVoid)
|
virtual |
Returns the count of entities. Depending of each norm, records can be Entities or SubParts (SubList in STEP, SubGroup in SET ...). NbEntities counts only Entities, not Subs Used for memory reservation in InterfaceModel Default implementation uses FindNextRecord Can be redefined into a more performant way.
Reimplemented in IGESData_IGESReaderData, and StepData_StepReaderData.
Standard_Integer Interface_FileReaderData::NbParams | ( | const Standard_Integer | num | ) | const |
Returns count of parameters attached to record "num" If <num> = 0, returns the total recorded count of parameters.
|
virtual |
Returns the count of registered records That is, value given for Initialization (can be redefined)
const Interface_FileParameter & Interface_FileReaderData::Param | ( | const Standard_Integer | num, |
const Standard_Integer | nump ) const |
Returns parameter "nump" of record "num", as a complete FileParameter.
Standard_CString Interface_FileReaderData::ParamCValue | ( | const Standard_Integer | num, |
const Standard_Integer | nump ) const |
Same as above, but as a CString was C++ : return const.
const Handle< Standard_Transient > & Interface_FileReaderData::ParamEntity | ( | const Standard_Integer | num, |
const Standard_Integer | nump ) const |
Returns the StepEntity referenced by a parameter Error if none.
Standard_Integer Interface_FileReaderData::ParamFirstRank | ( | const Standard_Integer | num | ) | const |
Returns the absolute rank of the beginning of a record (its list is from ParamFirstRank+1 to ParamFirstRank+NbParams)
Standard_Integer Interface_FileReaderData::ParamNumber | ( | const Standard_Integer | num, |
const Standard_Integer | nump ) const |
Returns record number of an entity referenced by a parameter of type Ident; 0 if no EntityNumber has been determined Note that it is used to reference Entities but also Sublists (sublists are not objects, but internal descriptions)
|
protected |
For a given absolute rank of parameter, determines the record to which its belongs, and the parameter number for it.
Handle< Interface_ParamList > Interface_FileReaderData::Params | ( | const Standard_Integer | num | ) | const |
Returns the complete ParamList of a record (read only) num = 0 to return the whole param list for the file.
Interface_ParamType Interface_FileReaderData::ParamType | ( | const Standard_Integer | num, |
const Standard_Integer | nump ) const |
Returns type of parameter "nump" of record "num" Returns literal value of parameter "nump" of record "num" was C++ : return const &.
Standard_Boolean Interface_FileReaderData::ResetErrorLoad | ( | ) |
Returns the former value of status "Error Load" then resets it Used to read the status then ensure it is reset.
void Interface_FileReaderData::SetErrorLoad | ( | const Standard_Boolean | val | ) |
Sets the status "Error Load" on, to overside check fails <val> True : declares unloaded <val> False : declares loaded If not called before loading (see FileReaderTool), check fails give the status IsErrorLoad says if SetErrorLoad has been called by user ResetErrorLoad resets it (called by FileReaderTool) This allows to specify that the currently loaded entity remains unloaded (because of syntactic fail)
void Interface_FileReaderData::SetParam | ( | const Standard_Integer | num, |
const Standard_Integer | nump, | ||
const Interface_FileParameter & | FP ) |
Sets a new value for a parameter of a record, given by : num : record number; nump : parameter number in the record.