1 // Copyright (C) 2006-2008 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.
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
19 #include "EditionForEachLoop.hxx"
20 #include "FormEachLoop.hxx"
23 #include "YacsTrace.hxx"
31 using namespace YACS::HMI;
33 EditionForEachLoop::EditionForEachLoop(Subject* subject,
36 : EditionNode(subject, parent, name)
38 _formEachLoop = new FormEachLoop(this);
39 _wid->gridLayout1->addWidget(_formEachLoop);
40 _formEachLoop->sb_nbranch->setMinimum(1);
41 _formEachLoop->sb_nbranch->setMaximum(INT_MAX);
42 connect(_formEachLoop->sb_nbranch, SIGNAL(valueChanged(const QString &)),
43 this, SLOT(onModifyNbBranches(const QString &)));
46 EditionForEachLoop::~EditionForEachLoop()
50 void EditionForEachLoop::onModifyNbBranches(const QString &text)
52 SubjectForEachLoop *sfe = dynamic_cast<SubjectForEachLoop*>(_subject);
54 sfe->setNbBranches(text.toStdString());
57 void EditionForEachLoop::synchronize()
59 _subject->update(SETVALUE, 0, _subject);
62 void EditionForEachLoop::update(GuiEvent event, int type, Subject* son)
64 DEBTRACE("EditionForEachLoop::update " << eventName(event) << " " << type);
65 EditionNode::update(event, type, son);
69 SubjectComposedNode * scn = dynamic_cast<SubjectComposedNode*>(_subject);
70 string val = scn->getValue();
71 istringstream ss(val);
76 _formEachLoop->sb_nbranch->setValue(i);