// $Header$
#include "SALOMEDS_SComponentIterator_i.hxx"
-using namespace std;
+#include "SALOMEDS_SComponent_i.hxx"
+#include "SALOMEDS.hxx"
+using namespace std;
//============================================================================
/*! Function : constructor
*/
//============================================================================
-SALOMEDS_SComponentIterator_i::SALOMEDS_SComponentIterator_i(const Handle(TDocStd_Document) aDoc,
- CORBA::ORB_ptr orb)
+SALOMEDS_SComponentIterator_i::SALOMEDS_SComponentIterator_i(SALOMEDS_Study_i* theStudy,
+ const Handle(TDocStd_Document)& theDocument):
+ _it(theDocument->Main()),
+ _lab(theDocument->Main()),
+ _study(theStudy)
{
- _orb = CORBA::ORB::_duplicate(orb);
- _lab = aDoc->Main();
- _it.Initialize (_lab);
}
//============================================================================
//============================================================================
void SALOMEDS_SComponentIterator_i::Init()
{
+ SALOMEDS::Locker lock;
+
_it.Initialize (_lab);
}
//============================================================================
CORBA::Boolean SALOMEDS_SComponentIterator_i::More()
{
+ SALOMEDS::Locker lock;
+
if (!_it.More())
return false;
TDF_Label L = _it.Value();
//============================================================================
void SALOMEDS_SComponentIterator_i::Next()
{
+ SALOMEDS::Locker lock;
+
_it.Next();
}
//============================================================================
SALOMEDS::SComponent_ptr SALOMEDS_SComponentIterator_i::Value()
{
- SALOMEDS_SComponent_i * so_servant = new SALOMEDS_SComponent_i (_it.Value(),_orb);
- SALOMEDS::SComponent_var so = SALOMEDS::SComponent::_narrow(so_servant->SComponent::_this()); //pb d'heritage??
- return so;
+ SALOMEDS::Locker lock;
+
+ return SALOMEDS_SComponent_i::NewRef(_study,_it.Value())._retn();
}