From d4201ef51fcd4b46987cd99750a511367bc9be50 Mon Sep 17 00:00:00 2001 From: Maciej Suminski Date: Mon, 7 Aug 2017 11:26:47 +0200 Subject: [PATCH] Eeschema Eagle Import: memory leak fixes --- eeschema/sch_eagle_plugin.cpp | 10 +++++----- eeschema/sch_eagle_plugin.h | 4 ++-- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/eeschema/sch_eagle_plugin.cpp b/eeschema/sch_eagle_plugin.cpp index 757b88bf66..76e340d476 100644 --- a/eeschema/sch_eagle_plugin.cpp +++ b/eeschema/sch_eagle_plugin.cpp @@ -1179,8 +1179,8 @@ EAGLE_LIBRARY SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode ) while( symbolNode ) { - wxString symbolName = symbolNode->GetAttribute( "name" ); - elib.symbolnodes[symbolName.ToStdString()] = symbolNode; + string symbolName = symbolNode->GetAttribute( "name" ).ToStdString(); + elib.symbolnodes[symbolName] = symbolNode; symbolNode = symbolNode->GetNext(); } @@ -1239,9 +1239,9 @@ EAGLE_LIBRARY SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode ) kpart->SetUnitCount( gates_count ); if(gates_count == 1 && ispower) kpart->SetPower(); - const string& name = kpart->GetName().ToStdString(); + string name = kpart->GetName().ToStdString(); m_partlib->AddPart( kpart.get() ); - elib.kicadsymbols[name] = kpart.release(); + elib.kicadsymbols.insert( name, kpart.release() ); deviceNode = deviceNode->GetNext(); } // devicenode @@ -1267,7 +1267,7 @@ bool SCH_EAGLE_PLUGIN::loadSymbol( wxXmlNode* aSymbolNode, bool foundName = false; bool foundValue = false; bool ispower = false; - int pincount; + int pincount = 0; while( currentNode ) { diff --git a/eeschema/sch_eagle_plugin.h b/eeschema/sch_eagle_plugin.h index 059dcd8dbe..4485625bd6 100644 --- a/eeschema/sch_eagle_plugin.h +++ b/eeschema/sch_eagle_plugin.h @@ -69,8 +69,8 @@ class LIB_TEXT; typedef struct EAGLE_LIBRARY { std::string name; - boost::ptr_map kicadsymbols; - boost::ptr_map symbolnodes; + boost::ptr_map kicadsymbols; + std::unordered_map symbolnodes; std::unordered_map gate_unit; std::unordered_map package;