Salome HOME
Revert "Merge branch 'yan/parallel_mesh2'"
[plugins/netgenplugin.git] / src / NETGENPlugin / NETGENPlugin_Hypothesis_i.cxx
1 // Copyright (C) 2007-2022  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
10 //
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 // Lesser General Public License for more details.
15 //
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
19 //
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22
23 //  NETGENPlugin : C++ implementation
24 // File      : NETGENPlugin_Hypothesis_i.cxx
25 // Author    : Michael Sazonov (OCN)
26 // Date      : 03/04/2006
27 // Project   : SALOME
28 //=============================================================================
29 //
30 #include "NETGENPlugin_Hypothesis_i.hxx"
31 #include "SMESH_Gen.hxx"
32 #include "SMESH_PythonDump.hxx"
33
34 #include "Utils_CorbaException.hxx"
35 #include "utilities.h"
36
37 using namespace std;
38
39 //=============================================================================
40 /*!
41  *  Specialization of isToSetParameter<T> for double
42  */
43 //=============================================================================
44
45 template<>
46 bool NETGENPlugin_Hypothesis_i::isToSetParameter<double>(double curValue,
47                                                          double newValue,
48                                                          /*SettingMethod*/int meth)
49 {
50   return isToSetParameter(true, (fabs(curValue - newValue) < 1e-20), meth);
51 }
52
53 //=============================================================================
54 /*!
55  *  NETGENPlugin_Hypothesis_i::NETGENPlugin_Hypothesis_i
56  *
57  *  Constructor
58  */
59 //=============================================================================
60 NETGENPlugin_Hypothesis_i::
61 NETGENPlugin_Hypothesis_i (PortableServer::POA_ptr thePOA,
62                            ::SMESH_Gen*            theGenImpl)
63   : SALOME::GenericObj_i( thePOA ), 
64     SMESH_Hypothesis_i( thePOA ),
65     mySetMethodFlags(0)
66 {
67   myBaseImpl = new ::NETGENPlugin_Hypothesis (theGenImpl->GetANewId(),
68                                               theGenImpl);
69 }
70
71 //=============================================================================
72 /*!
73  *  NETGENPlugin_Hypothesis_i::~NETGENPlugin_Hypothesis_i
74  *
75  *  Destructor
76  */
77 //=============================================================================
78 NETGENPlugin_Hypothesis_i::~NETGENPlugin_Hypothesis_i()
79 {
80 }
81
82 //=============================================================================
83 /*!
84  *  NETGENPlugin_Hypothesis_i::SetMaxSize
85  *
86  *  Set MaxSize
87  */
88 //=============================================================================
89 void NETGENPlugin_Hypothesis_i::SetMaxSize (CORBA::Double theValue)
90 {
91   if ( isToSetParameter( GetMaxSize(), theValue, METH_SetMaxSize ))
92   {
93     this->GetImpl()->SetMaxSize(theValue);
94     SMESH::TPythonDump() << _this() << ".SetMaxSize( " << SMESH::TVar(theValue) << " )";
95   }
96 }
97
98 //=============================================================================
99 /*!
100  *  NETGENPlugin_Hypothesis_i::GetMaxSize
101  *
102  *  Get MaxSize
103  */
104 //=============================================================================
105 CORBA::Double NETGENPlugin_Hypothesis_i::GetMaxSize()
106 {
107   return this->GetImpl()->GetMaxSize();
108 }
109
110 //=============================================================================
111 /*!
112  *  NETGENPlugin_Hypothesis_i::SetMinSize
113  *
114  *  Set MinSize
115  */
116 //=============================================================================
117 void NETGENPlugin_Hypothesis_i::SetMinSize (CORBA::Double theValue)
118 {
119   if ( isToSetParameter( GetMinSize(), theValue, METH_SetMinSize ))
120   {
121     this->GetImpl()->SetMinSize(theValue);
122     SMESH::TPythonDump() << _this() << ".SetMinSize( " << SMESH::TVar(theValue) << " )";
123   }
124 }
125
126 //=============================================================================
127 /*!
128  *  NETGENPlugin_Hypothesis_i::GetMinSize
129  *
130  *  Get MinSize
131  */
132 //=============================================================================
133 CORBA::Double NETGENPlugin_Hypothesis_i::GetMinSize()
134 {
135   return this->GetImpl()->GetMinSize();
136 }
137
138 //=============================================================================
139 /*!
140  *  NETGENPlugin_Hypothesis_i::SetSecondOrder
141  *
142  *  Set SecondOrder flag
143  */
144 //=============================================================================
145 void NETGENPlugin_Hypothesis_i::SetSecondOrder (CORBA::Boolean theValue)
146 {
147   if ( isToSetParameter( GetSecondOrder(), theValue, METH_SetSecondOrder ))
148   {
149     this->GetImpl()->SetSecondOrder(theValue);
150     SMESH::TPythonDump() << _this() << ".SetSecondOrder( " << theValue << " )";
151   }
152 }
153
154 //=============================================================================
155 /*!
156  *  NETGENPlugin_Hypothesis_i::GetSecondOrder
157  *
158  *  Get SecondOrder flag
159  */
160 //=============================================================================
161 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetSecondOrder()
162 {
163   return this->GetImpl()->GetSecondOrder();
164 }
165
166 //=============================================================================
167 /*!
168  *  NETGENPlugin_Hypothesis_i::SetOptimize
169  *
170  *  Set Optimize flag
171  */
172 //=============================================================================
173 void NETGENPlugin_Hypothesis_i::SetOptimize (CORBA::Boolean theValue)
174 {
175   if ( isToSetParameter( GetOptimize(), theValue, METH_SetOptimize ))
176   {
177     this->GetImpl()->SetOptimize(theValue);
178     SMESH::TPythonDump() << _this() << ".SetOptimize( " << theValue << " )";
179   }
180 }
181
182 //=============================================================================
183 /*!
184  *  NETGENPlugin_Hypothesis_i::GetOptimize
185  *
186  *  Get Optimize flag
187  */
188 //=============================================================================
189 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetOptimize()
190 {
191   return this->GetImpl()->GetOptimize();
192 }
193
194 //=============================================================================
195 /*!
196  *  NETGENPlugin_Hypothesis_i::SetFineness
197  *
198  *  Set Fineness
199  */
200 //=============================================================================
201 void NETGENPlugin_Hypothesis_i::SetFineness (CORBA::Long theValue)
202 {
203   if ( isToSetParameter( GetFineness(), theValue, METH_SetFineness ))
204   {
205     this->GetImpl()->SetFineness((::NETGENPlugin_Hypothesis::Fineness)theValue);
206     SMESH::TPythonDump() << _this() << ".SetFineness( " << theValue << " )";
207   }
208 }
209
210 //=============================================================================
211 /*!
212  *  NETGENPlugin_Hypothesis_i::GetFineness
213  *
214  *  Get Fineness
215  */
216 //=============================================================================
217 CORBA::Long NETGENPlugin_Hypothesis_i::GetFineness()
218 {
219   return this->GetImpl()->GetFineness();
220 }
221
222 //=============================================================================
223 /*!
224  *  NETGENPlugin_Hypothesis_i::SetGrowthRate
225  *
226  *  Set GrowthRate
227  */
228 //=============================================================================
229 void NETGENPlugin_Hypothesis_i::SetGrowthRate (CORBA::Double theValue)
230 {
231   if ( isToSetParameter( GetGrowthRate(), theValue, METH_SetGrowthRate ))
232   {
233     this->GetImpl()->SetGrowthRate(theValue);
234     SMESH::TPythonDump() << _this() << ".SetGrowthRate( " << SMESH::TVar(theValue) << " )";
235   }
236 }
237
238 //=============================================================================
239 /*!
240  *  NETGENPlugin_Hypothesis_i::GetGrowthRate
241  *
242  *  Get GrowthRate
243  */
244 //=============================================================================
245 CORBA::Double NETGENPlugin_Hypothesis_i::GetGrowthRate()
246 {
247   return this->GetImpl()->GetGrowthRate();
248 }
249
250 //=============================================================================
251 /*!
252  *  NETGENPlugin_Hypothesis_i::SetNbSegPerEdge
253  *
254  *  Set NbSegPerEdge
255  */
256 //=============================================================================
257 void NETGENPlugin_Hypothesis_i::SetNbSegPerEdge (CORBA::Double theValue)
258 {
259   if ( isToSetParameter( GetNbSegPerEdge(), theValue, METH_SetNbSegPerEdge ))
260   {
261     this->GetImpl()->SetNbSegPerEdge(theValue);
262     SMESH::TPythonDump() << _this() << ".SetNbSegPerEdge( " << SMESH::TVar(theValue) << " )";
263   }
264 }
265
266 //=============================================================================
267 /*!
268  *  NETGENPlugin_Hypothesis_i::GetNbSegPerEdge
269  *
270  *  Get NbSegPerEdge
271  */
272 //=============================================================================
273 CORBA::Double NETGENPlugin_Hypothesis_i::GetNbSegPerEdge()
274 {
275   return this->GetImpl()->GetNbSegPerEdge();
276 }
277
278 //=============================================================================
279 /*!
280  *  NETGENPlugin_Hypothesis_i::SetNbSegPerRadius
281  *
282  *  Set NbSegPerRadius
283  */
284 //=============================================================================
285 void NETGENPlugin_Hypothesis_i::SetNbSegPerRadius (CORBA::Double theValue)
286 {
287   if ( isToSetParameter( GetNbSegPerRadius(), theValue, METH_SetNbSegPerRadius ))
288   {
289     this->GetImpl()->SetNbSegPerRadius(theValue);
290     SMESH::TPythonDump() << _this() << ".SetNbSegPerRadius( " << SMESH::TVar(theValue) << " )";
291   }
292 }
293
294 //=============================================================================
295 /*!
296  *  NETGENPlugin_Hypothesis_i::GetNbSegPerRadius
297  *
298  *  Get NbSegPerRadius
299  */
300 //=============================================================================
301 CORBA::Double NETGENPlugin_Hypothesis_i::GetNbSegPerRadius()
302 {
303   return this->GetImpl()->GetNbSegPerRadius();
304 }
305
306 //=============================================================================
307
308 void NETGENPlugin_Hypothesis_i::SetChordalErrorEnabled(CORBA::Boolean theValue)
309 {
310   if ( isToSetParameter( GetChordalErrorEnabled(), theValue, METH_SetChordalErrorEnabled ))
311   {
312     this->GetImpl()->SetChordalErrorEnabled(theValue);
313     SMESH::TPythonDump() << _this() << ".SetChordalErrorEnabled( " << theValue << " )";
314   }
315 }
316
317 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetChordalErrorEnabled()
318 {
319   return GetImpl()->GetChordalErrorEnabled();
320 }
321
322 void NETGENPlugin_Hypothesis_i::SetChordalError(CORBA::Double theValue)
323 {
324   if ( isToSetParameter( GetChordalError(), theValue, METH_SetChordalError ))
325   {
326     this->GetImpl()->SetChordalError(theValue);
327     SMESH::TPythonDump() << _this() << ".SetChordalError( " << SMESH::TVar(theValue) << " )";
328   }
329 }
330
331 CORBA::Double NETGENPlugin_Hypothesis_i::GetChordalError()
332 {
333   return GetImpl()->GetChordalError();
334 }
335
336 //=============================================================================
337
338 void NETGENPlugin_Hypothesis_i::SetLocalSizeOnShape(GEOM::GEOM_Object_ptr GeomObj,
339                                                     CORBA::Double         localSize)
340 {
341   string entry;
342   entry = GeomObj->GetStudyEntry();
343   if ( entry.empty() )
344     THROW_SALOME_CORBA_EXCEPTION( "SetLocalSizeOnShape(), shape is not published in study!",
345                                   SALOME::BAD_PARAM );
346   SetLocalSizeOnEntry(entry.c_str(), localSize);
347 }
348
349 //=============================================================================
350
351 void NETGENPlugin_Hypothesis_i::SetLocalSizeOnEntry(const char*   entry,
352                                                     CORBA::Double localSize)
353 {
354   if ( isToSetParameter( GetLocalSizeOnEntry(entry), localSize, METH_SetLocalSizeOnEntry ))
355   {
356     this->GetImpl()->SetLocalSizeOnEntry(entry, localSize);
357     SMESH::TPythonDump()
358       << _this() << ".SetLocalSizeOnShape(" << entry << ", " << localSize << ")";
359   }
360 }
361
362 //=============================================================================
363
364 CORBA::Double NETGENPlugin_Hypothesis_i::GetLocalSizeOnEntry(const char* entry)
365 {
366   return this->GetImpl()->GetLocalSizeOnEntry(entry);
367 }
368
369 //=============================================================================
370
371 NETGENPlugin::string_array* NETGENPlugin_Hypothesis_i::GetLocalSizeEntries()
372 {
373   NETGENPlugin::string_array_var result = new NETGENPlugin::string_array();
374   const ::NETGENPlugin_Hypothesis::TLocalSize localSizes =
375     this->GetImpl()->GetLocalSizesAndEntries();
376   result->length((CORBA::ULong) localSizes.size());
377   ::NETGENPlugin_Hypothesis::TLocalSize::const_iterator it = localSizes.begin();
378   for (int i=0 ; it != localSizes.end() ; i++, it++)
379     {
380       string entry = (*it).first;
381       result[i] = CORBA::string_dup(entry.c_str());
382     }
383   return result._retn();
384 }
385
386 //=============================================================================
387
388 void NETGENPlugin_Hypothesis_i::UnsetLocalSizeOnEntry(const char* entry)
389 {
390   this->GetImpl()->UnsetLocalSizeOnEntry(entry);
391   SMESH::TPythonDump() << _this() << ".UnsetLocalSizeOnEntry(\"" << entry << "\")";
392 }
393
394 //=============================================================================
395
396 void NETGENPlugin_Hypothesis_i::SetMeshSizeFile(const char* fileName)
397 {
398   if ( GetImpl()->GetMeshSizeFile() != fileName )
399   {
400     GetImpl()->SetMeshSizeFile( fileName );
401     SMESH::TPythonDump() << _this() << ".SetMeshSizeFile( '" << fileName << "' )";
402   }
403 }
404
405 //=============================================================================
406
407 char* NETGENPlugin_Hypothesis_i::GetMeshSizeFile()
408 {
409   return CORBA::string_dup( GetImpl()->GetMeshSizeFile().c_str() );
410 }
411
412 //=============================================================================
413
414 void NETGENPlugin_Hypothesis_i::SetQuadAllowed (CORBA::Boolean theValue)
415 {
416   if ( NETGENPlugin_Hypothesis_i::isToSetParameter( GetQuadAllowed(),
417                                                     theValue,
418                                                     METH_SetQuadAllowed ))
419   {
420     this->GetImpl()->SetQuadAllowed(theValue);
421     SMESH::TPythonDump() << _this() << ".SetQuadAllowed( " << theValue << " )";
422   }
423 }
424
425 //=============================================================================
426
427 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetQuadAllowed()
428 {
429   return this->GetImpl()->GetQuadAllowed();
430 }
431
432 //=============================================================================
433
434 void NETGENPlugin_Hypothesis_i::SetUseSurfaceCurvature (CORBA::Boolean theValue)
435 {
436   if ( NETGENPlugin_Hypothesis_i::isToSetParameter( GetUseSurfaceCurvature(),
437                                                     theValue,
438                                                     METH_SetSurfaceCurvature ))
439   {
440     this->GetImpl()->SetSurfaceCurvature(theValue);
441     SMESH::TPythonDump() << _this() << ".SetUseSurfaceCurvature( " << theValue << " )";
442   }
443 }
444
445 //=============================================================================
446
447 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetUseSurfaceCurvature()
448 {
449   return this->GetImpl()->GetSurfaceCurvature();
450 }
451
452 //=============================================================================
453
454 void NETGENPlugin_Hypothesis_i::SetFuseEdges (CORBA::Boolean theValue)
455 {
456   if ( NETGENPlugin_Hypothesis_i::isToSetParameter( GetFuseEdges(),
457                                                     theValue,
458                                                     METH_SetFuseEdges ))
459   {
460     this->GetImpl()->SetFuseEdges(theValue);
461     SMESH::TPythonDump() << _this() << ".SetFuseEdges( " << theValue << " )";
462   }
463 }
464
465 //=============================================================================
466
467 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetFuseEdges()
468 {
469   return this->GetImpl()->GetFuseEdges();
470 }
471
472 //=======================================================================
473 //function : SetNbSurfOptSteps
474 //purpose  : 
475 //=======================================================================
476
477 void NETGENPlugin_Hypothesis_i::SetNbSurfOptSteps(CORBA::Short nb )
478 {
479   if ( GetNbSurfOptSteps() != nb )
480   {
481     this->GetImpl()->SetNbSurfOptSteps( nb );
482     SMESH::TPythonDump() << _this() << ".SetNbSurfOptSteps( " << SMESH::TVar(nb) << " )";
483   }
484 }
485
486 //=======================================================================
487 //function : GetNbSurfOptSteps
488 //purpose  :
489 //=======================================================================
490
491 CORBA::Short NETGENPlugin_Hypothesis_i::GetNbSurfOptSteps()
492 {
493   return (CORBA::Short) GetImpl()->GetNbSurfOptSteps();
494 }
495
496 //=======================================================================
497 //function : SetNbVolOptSteps
498 //purpose  : 
499 //=======================================================================
500
501 void NETGENPlugin_Hypothesis_i::SetNbVolOptSteps(CORBA::Short nb )
502 {
503   if ( GetNbVolOptSteps() != nb )
504   {
505     this->GetImpl()->SetNbVolOptSteps( nb );
506     SMESH::TPythonDump() << _this() << ".SetNbVolOptSteps( " << SMESH::TVar(nb) << " )";
507   }
508
509 }
510
511 //=======================================================================
512 //function : GetNbVolOptSteps
513 //purpose  :
514 //=======================================================================
515
516 CORBA::Short NETGENPlugin_Hypothesis_i::GetNbVolOptSteps()
517 {
518   return (CORBA::Short) GetImpl()->GetNbVolOptSteps();
519 }
520
521 //=======================================================================
522 //function : SetElemSizeWeight
523 //purpose  : 
524 //=======================================================================
525
526 void NETGENPlugin_Hypothesis_i::SetElemSizeWeight(CORBA::Double size )
527 {
528   if ( GetElemSizeWeight() != size )
529   {
530     this->GetImpl()->SetElemSizeWeight( size );
531     SMESH::TPythonDump() << _this() << ".SetElemSizeWeight( " << SMESH::TVar(size) << " )";
532   }
533 }
534
535 //=======================================================================
536 //function : GetElemSizeWeight
537 //purpose  :
538 //=======================================================================
539
540 CORBA::Double NETGENPlugin_Hypothesis_i::GetElemSizeWeight()
541 {
542   return GetImpl()->GetElemSizeWeight();
543 }
544
545 //=======================================================================
546 //function : SetWorstElemMeasure
547 //purpose  : 
548 //=======================================================================
549
550 void NETGENPlugin_Hypothesis_i::SetWorstElemMeasure(CORBA::Short val )
551 {
552   if ( GetWorstElemMeasure() != val )
553   {
554     this->GetImpl()->SetWorstElemMeasure( val );
555     SMESH::TPythonDump() << _this() << ".SetWorstElemMeasure( " << SMESH::TVar(val) << " )";
556   }
557 }
558
559 //=======================================================================
560 //function : GetWorstElemMeasure
561 //purpose  : 
562 //=======================================================================
563
564 CORBA::Short NETGENPlugin_Hypothesis_i::GetWorstElemMeasure()
565 {
566   return (CORBA::Short) GetImpl()->GetWorstElemMeasure();
567 }
568
569 //=======================================================================
570 //function : SetUseDelauney
571 //purpose  : 
572 //=======================================================================
573
574 void NETGENPlugin_Hypothesis_i::SetUseDelauney(CORBA::Boolean toUse)
575 {
576   if ( GetUseDelauney() != toUse )
577   {
578     this->GetImpl()->SetUseDelauney( toUse );
579     SMESH::TPythonDump() << _this() << ".SetUseDelauney( " << toUse << " )";
580   }
581 }
582
583 //=======================================================================
584 //function : GetUseDelauney
585 //purpose  : 
586 //=======================================================================
587
588 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetUseDelauney()
589 {
590   return GetImpl()->GetUseDelauney();
591 }
592
593 //=======================================================================
594 //function : SetCheckOverlapping
595 //purpose  : 
596 //=======================================================================
597
598 void NETGENPlugin_Hypothesis_i::SetCheckOverlapping(CORBA::Boolean toCheck )
599 {
600   if ( GetCheckOverlapping() != toCheck )
601   {
602     this->GetImpl()->SetCheckOverlapping( toCheck );
603     SMESH::TPythonDump() << _this() << ".SetCheckOverlapping( " << toCheck << " )";
604   }
605 }
606
607 //=======================================================================
608 //function : GetCheckOverlapping
609 //purpose  : 
610 //=======================================================================
611
612 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetCheckOverlapping()
613 {
614   return GetImpl()->GetCheckOverlapping();
615 }
616
617 //=======================================================================
618 //function : SetCheckChartBoundary
619 //purpose  : 
620 //=======================================================================
621
622 void NETGENPlugin_Hypothesis_i::SetCheckChartBoundary(CORBA::Boolean toCheck )
623 {
624   if ( GetCheckChartBoundary() != toCheck )
625   {
626     this->GetImpl()->SetCheckChartBoundary( toCheck );
627     SMESH::TPythonDump() << _this() << ".SetCheckChartBoundary( " << toCheck << " )";
628   }
629 }
630
631 //=======================================================================
632 //function : GetCheckChartBoundary
633 //purpose  : Get implementation
634 //=======================================================================
635
636 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetCheckChartBoundary()
637 {
638   return GetImpl()->GetCheckChartBoundary();
639 }
640
641 //=============================================================================
642 /*!
643  *  NETGENPlugin_Hypothesis_i::GetImpl
644  *
645  *  Get implementation
646  */
647 //=============================================================================
648 ::NETGENPlugin_Hypothesis* NETGENPlugin_Hypothesis_i::GetImpl()
649 {
650   return (::NETGENPlugin_Hypothesis*)myBaseImpl;
651 }
652
653 //================================================================================
654 /*!
655  * \brief Verify whether hypothesis supports given entity type 
656   * \param type - dimension (see SMESH::Dimension enumeration)
657   * \retval CORBA::Boolean - TRUE if dimension is supported, FALSE otherwise
658  * 
659  * Verify whether hypothesis supports given entity type (see SMESH::Dimension enumeration)
660  */
661 //================================================================================  
662 CORBA::Boolean NETGENPlugin_Hypothesis_i::IsDimSupported( SMESH::Dimension type )
663 {
664   return type == SMESH::DIM_3D;
665 }
666
667 //================================================================================
668 /*!
669  * \brief method intended to remove explicit treatment of Netgen hypotheses from SMESH_NoteBook
670  */
671 //================================================================================
672
673 int NETGENPlugin_Hypothesis_i::getParamIndex(const TCollection_AsciiString& method,
674                                              int nbVars) const
675 {
676   if ( method == "SetMaxSize"        ) return 0;
677   if ( method == "SetGrowthRate"     ) return 1;
678   if ( method == "SetNbSegPerEdge"   ) return 2;
679   if ( method == "SetNbSegPerRadius" ) return 3;
680   if ( method == "SetMinSize" )        return nbVars-1;
681
682   return SMESH_Hypothesis_i::getParamIndex( method, nbVars ); // return default value
683 }
684
685 //================================================================================
686 /*!
687  * \brief Method used to convert variable parameters stored in an old study
688  * into myMethod2VarParams. It should return a method name for an index of
689  * variable parameters. Index is countered from zero
690  */
691 //================================================================================
692
693 std::string NETGENPlugin_Hypothesis_i::getMethodOfParameter(const int paramIndex,
694                                                             int nbVars) const
695 {
696   switch ( paramIndex ) {
697   case 0: return "SetMaxSize";
698   case 1: return nbVars == 2 ? "SetMinSize" : "SetGrowthRate";
699   case 2: return "SetNbSegPerEdge";
700   case 3: return "SetNbSegPerRadius";
701   case 4: return "SetMinSize";
702   }
703   return "";
704 }
705
706 //================================================================================
707 /*!
708  * \brief Return geometry this hypothesis depends on. Return false if there is no geometry parameter
709  */
710 //================================================================================
711
712 bool
713 NETGENPlugin_Hypothesis_i::getObjectsDependOn( std::vector< std::string > & entryArray,
714                                                std::vector< int >         & /*subIDArray*/ ) const
715 {
716   typedef ::NETGENPlugin_Hypothesis THyp;
717
718   const THyp* h = static_cast< ::NETGENPlugin_Hypothesis* >( myBaseImpl );
719   const THyp::TLocalSize& ls = h->GetLocalSizesAndEntries();
720
721   THyp::TLocalSize::const_iterator entry2size = ls.cbegin();
722   for ( ; entry2size != ls.cend(); ++entry2size )
723     entryArray.push_back( entry2size->first );
724
725   return true;
726 }
727
728 //================================================================================
729 /*!
730  * \brief Set new geometry instead of that returned by getObjectsDependOn()
731  */
732 //================================================================================
733
734 bool
735 NETGENPlugin_Hypothesis_i::setObjectsDependOn( std::vector< std::string > & entryArray,
736                                                std::vector< int >         & /*subIDArray*/ )
737 {
738   typedef ::NETGENPlugin_Hypothesis THyp;
739
740   const THyp* h = static_cast< ::NETGENPlugin_Hypothesis* >( myBaseImpl );
741
742   THyp::TLocalSize& lsNew = const_cast< THyp::TLocalSize& >( h->GetLocalSizesAndEntries() );
743   THyp::TLocalSize ls;
744   lsNew.swap( ls );
745
746   THyp::TLocalSize::const_iterator entry2size = ls.cbegin();
747   for ( int i = 0; entry2size != ls.cend(); ++entry2size, ++i )
748     if ( !entryArray[ i ].empty() )
749       lsNew[ entryArray[ i ]] = entry2size->second;
750
751   return true;
752 }