PAL14861 A warning stop the computation

This commit is contained in:
eap 2007-12-19 15:06:39 +00:00
parent 92c5811d43
commit 0f966be150
3 changed files with 159 additions and 145 deletions

View File

@ -693,12 +693,12 @@ QFrame* SMESHGUI_ComputeDlg::createMainFrame (QWidget* theParent)
myBriefInfo = new SMESHGUI_MeshInfosBox(false, aFrame); myBriefInfo = new SMESHGUI_MeshInfosBox(false, aFrame);
myFullInfo = new SMESHGUI_MeshInfosBox(true, aFrame); myFullInfo = new SMESHGUI_MeshInfosBox(true, aFrame);
// errors // Computation errors
myErrorGroup = new QGroupBox(tr("ERRORS"), aFrame, "errorGrBox"); myCompErrorGroup = new QGroupBox(tr("ERRORS"), aFrame, "myCompErrorGroup");
myTable = new QTable( 1, NB_COLUMNS, myErrorGroup, "myTable"); myTable = new QTable( 1, NB_COLUMNS, myCompErrorGroup, "myTable");
myShowBtn = new QPushButton(tr("SHOW_SHAPE"), myErrorGroup, "myShowBtn"); myShowBtn = new QPushButton(tr("SHOW_SHAPE"), myCompErrorGroup, "myShowBtn");
myPublishBtn = new QPushButton(tr("PUBLISH_SHAPE"), myErrorGroup, "myPublishBtn"); myPublishBtn = new QPushButton(tr("PUBLISH_SHAPE"), myCompErrorGroup, "myPublishBtn");
myTable->setReadOnly( TRUE ); myTable->setReadOnly( TRUE );
myTable->hideColumn( COL_PUBLISHED ); myTable->hideColumn( COL_PUBLISHED );
@ -715,11 +715,11 @@ QFrame* SMESHGUI_ComputeDlg::createMainFrame (QWidget* theParent)
} }
myTable->horizontalHeader()->setLabel( col, header ); myTable->horizontalHeader()->setLabel( col, header );
} }
// layouting
myErrorGroup->setColumnLayout(0, Qt::Vertical); myCompErrorGroup->setColumnLayout(0, Qt::Vertical);
myErrorGroup->layout()->setSpacing(0); myCompErrorGroup->layout()->setSpacing(0);
myErrorGroup->layout()->setMargin(0); myCompErrorGroup->layout()->setMargin(0);
QGridLayout* grpLayout = new QGridLayout(myErrorGroup->layout()); QGridLayout* grpLayout = new QGridLayout(myCompErrorGroup->layout());
grpLayout->setAlignment(Qt::AlignTop); grpLayout->setAlignment(Qt::AlignTop);
grpLayout->setSpacing(SPACING); grpLayout->setSpacing(SPACING);
grpLayout->setMargin(MARGIN); grpLayout->setMargin(MARGIN);
@ -728,6 +728,11 @@ QFrame* SMESHGUI_ComputeDlg::createMainFrame (QWidget* theParent)
grpLayout->addWidget ( myPublishBtn, 1, 1 ); grpLayout->addWidget ( myPublishBtn, 1, 1 );
grpLayout->setRowStretch( 2, 1 ); grpLayout->setRowStretch( 2, 1 );
// Hypothesis definition errors
myHypErrorGroup = new QGroupBox(1,Qt::Vertical, tr("SMESH_WRN_MISSING_PARAMETERS"),aFrame);
myHypErrorLabel = new QLabel(myHypErrorGroup);
// Memory Lack Label // Memory Lack Label
myMemoryLackGroup = new QVGroupBox(tr("ERRORS"), aFrame, "memlackGrBox"); myMemoryLackGroup = new QVGroupBox(tr("ERRORS"), aFrame, "memlackGrBox");
@ -742,9 +747,12 @@ QFrame* SMESHGUI_ComputeDlg::createMainFrame (QWidget* theParent)
aLay->addWidget( nameBox ); aLay->addWidget( nameBox );
aLay->addWidget( myBriefInfo ); aLay->addWidget( myBriefInfo );
aLay->addWidget( myFullInfo ); aLay->addWidget( myFullInfo );
aLay->addWidget( myErrorGroup ); aLay->addWidget( myHypErrorGroup );
aLay->addWidget( myCompErrorGroup );
aLay->addWidget( myMemoryLackGroup ); aLay->addWidget( myMemoryLackGroup );
aLay->setStretchFactor( myErrorGroup, 1 ); aLay->setStretchFactor( myCompErrorGroup, 1 );
((QPushButton*) button( OK ))->setDefault( true );
return aFrame; return aFrame;
} }
@ -759,7 +767,8 @@ SMESHGUI_ComputeOp::SMESHGUI_ComputeOp()
{ {
myDlg = new SMESHGUI_ComputeDlg; myDlg = new SMESHGUI_ComputeDlg;
myTShapeDisplayer = new TShapeDisplayer(); myTShapeDisplayer = new TShapeDisplayer();
myHelpFileName = "about_meshes_page.html"; //myHelpFileName = "/files/about_meshes.htm"; // V3
myHelpFileName = "about_meshes_page.html"; // V4
// connect signals and slots // connect signals and slots
connect(myDlg->myShowBtn, SIGNAL (clicked()), SLOT(onPreviewShape())); connect(myDlg->myShowBtn, SIGNAL (clicked()), SLOT(onPreviewShape()));
@ -777,15 +786,11 @@ void SMESHGUI_ComputeOp::startOperation()
{ {
SMESHGUI_Operation::startOperation(); SMESHGUI_Operation::startOperation();
// check selection
SMESH::SMESH_Mesh_var aMesh; SMESH::SMESH_Mesh_var aMesh;
SMESH::compute_error_array_var anErrors;
myMainShape = GEOM::GEOM_Object::_nil(); myMainShape = GEOM::GEOM_Object::_nil();
// COMPUTE MESH
bool computeFailed = true, memoryLack = false;
LightApp_SelectionMgr *Sel = selectionMgr(); LightApp_SelectionMgr *Sel = selectionMgr();
SALOME_ListIO selected; Sel->selectedObjects( selected ); SALOME_ListIO selected; Sel->selectedObjects( selected );
@ -801,24 +806,35 @@ void SMESHGUI_ComputeOp::startOperation()
Handle(SALOME_InteractiveObject) IObject = selected.First(); Handle(SALOME_InteractiveObject) IObject = selected.First();
aMesh = SMESH::GetMeshByIO(IObject); aMesh = SMESH::GetMeshByIO(IObject);
if (!aMesh->_is_nil()) if (aMesh->_is_nil()) {
{ SUIT_MessageBox::warn1(desktop(),
tr("SMESH_WRN_WARNING"),
tr("SMESH_WRN_NO_AVAILABLE_DATA"),
tr("SMESH_BUT_OK"));
onCancel();
return;
}
// COMPUTE MESH
MemoryReserve aMemoryReserve; MemoryReserve aMemoryReserve;
SMESH::compute_error_array_var aCompErrors;
QString aHypErrors;
bool computeFailed = true, memoryLack = false;
_PTR(SObject) aMeshSObj = SMESH::FindSObject(aMesh); _PTR(SObject) aMeshSObj = SMESH::FindSObject(aMesh);
myMainShape = aMesh->GetShapeToMesh(); myMainShape = aMesh->GetShapeToMesh();
if ( ((!myMainShape->_is_nil() && aMesh->HasShapeToMesh()) || bool hasShape = aMesh->HasShapeToMesh();
(myMainShape->_is_nil() && !aMesh->HasShapeToMesh())) bool shapeOK = myMainShape->_is_nil() ? !hasShape : hasShape;
&& aMeshSObj ) if ( shapeOK && aMeshSObj )
{ {
myDlg->myMeshName->setText( aMeshSObj->GetName() ); myDlg->myMeshName->setText( aMeshSObj->GetName() );
SMESH::SMESH_Gen_var gen = getSMESHGUI()->GetSMESHGen(); SMESH::SMESH_Gen_var gen = getSMESHGUI()->GetSMESHGen();
SMESH::algo_error_array_var errors = gen->GetAlgoState(aMesh,myMainShape); SMESH::algo_error_array_var errors = gen->GetAlgoState(aMesh,myMainShape);
if ( errors->length() > 0 ) { if ( errors->length() > 0 ) {
SUIT_MessageBox::warn1(desktop(), tr("SMESH_WRN_WARNING"), aHypErrors = SMESH::GetMessageOnAlgoStateErrors( errors.in() );
SMESH::GetMessageOnAlgoStateErrors( errors.in() ),
tr("SMESH_BUT_OK"));
onCancel();
return;
} }
SUIT_OverrideCursor aWaitCursor; SUIT_OverrideCursor aWaitCursor;
try { try {
@ -830,24 +846,15 @@ void SMESHGUI_ComputeOp::startOperation()
} }
catch(const SALOME::SALOME_Exception & S_ex){ catch(const SALOME::SALOME_Exception & S_ex){
memoryLack = true; memoryLack = true;
//SalomeApp_Tools::QtCatchCorbaException(S_ex);
} }
try { try {
#if (OCC_VERSION_MAJOR << 16 | OCC_VERSION_MINOR << 8 | OCC_VERSION_MAINTENANCE) > 0x060100 #if (OCC_VERSION_MAJOR << 16 | OCC_VERSION_MINOR << 8 | OCC_VERSION_MAINTENANCE) > 0x060100
OCC_CATCH_SIGNALS; OCC_CATCH_SIGNALS;
#endif #endif
anErrors = gen->GetComputeErrors( aMesh, myMainShape ); aCompErrors = gen->GetComputeErrors( aMesh, myMainShape );
// if ( anErrors->length() == 0 ) {
// SUIT_MessageBox::warn1(desktop(),
// tr("SMESH_WRN_WARNING"),
// tr("SMESH_WRN_COMPUTE_FAILED"),
// tr("SMESH_BUT_OK"));
// onCancel();
// return;
// }
// check if there are memory problems // check if there are memory problems
for ( int i = 0; (i < anErrors->length()) && !memoryLack; ++i ) for ( int i = 0; (i < aCompErrors->length()) && !memoryLack; ++i )
memoryLack = ( anErrors[ i ].code == SMESH::COMPERR_MEMORY_PB ); memoryLack = ( aCompErrors[ i ].code == SMESH::COMPERR_MEMORY_PB );
} }
catch(const SALOME::SALOME_Exception & S_ex){ catch(const SALOME::SALOME_Exception & S_ex){
memoryLack = true; memoryLack = true;
@ -883,36 +890,29 @@ void SMESHGUI_ComputeOp::startOperation()
Sel->setSelectedObjects( selected ); Sel->setSelectedObjects( selected );
} }
} }
}
else {
SUIT_MessageBox::warn1(desktop(),
tr("SMESH_WRN_WARNING"),
tr("SMESH_WRN_NO_AVAILABLE_DATA"),
tr("SMESH_BUT_OK"));
onCancel();
return;
}
myDlg->setCaption(tr( computeFailed ? "SMESH_WRN_COMPUTE_FAILED" : "SMESH_COMPUTE_SUCCEED")); myDlg->setCaption(tr( computeFailed ? "SMESH_WRN_COMPUTE_FAILED" : "SMESH_COMPUTE_SUCCEED"));
myDlg->myMemoryLackGroup->hide(); myDlg->myMemoryLackGroup->hide();
// SHOW ERRORS // SHOW ERRORS
bool noError = ( !anErrors.operator->() || anErrors->length() == 0 ); bool noCompError = ( !aCompErrors.operator->() || aCompErrors->length() == 0 );
bool noHypoError = ( aHypErrors.isEmpty() );
if ( memoryLack ) if ( memoryLack )
{ {
myDlg->myMemoryLackGroup->show(); myDlg->myMemoryLackGroup->show();
myDlg->myFullInfo->hide(); myDlg->myFullInfo->hide();
myDlg->myBriefInfo->hide(); myDlg->myBriefInfo->hide();
myDlg->myErrorGroup->hide(); myDlg->myHypErrorGroup->hide();
myDlg->myCompErrorGroup->hide();
} }
else if ( noError ) else if ( noCompError && noHypoError )
{ {
SUIT_OverrideCursor aWaitCursor;
myDlg->myFullInfo->SetInfoByMesh( aMesh ); myDlg->myFullInfo->SetInfoByMesh( aMesh );
myDlg->myFullInfo->show(); myDlg->myFullInfo->show();
myDlg->myBriefInfo->hide(); myDlg->myBriefInfo->hide();
myDlg->myErrorGroup->hide(); myDlg->myHypErrorGroup->hide();
myDlg->myCompErrorGroup->hide();
} }
else else
{ {
@ -920,28 +920,39 @@ void SMESHGUI_ComputeOp::startOperation()
myDlg->myBriefInfo->SetInfoByMesh( aMesh ); myDlg->myBriefInfo->SetInfoByMesh( aMesh );
myDlg->myBriefInfo->show(); myDlg->myBriefInfo->show();
myDlg->myFullInfo->hide(); myDlg->myFullInfo->hide();
myDlg->myErrorGroup->show();
bool hasShape = aMesh->HasShapeToMesh(); if ( noHypoError ) {
if ( !hasShape ) myDlg->myHypErrorGroup->hide();
{ }
else {
myDlg->myHypErrorGroup->show();
myDlg->myHypErrorLabel->setText( aHypErrors );
}
if ( noCompError ) {
myDlg->myCompErrorGroup->hide();
}
else {
myDlg->myCompErrorGroup->show();
if ( !hasShape ) {
myDlg->myPublishBtn->hide(); myDlg->myPublishBtn->hide();
myDlg->myShowBtn->hide(); myDlg->myShowBtn->hide();
} }
else else {
{
myDlg->myPublishBtn->show(); myDlg->myPublishBtn->show();
myDlg->myShowBtn->show(); myDlg->myShowBtn->show();
} }
// fill table of errors // fill table of errors
tbl->setNumRows( anErrors->length() ); tbl->setNumRows( aCompErrors->length() );
if ( !hasShape ) tbl->hideColumn( COL_SHAPE ); if ( !hasShape ) tbl->hideColumn( COL_SHAPE );
else tbl->showColumn( COL_SHAPE ); else tbl->showColumn( COL_SHAPE );
tbl->setColumnWidth( COL_ERROR, 200 ); tbl->setColumnWidth( COL_ERROR, 200 );
for ( int row = 0; row < anErrors->length(); ++row ) for ( int row = 0; row < aCompErrors->length(); ++row )
{ {
SMESH::ComputeError & err = anErrors[ row ]; SMESH::ComputeError & err = aCompErrors[ row ];
tbl->setText( row, COL_ALGO, err.algoName.in() ); tbl->setText( row, COL_ALGO, err.algoName.in() );
tbl->setText( row, COL_ERROR, errorText( err.code, err.comment.in() )); tbl->setText( row, COL_ERROR, errorText( err.code, err.comment.in() ));
tbl->setText( row, COL_SHAPEID, QString("%1").arg( err.subShapeID )); tbl->setText( row, COL_SHAPEID, QString("%1").arg( err.subShapeID ));
@ -961,6 +972,7 @@ void SMESHGUI_ComputeOp::startOperation()
tbl->setCurrentCell(0,0); tbl->setCurrentCell(0,0);
currentCellChanged(); // to update buttons currentCellChanged(); // to update buttons
} }
}
myDlg->show(); myDlg->show();
} }

View File

@ -131,7 +131,9 @@ private:
QLabel* myMeshName; QLabel* myMeshName;
QGroupBox* myMemoryLackGroup; QGroupBox* myMemoryLackGroup;
QGroupBox* myErrorGroup; QGroupBox* myCompErrorGroup;
QGroupBox* myHypErrorGroup;
QLabel* myHypErrorLabel;
QTable* myTable; QTable* myTable;
QPushButton* myShowBtn; QPushButton* myShowBtn;
QPushButton* myPublishBtn; QPushButton* myPublishBtn;

View File

@ -615,7 +615,7 @@ namespace SMESH{
#define CASE2MESSAGE(enum) case SMESH::enum: msg = QObject::tr( "STATE_" #enum ); break; #define CASE2MESSAGE(enum) case SMESH::enum: msg = QObject::tr( "STATE_" #enum ); break;
QString GetMessageOnAlgoStateErrors(const algo_error_array& errors) QString GetMessageOnAlgoStateErrors(const algo_error_array& errors)
{ {
QString resMsg = QObject::tr("SMESH_WRN_MISSING_PARAMETERS") + ":\n"; QString resMsg; // PAL14861 = QObject::tr("SMESH_WRN_MISSING_PARAMETERS") + ":\n";
for ( int i = 0; i < errors.length(); ++i ) { for ( int i = 0; i < errors.length(); ++i ) {
const SMESH::AlgoStateError & error = errors[ i ]; const SMESH::AlgoStateError & error = errors[ i ];
const bool hasAlgo = ( strlen( error.algoName ) != 0 ); const bool hasAlgo = ( strlen( error.algoName ) != 0 );