1 // Copyright (C) 2006-2014 CEA/DEN, EDF R&D
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License, or (at your option) any later version.
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 // Lesser General Public License for more details.
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
20 #include "EditionOptimizerLoop.hxx"
21 #include "FormOptimizerLoop.hxx"
23 #include "OptimizerLoop.hxx"
24 #include "TypeCode.hxx"
25 #include "QtGuiContext.hxx"
26 #include "Message.hxx"
29 #include "YacsTrace.hxx"
36 using namespace YACS::HMI;
37 using namespace YACS::ENGINE;
39 EditionOptimizerLoop::EditionOptimizerLoop(Subject* subject,
42 : EditionNode(subject, parent, name)
44 _formOptimizerLoop = new FormOptimizerLoop(this);
46 _wid->gridLayout1->addWidget(_formOptimizerLoop);
47 _formOptimizerLoop->sb_nbranch->setMinimum(1);
48 _formOptimizerLoop->sb_nbranch->setMaximum(INT_MAX);
50 connect(_formOptimizerLoop->sb_nbranch, SIGNAL(editingFinished()),
51 this, SLOT(onNbBranchesEdited()));
52 connect(_formOptimizerLoop->lineEdit_initValue, SIGNAL(editingFinished()),
53 this, SLOT(onModifyInitFile()));
54 connect(_formOptimizerLoop->lineEdit_entry, SIGNAL(editingFinished()),
55 this, SLOT(onModifyEntry()));
56 connect(_formOptimizerLoop->lineEdit_lib, SIGNAL(editingFinished()),
57 this, SLOT(onModifyLib()));
60 EditionOptimizerLoop::~EditionOptimizerLoop()
64 void EditionOptimizerLoop::onModifyInitFile()
67 Node* node=_subjectNode->getNode();
68 OptimizerLoop *ol = dynamic_cast<OptimizerLoop*>(node);
69 InputPort * dp = ol->edGetAlgoInitPort();
70 SubjectDataPort* sdp = QtGuiContext::getQtCurrent()->_mapOfSubjectDataPort[dp];
71 isOk=sdp->setValue(_formOptimizerLoop->lineEdit_initValue->text().toStdString());
75 void EditionOptimizerLoop::onModifyEntry()
77 DEBTRACE("EditionOptimizerLoop::onModifyEntry");
78 OptimizerLoop *oloop = dynamic_cast<OptimizerLoop*>(_subjectNode->getNode());
79 if (oloop->getSymbol() == _formOptimizerLoop->lineEdit_entry->text().toStdString()) return;
82 SubjectOptimizerLoop *ol = dynamic_cast<SubjectOptimizerLoop*>(_subjectNode);
83 isOk=ol->setAlgorithm(_formOptimizerLoop->lineEdit_lib->text().toStdString(),
84 _formOptimizerLoop->lineEdit_entry->text().toStdString());
90 void EditionOptimizerLoop::onModifyLib()
92 DEBTRACE("EditionOptimizerLoop::onModifyLib");
93 OptimizerLoop *oloop = dynamic_cast<OptimizerLoop*>(_subjectNode->getNode());
94 if(oloop->getAlgLib() == _formOptimizerLoop->lineEdit_lib->text().toStdString()) return;
97 SubjectOptimizerLoop *ol = dynamic_cast<SubjectOptimizerLoop*>(_subjectNode);
98 isOk=ol->setAlgorithm(_formOptimizerLoop->lineEdit_lib->text().toStdString(),
99 _formOptimizerLoop->lineEdit_entry->text().toStdString());
100 if (!isOk && !_formOptimizerLoop->lineEdit_lib->text().isEmpty() &&
101 !_formOptimizerLoop->lineEdit_entry->text().isEmpty())
106 void EditionOptimizerLoop::onNbBranchesEdited()
108 int newval = _formOptimizerLoop->sb_nbranch->value();
109 DEBTRACE("EditionOptimizerLoop::onNbBranchesEdited " << _nbBranches << " --> " << newval);
110 if (newval != _nbBranches)
112 SubjectOptimizerLoop *sol = dynamic_cast<SubjectOptimizerLoop*>(_subject);
114 QString text = _formOptimizerLoop->sb_nbranch->cleanText();
115 sol->setNbBranches(text.toStdString());
119 void EditionOptimizerLoop::synchronize()
121 _subject->update(SETVALUE, 0, _subject);
124 void EditionOptimizerLoop::update(GuiEvent event, int type, Subject* son)
126 DEBTRACE("EditionOptimizerLoop::update " << eventName(event) << " " << type);
127 EditionNode::update(event, type, son);
132 SubjectComposedNode * scn = dynamic_cast<SubjectComposedNode*>(_subject);
133 string val = scn->getValue();
134 istringstream ss(val);
139 _formOptimizerLoop->sb_nbranch->setValue(i);
142 OptimizerLoop * ol = dynamic_cast<OptimizerLoop *>(_subjectNode->getNode());
145 InputPort * dp = ol->edGetAlgoInitPort();
146 _formOptimizerLoop->lineEdit_initValue->setText(dp->getAsString().c_str());
148 // Algo library and entry
149 _formOptimizerLoop->lineEdit_entry->setText(QString::fromStdString(ol->getSymbol()));
150 _formOptimizerLoop->lineEdit_lib->setText(QString::fromStdString(ol->getAlgLib()));
153 _formOptimizerLoop->label_evalSampleType->setText(ol->edGetSamplePort()->edGetType()->name());
154 _formOptimizerLoop->label_evalResultType->setText(ol->edGetPortForOutPool()->edGetType()->name());
155 _formOptimizerLoop->label_algoInitType->setText(ol->edGetAlgoInitPort()->edGetType()->name());
156 _formOptimizerLoop->label_algoResultType->setText(ol->edGetAlgoResultPort()->edGetType()->name());