]> SALOME platform Git repositories - modules/smesh.git/commitdiff
Salome HOME
PAL10491. Add GetMessageOnAlgoStateErrors()
authoreap <eap@opencascade.com>
Mon, 14 Nov 2005 09:17:11 +0000 (09:17 +0000)
committereap <eap@opencascade.com>
Mon, 14 Nov 2005 09:17:11 +0000 (09:17 +0000)
src/SMESHGUI/SMESHGUI_HypothesesUtils.cxx
src/SMESHGUI/SMESHGUI_HypothesesUtils.h

index 585562c8f233c43684c698be5372c5c77d2e126c..68d15b79bd3878fac173c80b4c26e617156fa742 100644 (file)
@@ -549,4 +549,33 @@ namespace SMESH{
     if (MYDEBUG) MESSAGE("SMESHGUI::GetMeshesUsingAlgoOrHypothesis(): completed");
     return listSOmesh;
   }
+
+#define CASE2MESSAGE(enum) case SMESH::enum: msg = QObject::tr( #enum ); break;
+  QString GetMessageOnAlgoStateErrors(const algo_error_array& errors)
+  {
+    QString resMsg = QObject::tr("SMESH_WRN_MISSING_PARAMETERS") + ":\n";
+    for ( int i = 0; i < errors.length(); ++i ) {
+      const SMESH::AlgoStateError & error = errors[ i ];
+      QString msg;
+      switch( error.name ) {
+        CASE2MESSAGE( MISSING_ALGO );
+        CASE2MESSAGE( MISSING_HYPO );
+        CASE2MESSAGE( NOT_CONFORM_MESH );
+      default: continue;
+      }
+      // apply args to message:
+      // %1 - algo name
+      if ( error.algoName.in() != 0 )
+        msg = msg.arg( error.algoName.in() );
+      // %2 - dimention
+      msg = msg.arg( error.algoDim );
+      // %3 - global/local
+      msg = msg.arg( QObject::tr( error.isGlobalAlgo ? "GLOBAL_ALGO" : "LOCAL_ALGO" ));
+
+      if ( i ) resMsg += ";\n";
+      resMsg += msg;
+    }
+    return resMsg;
+  }
+
 }
index a3b93265772ece809f773ae9ffc7149617bd83dd..2fb920af91c60e99f87f4ee7322916b5a17685b3 100644 (file)
@@ -45,6 +45,7 @@ class HypothesisData;
 class HypothesesSet;
 class SMESHGUI_GenericHypothesisCreator;
 class SALOMEDSClient_SObject;
+class algo_error_array;
 
 namespace SMESH{
 
@@ -78,6 +79,7 @@ namespace SMESH{
   typedef std::vector<_PTR(SObject)> SObjectList;
   SObjectList GetMeshesUsingAlgoOrHypothesis(SMESH::SMESH_Hypothesis_ptr AlgoOrHyp ) ;
 
+  QString GetMessageOnAlgoStateErrors(const algo_error_array& errors);
 }
 
 #endif