mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-25 04:50:33 +05:00
22261: EDF 2698 SMESH: Memory leak when displaying 2D quadratic elements as arcs
Fix leaks of CORBA objects
This commit is contained in:
parent
a9dca097e6
commit
84eccf2fcf
@ -62,6 +62,7 @@
|
|||||||
#include <OSD.hxx>
|
#include <OSD.hxx>
|
||||||
|
|
||||||
#include <SALOMEDS_Tool.hxx>
|
#include <SALOMEDS_Tool.hxx>
|
||||||
|
#include <SALOMEDS_wrap.hxx>
|
||||||
|
|
||||||
//============================================================================
|
//============================================================================
|
||||||
// function : GEOM_Gen_i()
|
// function : GEOM_Gen_i()
|
||||||
@ -574,25 +575,27 @@ CORBA::Boolean GEOM_Gen_i::Load(SALOMEDS::SComponent_ptr theComponent,
|
|||||||
|
|
||||||
// Prepare a file name to open
|
// Prepare a file name to open
|
||||||
TCollection_AsciiString aNameWithExt("");
|
TCollection_AsciiString aNameWithExt("");
|
||||||
if (isMultiFile)
|
SALOMEDS::Study_var study = theComponent->GetStudy();
|
||||||
aNameWithExt = TCollection_AsciiString((char*)(SALOMEDS_Tool::GetNameFromPath
|
if (isMultiFile) {
|
||||||
(theComponent->GetStudy()->URL())).c_str());
|
CORBA::String_var url = study->URL();
|
||||||
aNameWithExt += TCollection_AsciiString("_GEOM.sgd");
|
aNameWithExt = (char*)SALOMEDS_Tool::GetNameFromPath(url.in()).c_str();
|
||||||
|
}
|
||||||
|
aNameWithExt += "_GEOM.sgd";
|
||||||
TCollection_AsciiString aFullName = (TCollection_AsciiString((char*)aTmpDir.c_str()) + aNameWithExt);
|
TCollection_AsciiString aFullName = (TCollection_AsciiString((char*)aTmpDir.c_str()) + aNameWithExt);
|
||||||
|
|
||||||
// Open document
|
// Open document
|
||||||
if (!_impl->Load(theComponent->GetStudy()->StudyId(),(char*) aFullName.ToCString())) return false;
|
if (!_impl->Load(study->StudyId(),(char*) aFullName.ToCString())) return false;
|
||||||
|
|
||||||
// Remove the created file and tmp directory
|
// Remove the created file and tmp directory
|
||||||
if (!isMultiFile) SALOMEDS_Tool::RemoveTemporaryFiles(aTmpDir.c_str(), aSeq.in(), true);
|
if (!isMultiFile) SALOMEDS_Tool::RemoveTemporaryFiles(aTmpDir.c_str(), aSeq.in(), true);
|
||||||
|
|
||||||
// creation of tree nodes for all data objects in the study
|
// creation of tree nodes for all data objects in the study
|
||||||
// to support tree representation customization and drag-n-drop:
|
// to support tree representation customization and drag-n-drop:
|
||||||
SALOMEDS::UseCaseBuilder_var useCaseBuilder = theComponent->GetStudy()->GetUseCaseBuilder();
|
SALOMEDS::UseCaseBuilder_wrap useCaseBuilder = study->GetUseCaseBuilder();
|
||||||
if ( !useCaseBuilder->IsUseCaseNode( theComponent ) ) {
|
if ( !useCaseBuilder->IsUseCaseNode( theComponent ) ) {
|
||||||
useCaseBuilder->SetRootCurrent();
|
useCaseBuilder->SetRootCurrent();
|
||||||
useCaseBuilder->Append( theComponent ); // component object is added as the top level item
|
useCaseBuilder->Append( theComponent ); // component object is added as the top level item
|
||||||
SALOMEDS::ChildIterator_var it = theComponent->GetStudy()->NewChildIterator( theComponent );
|
SALOMEDS::ChildIterator_wrap it = study->NewChildIterator( theComponent );
|
||||||
for (it->InitEx(true); it->More(); it->Next()) {
|
for (it->InitEx(true); it->More(); it->Next()) {
|
||||||
useCaseBuilder->AppendTo( it->Value()->GetFather(), it->Value() );
|
useCaseBuilder->AppendTo( it->Value()->GetFather(), it->Value() );
|
||||||
}
|
}
|
||||||
@ -756,10 +759,9 @@ SALOMEDS::SObject_ptr GEOM_Gen_i::AddInStudy (SALOMEDS::Study_ptr theStudy,
|
|||||||
|
|
||||||
if(!theFather->_is_nil()) {
|
if(!theFather->_is_nil()) {
|
||||||
IOR = _orb->object_to_string(theFather);
|
IOR = _orb->object_to_string(theFather);
|
||||||
SALOMEDS::SObject_var aFatherSO = theStudy->FindObjectIOR(IOR.in());
|
SALOMEDS::SObject_wrap aFatherSO = theStudy->FindObjectIOR(IOR.in());
|
||||||
if(aFatherSO->_is_nil()) return aResultSO._retn();
|
if(aFatherSO->_is_nil()) return aResultSO._retn();
|
||||||
aResultSO = aStudyBuilder->NewObject(aFatherSO);
|
aResultSO = aStudyBuilder->NewObject(aFatherSO);
|
||||||
aFatherSO->UnRegister();
|
|
||||||
//aStudyBuilder->Addreference(aResultSO, aResultSO);
|
//aStudyBuilder->Addreference(aResultSO, aResultSO);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -776,15 +778,13 @@ SALOMEDS::SObject_ptr GEOM_Gen_i::AddInStudy (SALOMEDS::Study_ptr theStudy,
|
|||||||
GEOM::GEOM_Object_var anObject = aList[i];
|
GEOM::GEOM_Object_var anObject = aList[i];
|
||||||
if(anObject->_is_nil()) continue;
|
if(anObject->_is_nil()) continue;
|
||||||
IOR = _orb->object_to_string(anObject);
|
IOR = _orb->object_to_string(anObject);
|
||||||
SALOMEDS::SObject_var aSO = theStudy->FindObjectIOR(IOR.in());
|
SALOMEDS::SObject_wrap aSO = theStudy->FindObjectIOR(IOR.in());
|
||||||
if(aSO->_is_nil()) continue;
|
if(aSO->_is_nil()) continue;
|
||||||
CORBA::String_var anID = aSO->GetID();
|
CORBA::String_var anID = aSO->GetID();
|
||||||
if ( aPrevID == anID.in() ) continue;
|
if ( aPrevID == anID.in() ) continue;
|
||||||
aPrevID = anID.in();
|
aPrevID = anID.in();
|
||||||
SALOMEDS::SObject_var aSubSO = aStudyBuilder->NewObject(aResultSO);
|
SALOMEDS::SObject_wrap aSubSO = aStudyBuilder->NewObject(aResultSO);
|
||||||
aStudyBuilder->Addreference(aSubSO, aSO);
|
aStudyBuilder->Addreference(aSubSO, aSO);
|
||||||
aSO->UnRegister();
|
|
||||||
aSubSO->UnRegister();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return aResultSO._retn();
|
return aResultSO._retn();
|
||||||
|
Loading…
Reference in New Issue
Block a user