mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-12 01:30:34 +05:00
PAL8021. In AlgpStateEngine(), clean existing sub-mesh only if hypothesis change. In CleanDependants(), do not go upper than SOLID.
This commit is contained in:
parent
137c43b02f
commit
a9750358c9
@ -792,20 +792,17 @@ SMESH_Hypothesis::Hypothesis_Status
|
|||||||
ASSERT(algo);
|
ASSERT(algo);
|
||||||
if (!algo->CheckHypothesis((*_father),_subShape, ret ))
|
if (!algo->CheckHypothesis((*_father),_subShape, ret ))
|
||||||
{
|
{
|
||||||
MESSAGE("two applying algo on the same shape not allowed");
|
|
||||||
_meshDS->RemoveHypothesis(_subShape, anHyp);
|
|
||||||
if ( !SMESH_Hypothesis::IsStatusFatal( ret ))
|
if ( !SMESH_Hypothesis::IsStatusFatal( ret ))
|
||||||
// ret should be fatal: anHyp was not added
|
// ret should be fatal: anHyp was not added
|
||||||
ret = SMESH_Hypothesis::HYP_INCOMPATIBLE;
|
ret = SMESH_Hypothesis::HYP_INCOMPATIBLE;
|
||||||
}
|
}
|
||||||
else if (SMESH_Hypothesis::IsStatusFatal( ret ))
|
|
||||||
{
|
|
||||||
_meshDS->RemoveHypothesis(_subShape, anHyp);
|
|
||||||
}
|
|
||||||
else if (!_father->IsUsedHypothesis( anHyp, _subShape ))
|
else if (!_father->IsUsedHypothesis( anHyp, _subShape ))
|
||||||
{
|
|
||||||
_meshDS->RemoveHypothesis(_subShape, anHyp);
|
|
||||||
ret = SMESH_Hypothesis::HYP_INCOMPATIBLE;
|
ret = SMESH_Hypothesis::HYP_INCOMPATIBLE;
|
||||||
|
|
||||||
|
if (SMESH_Hypothesis::IsStatusFatal( ret ))
|
||||||
|
{
|
||||||
|
MESSAGE("do not add extra hypothesis");
|
||||||
|
_meshDS->RemoveHypothesis(_subShape, anHyp);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -815,11 +812,19 @@ SMESH_Hypothesis::Hypothesis_Status
|
|||||||
}
|
}
|
||||||
case ADD_ALGO: { //already existing algo : on father ?
|
case ADD_ALGO: { //already existing algo : on father ?
|
||||||
SMESH_Algo* algo = gen->GetAlgo((*_father), _subShape);
|
SMESH_Algo* algo = gen->GetAlgo((*_father), _subShape);
|
||||||
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret ))
|
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret )) {
|
||||||
SetAlgoState(HYP_OK);
|
// check if algo changes
|
||||||
|
SMESH_HypoFilter f;
|
||||||
|
f.Init( SMESH_HypoFilter::IsAlgo() );
|
||||||
|
f.And( SMESH_HypoFilter::IsApplicableTo( _subShape ));
|
||||||
|
f.AndNot( SMESH_HypoFilter::Is( algo ));
|
||||||
|
const SMESH_Hypothesis * prevAlgo = _father->GetHypothesis( _subShape, f, true );
|
||||||
|
if (prevAlgo &&
|
||||||
|
string(algo->GetName()) != string(prevAlgo->GetName()) )
|
||||||
|
modifiedHyp = true;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
SetAlgoState(MISSING_HYP);
|
SetAlgoState(MISSING_HYP);
|
||||||
modifiedHyp = true;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case REMOVE_HYP: {
|
case REMOVE_HYP: {
|
||||||
@ -840,14 +845,14 @@ SMESH_Hypothesis::Hypothesis_Status
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret ))
|
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret )) {
|
||||||
SetAlgoState(HYP_OK);
|
// check if algo remains
|
||||||
else
|
|
||||||
SetAlgoState(MISSING_HYP);
|
|
||||||
// check if same algo remains
|
|
||||||
if ( anHyp != algo && strcmp( anHyp->GetName(), algo->GetName()) )
|
if ( anHyp != algo && strcmp( anHyp->GetName(), algo->GetName()) )
|
||||||
modifiedHyp = true;
|
modifiedHyp = true;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
SetAlgoState(MISSING_HYP);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case ADD_FATHER_HYP: { // new father hypothesis ?
|
case ADD_FATHER_HYP: { // new father hypothesis ?
|
||||||
@ -855,7 +860,6 @@ SMESH_Hypothesis::Hypothesis_Status
|
|||||||
ASSERT(algo);
|
ASSERT(algo);
|
||||||
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret ))
|
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret ))
|
||||||
{
|
{
|
||||||
SetAlgoState(HYP_OK);
|
|
||||||
if (_father->IsUsedHypothesis( anHyp, _subShape )) // new Hyp
|
if (_father->IsUsedHypothesis( anHyp, _subShape )) // new Hyp
|
||||||
modifiedHyp = true;
|
modifiedHyp = true;
|
||||||
}
|
}
|
||||||
@ -863,27 +867,35 @@ SMESH_Hypothesis::Hypothesis_Status
|
|||||||
SetAlgoState(MISSING_HYP);
|
SetAlgoState(MISSING_HYP);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case ADD_FATHER_ALGO: { // a new algo on father
|
case ADD_FATHER_ALGO: {
|
||||||
SMESH_Algo* algo = gen->GetAlgo((*_father), _subShape);
|
SMESH_Algo* algo = gen->GetAlgo((*_father), _subShape);
|
||||||
if ( algo == anHyp ) {
|
if ( algo == anHyp ) { // a new algo on father
|
||||||
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret ))
|
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret )) {
|
||||||
SetAlgoState(HYP_OK);
|
// check if algo changes
|
||||||
|
SMESH_HypoFilter f;
|
||||||
|
f.Init( SMESH_HypoFilter::IsAlgo() );
|
||||||
|
f.And( SMESH_HypoFilter::IsApplicableTo( _subShape ));
|
||||||
|
f.AndNot( SMESH_HypoFilter::Is( algo ));
|
||||||
|
const SMESH_Hypothesis* prevAlgo = _father->GetHypothesis( _subShape, f, true );
|
||||||
|
if (prevAlgo &&
|
||||||
|
string(algo->GetName()) != string(prevAlgo->GetName()) )
|
||||||
|
modifiedHyp = true;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
SetAlgoState(MISSING_HYP);
|
SetAlgoState(MISSING_HYP);
|
||||||
modifiedHyp = true;
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case REMOVE_FATHER_HYP: {
|
case REMOVE_FATHER_HYP: {
|
||||||
SMESH_Algo* algo = gen->GetAlgo((*_father), _subShape);
|
SMESH_Algo* algo = gen->GetAlgo((*_father), _subShape);
|
||||||
ASSERT(algo);
|
ASSERT(algo);
|
||||||
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret ))
|
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret )) {
|
||||||
SetAlgoState(HYP_OK);
|
|
||||||
else
|
|
||||||
SetAlgoState(MISSING_HYP);
|
|
||||||
// is there the same local hyp or maybe a new father algo applied?
|
// is there the same local hyp or maybe a new father algo applied?
|
||||||
if ( !GetSimilarAttached( _subShape, anHyp ) )
|
if ( !GetSimilarAttached( _subShape, anHyp ) )
|
||||||
modifiedHyp = true;
|
modifiedHyp = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SetAlgoState(MISSING_HYP);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case REMOVE_FATHER_ALGO: {
|
case REMOVE_FATHER_ALGO: {
|
||||||
@ -894,13 +906,13 @@ SMESH_Hypothesis::Hypothesis_Status
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret ))
|
if ( algo->CheckHypothesis((*_father),_subShape, aux_ret )) {
|
||||||
SetAlgoState(HYP_OK);
|
// check if algo changes
|
||||||
|
if ( string(algo->GetName()) != string( anHyp->GetName()) )
|
||||||
|
modifiedHyp = true;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
SetAlgoState(MISSING_HYP);
|
SetAlgoState(MISSING_HYP);
|
||||||
// is there the same local algo or maybe a new father algo applied?
|
|
||||||
if ( !GetSimilarAttached( _subShape, anHyp ))
|
|
||||||
modifiedHyp = true;
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1485,21 +1497,21 @@ void SMESH_subMesh::UpdateDependantsState(const compute_event theEvent)
|
|||||||
|
|
||||||
void SMESH_subMesh::CleanDependants()
|
void SMESH_subMesh::CleanDependants()
|
||||||
{
|
{
|
||||||
//MESSAGE("SMESH_subMesh::CleanDependants: shape type " << _subShape.ShapeType() );
|
|
||||||
|
|
||||||
TopTools_ListIteratorOfListOfShape it( _father->GetAncestors( _subShape ));
|
TopTools_ListIteratorOfListOfShape it( _father->GetAncestors( _subShape ));
|
||||||
for (; it.More(); it.Next())
|
for (; it.More(); it.Next())
|
||||||
{
|
{
|
||||||
const TopoDS_Shape& ancestor = it.Value();
|
const TopoDS_Shape& ancestor = it.Value();
|
||||||
//MESSAGE("ancestor shape type " << ancestor.ShapeType() );
|
// PAL8021. do not go upper than SOLID, else ComputeStateEngine(CLEANDEP)
|
||||||
|
// will erase mesh on other shapes in a compound
|
||||||
|
if ( ancestor.ShapeType() >= TopAbs_SOLID ) {
|
||||||
SMESH_subMesh *aSubMesh = _father->GetSubMeshContaining(ancestor);
|
SMESH_subMesh *aSubMesh = _father->GetSubMeshContaining(ancestor);
|
||||||
if (aSubMesh)
|
if (aSubMesh)
|
||||||
aSubMesh->ComputeStateEngine(CLEANDEP);
|
aSubMesh->ComputeStateEngine(CLEANDEP);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
ComputeStateEngine(CLEAN);
|
ComputeStateEngine(CLEAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
/*!
|
/*!
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user