22261: EDF 2698 SMESH: Memory leak when displaying 2D quadratic elements as arcs

-    aStudyName = ( (char*)SALOMEDS_Tool::GetNameFromPath( myCurrentStudy->URL() ).c_str() );
+    CORBA::String_var url = myCurrentStudy->URL();
This commit is contained in:
eap 2013-07-25 08:59:30 +00:00
parent e11c322ee9
commit b8a3fc622b

View File

@ -3957,7 +3957,7 @@ bool SMESH_Gen_i::Load( SALOMEDS::SComponent_ptr theComponent,
// Get temporary files location // Get temporary files location
TCollection_AsciiString tmpDir = TCollection_AsciiString tmpDir =
isMultiFile ? TCollection_AsciiString( ( char* )theURL ) : ( char* )SALOMEDS_Tool::GetTmpDir().c_str(); ( char* )( isMultiFile ? theURL : SALOMEDS_Tool::GetTmpDir().c_str() );
INFOS( "THE URL++++++++++++++" ); INFOS( "THE URL++++++++++++++" );
INFOS( theURL ); INFOS( theURL );
@ -3969,12 +3969,13 @@ bool SMESH_Gen_i::Load( SALOMEDS::SComponent_ptr theComponent,
tmpDir.ToCString(), tmpDir.ToCString(),
isMultiFile ); isMultiFile );
TCollection_AsciiString aStudyName( "" ); TCollection_AsciiString aStudyName( "" );
if ( isMultiFile ) if ( isMultiFile ) {
aStudyName = ( (char*)SALOMEDS_Tool::GetNameFromPath( myCurrentStudy->URL() ).c_str() ); CORBA::String_var url = myCurrentStudy->URL();
aStudyName = (char*)SALOMEDS_Tool::GetNameFromPath( url.in() ).c_str();
}
// Set names of temporary files // Set names of temporary files
TCollection_AsciiString filename = tmpDir + aStudyName + TCollection_AsciiString( "_SMESH.hdf" ); TCollection_AsciiString filename = tmpDir + aStudyName + "_SMESH.hdf";
TCollection_AsciiString meshfile = tmpDir + aStudyName + TCollection_AsciiString( "_SMESH_Mesh.med" ); TCollection_AsciiString meshfile = tmpDir + aStudyName + "_SMESH_Mesh.med";
int size; int size;
HDFfile* aFile; HDFfile* aFile;
@ -4430,21 +4431,21 @@ bool SMESH_Gen_i::Load( SALOMEDS::SComponent_ptr theComponent,
// --> try to find SUB-MESHES containers for each type of submesh // --> try to find SUB-MESHES containers for each type of submesh
for ( int j = GetSubMeshOnVertexTag(); j <= GetSubMeshOnCompoundTag(); j++ ) { for ( int j = GetSubMeshOnVertexTag(); j <= GetSubMeshOnCompoundTag(); j++ ) {
char name_meshgroup[ 30 ]; const char* name_meshgroup;
if ( j == GetSubMeshOnVertexTag() ) if ( j == GetSubMeshOnVertexTag() )
strcpy( name_meshgroup, "SubMeshes On Vertex" ); name_meshgroup = "SubMeshes On Vertex";
else if ( j == GetSubMeshOnEdgeTag() ) else if ( j == GetSubMeshOnEdgeTag() )
strcpy( name_meshgroup, "SubMeshes On Edge" ); name_meshgroup = "SubMeshes On Edge";
else if ( j == GetSubMeshOnWireTag() ) else if ( j == GetSubMeshOnWireTag() )
strcpy( name_meshgroup, "SubMeshes On Wire" ); name_meshgroup = "SubMeshes On Wire";
else if ( j == GetSubMeshOnFaceTag() ) else if ( j == GetSubMeshOnFaceTag() )
strcpy( name_meshgroup, "SubMeshes On Face" ); name_meshgroup = "SubMeshes On Face";
else if ( j == GetSubMeshOnShellTag() ) else if ( j == GetSubMeshOnShellTag() )
strcpy( name_meshgroup, "SubMeshes On Shell" ); name_meshgroup = "SubMeshes On Shell";
else if ( j == GetSubMeshOnSolidTag() ) else if ( j == GetSubMeshOnSolidTag() )
strcpy( name_meshgroup, "SubMeshes On Solid" ); name_meshgroup = "SubMeshes On Solid";
else if ( j == GetSubMeshOnCompoundTag() ) else if ( j == GetSubMeshOnCompoundTag() )
strcpy( name_meshgroup, "SubMeshes On Compound" ); name_meshgroup = "SubMeshes On Compound";
// try to get submeshes container HDF group // try to get submeshes container HDF group
if ( aTopGroup->ExistInternalObject( name_meshgroup ) ) { if ( aTopGroup->ExistInternalObject( name_meshgroup ) ) {
@ -4458,9 +4459,9 @@ bool SMESH_Gen_i::Load( SALOMEDS::SComponent_ptr theComponent,
// identify submesh // identify submesh
char name_submeshgroup[ HDF_NAME_MAX_LEN+1 ]; char name_submeshgroup[ HDF_NAME_MAX_LEN+1 ];
aGroup->InternalObjectIndentify( k, name_submeshgroup ); aGroup->InternalObjectIndentify( k, name_submeshgroup );
if ( string( name_submeshgroup ).substr( 0, 7 ) == string( "SubMesh" ) ) { if ( strncmp( name_submeshgroup, "SubMesh", 7 ) == 0 ) {
// --> get submesh id // --> get submesh id
int subid = atoi( string( name_submeshgroup ).substr( 7 ).c_str() ); int subid = atoi( name_submeshgroup + 7 );
if ( subid <= 0 ) if ( subid <= 0 )
continue; continue;
// open submesh HDF group // open submesh HDF group
@ -4510,7 +4511,7 @@ bool SMESH_Gen_i::Load( SALOMEDS::SComponent_ptr theComponent,
char name_dataset[ HDF_NAME_MAX_LEN+1 ]; char name_dataset[ HDF_NAME_MAX_LEN+1 ];
aSubSubGroup->InternalObjectIndentify( l, name_dataset ); aSubSubGroup->InternalObjectIndentify( l, name_dataset );
// check if it is an algorithm // check if it is an algorithm
if ( string( name_dataset ).substr( 0, 4 ) == string( "Algo" ) ) { if ( strncmp( name_dataset, "Algo", 4 ) == 0 ) {
aDataset = new HDFdataset( name_dataset, aSubSubGroup ); aDataset = new HDFdataset( name_dataset, aSubSubGroup );
aDataset->OpenOnDisk(); aDataset->OpenOnDisk();
size = aDataset->GetSize(); size = aDataset->GetSize();