mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-28 16:50:32 +05:00
correct SMESH_ElementFactory
This commit is contained in:
parent
0f2942f29e
commit
fed3f44553
@ -92,11 +92,11 @@ SMDS_ElementFactory::~SMDS_ElementFactory()
|
|||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief Return a number of elements in a chunk
|
* \brief Return a number of elements in a chunk
|
||||||
* \return int - chunk size
|
* \return smIdType - chunk size
|
||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
int SMDS_ElementFactory::ChunkSize()
|
smIdType SMDS_ElementFactory::ChunkSize()
|
||||||
{
|
{
|
||||||
return theChunkSize;
|
return theChunkSize;
|
||||||
}
|
}
|
||||||
@ -108,7 +108,7 @@ int SMDS_ElementFactory::ChunkSize()
|
|||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
int SMDS_ElementFactory::GetFreeID()
|
smIdType SMDS_ElementFactory::GetFreeID()
|
||||||
{
|
{
|
||||||
if ( myChunksWithUnused.empty() )
|
if ( myChunksWithUnused.empty() )
|
||||||
{
|
{
|
||||||
@ -122,11 +122,11 @@ int SMDS_ElementFactory::GetFreeID()
|
|||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief Return maximal ID of an used element
|
* \brief Return maximal ID of an used element
|
||||||
* \return int - element ID
|
* \return smIdType - element ID
|
||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
int SMDS_ElementFactory::GetMaxID()
|
smIdType SMDS_ElementFactory::GetMaxID()
|
||||||
{
|
{
|
||||||
int id = 0;
|
int id = 0;
|
||||||
TIndexRanges usedRanges;
|
TIndexRanges usedRanges;
|
||||||
@ -143,11 +143,11 @@ int SMDS_ElementFactory::GetMaxID()
|
|||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief Return minimal ID of an used element
|
* \brief Return minimal ID of an used element
|
||||||
* \return int - element ID
|
* \return smIdType - element ID
|
||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
int SMDS_ElementFactory::GetMinID()
|
smIdType SMDS_ElementFactory::GetMinID()
|
||||||
{
|
{
|
||||||
int id = 0;
|
int id = 0;
|
||||||
TIndexRanges usedRanges;
|
TIndexRanges usedRanges;
|
||||||
@ -169,7 +169,7 @@ int SMDS_ElementFactory::GetMinID()
|
|||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
SMDS_MeshElement* SMDS_ElementFactory::NewElement( const int id )
|
SMDS_MeshElement* SMDS_ElementFactory::NewElement( const smIdType id )
|
||||||
{
|
{
|
||||||
int iChunk = ( id - 1 ) / theChunkSize;
|
int iChunk = ( id - 1 ) / theChunkSize;
|
||||||
int index = ( id - 1 ) % theChunkSize;
|
int index = ( id - 1 ) % theChunkSize;
|
||||||
@ -200,7 +200,7 @@ SMDS_MeshElement* SMDS_ElementFactory::NewElement( const int id )
|
|||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
const SMDS_MeshElement* SMDS_ElementFactory::FindElement( const int id ) const
|
const SMDS_MeshElement* SMDS_ElementFactory::FindElement( const smIdType id ) const
|
||||||
{
|
{
|
||||||
if ( id > 0 )
|
if ( id > 0 )
|
||||||
{
|
{
|
||||||
@ -488,7 +488,7 @@ void SMDS_NodeFactory::SetNbShapes( size_t nbShapes )
|
|||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
int SMDS_NodeFactory::GetShapeDim( int shapeID ) const
|
int SMDS_NodeFactory::GetShapeDim( smIdType shapeID ) const
|
||||||
{
|
{
|
||||||
return shapeID < (int)myShapeDim.size() ? myShapeDim[ shapeID ] : theDefaultShapeDim;
|
return shapeID < (int)myShapeDim.size() ? myShapeDim[ shapeID ] : theDefaultShapeDim;
|
||||||
}
|
}
|
||||||
@ -499,9 +499,9 @@ int SMDS_NodeFactory::GetShapeDim( int shapeID ) const
|
|||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
void SMDS_NodeFactory::SetShapeDim( int shapeID, int dim )
|
void SMDS_NodeFactory::SetShapeDim( smIdType shapeID, int dim )
|
||||||
{
|
{
|
||||||
if ( shapeID >= (int)myShapeDim.size() )
|
if ( shapeID >= (smIdType)myShapeDim.size() )
|
||||||
myShapeDim.resize( shapeID + 10, theDefaultShapeDim );
|
myShapeDim.resize( shapeID + 10, theDefaultShapeDim );
|
||||||
myShapeDim[ shapeID ] = dim;
|
myShapeDim[ shapeID ] = dim;
|
||||||
}
|
}
|
||||||
|
@ -40,6 +40,8 @@
|
|||||||
|
|
||||||
#include <vtkType.h>
|
#include <vtkType.h>
|
||||||
|
|
||||||
|
#include <smIdType.hxx>
|
||||||
|
|
||||||
class SMDS_ElementChunk;
|
class SMDS_ElementChunk;
|
||||||
class SMDS_Mesh;
|
class SMDS_Mesh;
|
||||||
class SMDS_MeshCell;
|
class SMDS_MeshCell;
|
||||||
@ -78,25 +80,25 @@ public:
|
|||||||
virtual ~SMDS_ElementFactory();
|
virtual ~SMDS_ElementFactory();
|
||||||
|
|
||||||
//! Return minimal ID of a non-used element
|
//! Return minimal ID of a non-used element
|
||||||
int GetFreeID();
|
smIdType GetFreeID();
|
||||||
|
|
||||||
//! Return maximal ID of an used element
|
//! Return maximal ID of an used element
|
||||||
int GetMaxID();
|
smIdType GetMaxID();
|
||||||
|
|
||||||
//! Return minimal ID of an used element
|
//! Return minimal ID of an used element
|
||||||
int GetMinID();
|
smIdType GetMinID();
|
||||||
|
|
||||||
//! Return an element by ID. NULL if the element with the given ID is already used
|
//! Return an element by ID. NULL if the element with the given ID is already used
|
||||||
SMDS_MeshElement* NewElement( const int id );
|
SMDS_MeshElement* NewElement( const smIdType id );
|
||||||
|
|
||||||
//! Return a SMDS_MeshCell by ID. NULL if the cell with the given ID is already used
|
//! Return a SMDS_MeshCell by ID. NULL if the cell with the given ID is already used
|
||||||
SMDS_MeshCell* NewCell( const int id ) { return static_cast<SMDS_MeshCell*>( NewElement( id )); }
|
SMDS_MeshCell* NewCell( const smIdType id ) { return static_cast<SMDS_MeshCell*>( NewElement( id )); }
|
||||||
|
|
||||||
//! Return an used element by ID. NULL if the element with the given ID is not yet used
|
//! Return an used element by ID. NULL if the element with the given ID is not yet used
|
||||||
const SMDS_MeshElement* FindElement( const int id ) const;
|
const SMDS_MeshElement* FindElement( const smIdType id ) const;
|
||||||
|
|
||||||
//! Return a number of used elements
|
//! Return a number of used elements
|
||||||
int NbUsedElements() const { return myNbUsedElements; }
|
smIdType NbUsedElements() const { return myNbUsedElements; }
|
||||||
|
|
||||||
//! Return an iterator on all element filtered using a given filter.
|
//! Return an iterator on all element filtered using a given filter.
|
||||||
// nbElemsToReturn is used to optimize by stopping the iteration as soon as
|
// nbElemsToReturn is used to optimize by stopping the iteration as soon as
|
||||||
@ -132,7 +134,7 @@ public:
|
|||||||
virtual bool CompactChangePointers();
|
virtual bool CompactChangePointers();
|
||||||
|
|
||||||
//! Return a number of elements in a chunk
|
//! Return a number of elements in a chunk
|
||||||
static int ChunkSize();
|
static smIdType ChunkSize();
|
||||||
};
|
};
|
||||||
|
|
||||||
//------------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------------
|
||||||
@ -149,19 +151,19 @@ public:
|
|||||||
~SMDS_NodeFactory();
|
~SMDS_NodeFactory();
|
||||||
|
|
||||||
//! Return a SMDS_MeshNode by ID. NULL if the node with the given ID is already used
|
//! Return a SMDS_MeshNode by ID. NULL if the node with the given ID is already used
|
||||||
SMDS_MeshNode* NewNode( int id ) { return (SMDS_MeshNode*) NewElement(id); }
|
SMDS_MeshNode* NewNode( smIdType id ) { return (SMDS_MeshNode*) NewElement(id); }
|
||||||
|
|
||||||
//! Return an used node by ID. NULL if the node with the given ID is not yet used
|
//! Return an used node by ID. NULL if the node with the given ID is not yet used
|
||||||
const SMDS_MeshNode* FindNode( int id ) { return (const SMDS_MeshNode*) FindElement(id); }
|
const SMDS_MeshNode* FindNode( smIdType id ) { return (const SMDS_MeshNode*) FindElement(id); }
|
||||||
|
|
||||||
//! Set a total number of sub-shapes in the main shape
|
//! Set a total number of sub-shapes in the main shape
|
||||||
void SetNbShapes( size_t nbShapes );
|
void SetNbShapes( size_t nbShapes );
|
||||||
|
|
||||||
//! Return a dimension of a shape
|
//! Return a dimension of a shape
|
||||||
int GetShapeDim( int shapeID ) const;
|
int GetShapeDim( smIdType shapeID ) const;
|
||||||
|
|
||||||
//! Set a dimension of a shape
|
//! Set a dimension of a shape
|
||||||
void SetShapeDim( int shapeID, int dim );
|
void SetShapeDim( smIdType shapeID, int dim );
|
||||||
|
|
||||||
//! De-allocate all nodes
|
//! De-allocate all nodes
|
||||||
virtual void Clear();
|
virtual void Clear();
|
||||||
@ -403,7 +405,7 @@ public:
|
|||||||
static bool IsUsed( const _UsedRange& r ) { return r.myValue; }
|
static bool IsUsed( const _UsedRange& r ) { return r.myValue; }
|
||||||
|
|
||||||
//! Return index of an element in the chunk
|
//! Return index of an element in the chunk
|
||||||
int Index( const SMDS_MeshElement* e ) const { return e - myElements; }
|
smIdType Index( const SMDS_MeshElement* e ) const { return e - myElements; }
|
||||||
|
|
||||||
//! Return ID of the 1st element in the chunk
|
//! Return ID of the 1st element in the chunk
|
||||||
int Get1stID() const { return my1stID; }
|
int Get1stID() const { return my1stID; }
|
||||||
|
Loading…
Reference in New Issue
Block a user