From: sln Date: Tue, 23 Aug 2005 13:43:25 +0000 (+0000) Subject: try/catch blocks added X-Git-Tag: T_3_0_2a1~4 X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=commitdiff_plain;h=ee06fcf090b66e3118b5d5521532b9b42165840e try/catch blocks added --- diff --git a/src/SMESHGUI/SMESHGUI_MeshOp.cxx b/src/SMESHGUI/SMESHGUI_MeshOp.cxx index 1c5df7f4c..ac30ec89b 100644 --- a/src/SMESHGUI/SMESHGUI_MeshOp.cxx +++ b/src/SMESHGUI/SMESHGUI_MeshOp.cxx @@ -25,6 +25,7 @@ #include +#include #include #include #include @@ -109,18 +110,29 @@ bool SMESHGUI_MeshOp::onApply() bool aResult = false; aMess = ""; - if ( myToCreate && myIsMesh ) - aResult = createMesh( aMess ); - if ( myToCreate && !myIsMesh ) - aResult = createSubMesh( aMess ); - else if ( !myToCreate ) - aResult = editMeshOrSubMesh( aMess ); + try + { + if ( myToCreate && myIsMesh ) + aResult = createMesh( aMess ); + if ( myToCreate && !myIsMesh ) + aResult = createSubMesh( aMess ); + else if ( !myToCreate ) + aResult = editMeshOrSubMesh( aMess ); + if ( aResult ) + update( UF_ObjBrowser | UF_Model ); + } + catch ( const SALOME::SALOME_Exception& S_ex ) + { + SalomeApp_Tools::QtCatchCorbaException( S_ex ); + aResult = false; + } + catch ( ... ) + { + aResult = false; + } if ( aResult ) { - update( UF_ObjBrowser | UF_Model ); - - // set default name if necessary if ( myToCreate ) setDefaultName(); } @@ -229,20 +241,30 @@ void SMESHGUI_MeshOp::selectionDone() if ( !myToCreate ) { - QString anObjEntry = myDlg->selectedObject( SMESHGUI_MeshDlg::Obj ); - _PTR(SObject) pObj = studyDS()->FindObjectID( anObjEntry ); - if ( pObj != 0 ) + try + { + QString anObjEntry = myDlg->selectedObject( SMESHGUI_MeshDlg::Obj ); + _PTR(SObject) pObj = studyDS()->FindObjectID( anObjEntry ); + if ( pObj != 0 ) + { + SMESH::SMESH_subMesh_var aVar = + SMESH::SMESH_subMesh::_narrow( _CAST( SObject,pObj )->GetObject() ); + myDlg->setObjectShown( SMESHGUI_MeshDlg::Mesh, !aVar->_is_nil() ); + myDlg->objectWg( SMESHGUI_MeshDlg::Mesh, SMESHGUI_MeshDlg::Btn )->hide(); + myDlg->updateGeometry(); + myDlg->adjustSize(); + readMesh(); + } + else + myDlg->reset(); + } + catch ( const SALOME::SALOME_Exception& S_ex ) + { + SalomeApp_Tools::QtCatchCorbaException( S_ex ); + } + catch ( ... ) { - SMESH::SMESH_subMesh_var aVar = - SMESH::SMESH_subMesh::_narrow( _CAST( SObject,pObj )->GetObject() ); - myDlg->setObjectShown( SMESHGUI_MeshDlg::Mesh, !aVar->_is_nil() ); - myDlg->objectWg( SMESHGUI_MeshDlg::Mesh, SMESHGUI_MeshDlg::Btn )->hide(); - myDlg->updateGeometry(); - myDlg->adjustSize(); - readMesh(); } - else - myDlg->reset(); } } @@ -783,18 +805,21 @@ void SMESHGUI_MeshOp::readMesh() { // get algorithm QStringList anExisting; - existingHyps( dim, Algo, pObj, anExisting, myObjHyps[ dim ][ Algo ] ); - SMESH::SMESH_Hypothesis_var aVar = myObjHyps[ dim ][ Algo ].first(); - QString aHypTypeName = aVar->GetName(); - int aHypIndex = -1; - QStringList aHypTypeNameList = SMESH::GetAvailableHypotheses( true , dim, false ); - for ( int i = 0, n = aHypTypeNameList.count(); i < n; i++ ) - if ( aHypTypeName == aHypTypeNameList[ i ] ) - { - aHypIndex = i; - break; - } + existingHyps( dim, Algo, pObj, anExisting, myObjHyps[ dim ][ Algo ] ); + if ( myObjHyps[ dim ][ Algo ].count() > 0 ) + { + SMESH::SMESH_Hypothesis_var aVar = myObjHyps[ dim ][ Algo ].first(); + QString aHypTypeName = aVar->GetName(); + + QStringList aHypTypeNameList = SMESH::GetAvailableHypotheses( true , dim, false ); + for ( int i = 0, n = aHypTypeNameList.count(); i < n; i++ ) + if ( aHypTypeName == aHypTypeNameList[ i ] ) + { + aHypIndex = i; + break; + } + } setCurrentHyp( dim, Algo, aHypIndex ); // get hypotheses