Eeschema Eagle Import: Fix package assigment by combining eagle libraries of the same name.
This commit is contained in:
parent
e63e916279
commit
d260609e69
|
@ -509,8 +509,14 @@ void SCH_EAGLE_PLUGIN::loadSchematic( wxXmlNode* aSchematicNode )
|
||||||
|
|
||||||
while( libraryNode )
|
while( libraryNode )
|
||||||
{
|
{
|
||||||
EAGLE_LIBRARY elib = loadLibrary( libraryNode );
|
// Read the library name
|
||||||
m_eaglelibraries[elib.name] = elib;
|
wxString libName = libraryNode->GetAttribute( "name" );
|
||||||
|
|
||||||
|
EAGLE_LIBRARY* elib = &m_eaglelibraries[libName.ToStdString()];
|
||||||
|
elib->name = libName.ToStdString();
|
||||||
|
|
||||||
|
loadLibrary( libraryNode , &m_eaglelibraries[libName.ToStdString()]);
|
||||||
|
|
||||||
libraryNode = libraryNode->GetNext();
|
libraryNode = libraryNode->GetNext();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1030,22 +1036,26 @@ void SCH_EAGLE_PLUGIN::loadInstance( wxXmlNode* aInstanceNode )
|
||||||
// Calculate the unit number from the gate entry of the instance
|
// Calculate the unit number from the gate entry of the instance
|
||||||
// Assign the the LIB_ID from deviceset and device names
|
// Assign the the LIB_ID from deviceset and device names
|
||||||
|
|
||||||
|
|
||||||
EPART* epart = m_partlist[einstance.part].get();
|
EPART* epart = m_partlist[einstance.part].get();
|
||||||
|
|
||||||
|
std::string libraryname = epart->library;
|
||||||
std::string gatename = epart->deviceset + epart->device + einstance.gate;
|
std::string gatename = epart->deviceset + epart->device + einstance.gate;
|
||||||
wxString sntemp( epart->deviceset + epart->device );
|
wxString sntemp( epart->deviceset + epart->device );
|
||||||
sntemp.Replace("*", "");
|
sntemp.Replace("*", "");
|
||||||
std::string symbolname = sntemp.ToStdString();
|
std::string symbolname = sntemp.ToStdString();
|
||||||
|
|
||||||
|
int unit = m_eaglelibraries[libraryname].gate_unit[gatename];
|
||||||
// KiCad enumerates units starting from 1, Eagle starts with 0
|
|
||||||
int unit = m_eaglelibraries[epart->library].gate_unit[gatename];
|
|
||||||
std::string package = m_eaglelibraries[epart->library].package[symbolname];
|
|
||||||
|
|
||||||
// std::cout << "Instance> part: " << einstance.part << " Gate: " << einstance.gate << " " << symbolname << '\n';
|
std::string package;
|
||||||
|
EAGLE_LIBRARY* elib = &m_eaglelibraries[libraryname];
|
||||||
|
|
||||||
|
auto p = elib->package.find(symbolname);
|
||||||
|
if(p != elib->package.end() )
|
||||||
|
{
|
||||||
|
package = p->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
//std::cout << "Instance> part: " << einstance.part << " Library: \"" << libraryname << "\" Gate: " << einstance.gate << " Symbol \"" << symbolname << " "<<symbolname.length() << "\" package " << package <<'\n';
|
||||||
LIB_ID libId( wxEmptyString, symbolname );
|
LIB_ID libId( wxEmptyString, symbolname );
|
||||||
|
|
||||||
LIB_PART* part = m_partlib->FindPart(symbolname);
|
LIB_PART* part = m_partlib->FindPart(symbolname);
|
||||||
|
@ -1194,16 +1204,9 @@ void SCH_EAGLE_PLUGIN::loadModuleinst( wxXmlNode* aModuleinstNode )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
EAGLE_LIBRARY SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode )
|
EAGLE_LIBRARY* SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode, EAGLE_LIBRARY* elib )
|
||||||
{
|
{
|
||||||
|
|
||||||
EAGLE_LIBRARY elib;
|
|
||||||
|
|
||||||
|
|
||||||
// Read the library name
|
|
||||||
wxString libName = aLibraryNode->GetAttribute( "name" );
|
|
||||||
elib.name = libName.ToStdString();
|
|
||||||
|
|
||||||
////std::cout << "Importing Eagle Library "<< libName.ToStdString() << std::endl;
|
////std::cout << "Importing Eagle Library "<< libName.ToStdString() << std::endl;
|
||||||
|
|
||||||
// Query all children and map them into a readable dictionary
|
// Query all children and map them into a readable dictionary
|
||||||
|
@ -1227,7 +1230,7 @@ EAGLE_LIBRARY SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode )
|
||||||
while( symbolNode )
|
while( symbolNode )
|
||||||
{
|
{
|
||||||
string symbolName = symbolNode->GetAttribute( "name" ).ToStdString();
|
string symbolName = symbolNode->GetAttribute( "name" ).ToStdString();
|
||||||
elib.symbolnodes[symbolName] = symbolNode;
|
elib->symbolnodes[symbolName] = symbolNode;
|
||||||
symbolNode = symbolNode->GetNext();
|
symbolNode = symbolNode->GetNext();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1253,11 +1256,19 @@ EAGLE_LIBRARY SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode )
|
||||||
|
|
||||||
// Create symbol name from deviceset and device names.
|
// Create symbol name from deviceset and device names.
|
||||||
wxString symbolName = wxString( edeviceset.name + edevice.name );
|
wxString symbolName = wxString( edeviceset.name + edevice.name );
|
||||||
// std::cout << "Creating Kicad Symbol: " << symbolName.ToStdString() << '\n';
|
//std::cout << "edevice.name \""<< edevice.name << "\"\n";
|
||||||
symbolName.Replace("*", "");
|
//symbolName.Replace("*", "");
|
||||||
|
|
||||||
|
|
||||||
|
std::string symbolname = symbolName.ToStdString();
|
||||||
|
|
||||||
|
std::string package;
|
||||||
if( edevice.package )
|
if( edevice.package )
|
||||||
elib.package[symbolName.ToStdString()] = edevice.package.Get();
|
{
|
||||||
|
package = edevice.package.Get();
|
||||||
|
elib->package[symbolname] = package;
|
||||||
|
}
|
||||||
|
//std::cout << "Creating Kicad Symbol: " << symbolname << " in library \""<< elib->name<<"\" "<< symbolname.length() << " with package \""<< package << "\"\n";
|
||||||
|
|
||||||
// Create kicad symbol.
|
// Create kicad symbol.
|
||||||
unique_ptr<LIB_PART> kpart( new LIB_PART( symbolName ) );
|
unique_ptr<LIB_PART> kpart( new LIB_PART( symbolName ) );
|
||||||
|
@ -1270,15 +1281,12 @@ EAGLE_LIBRARY SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode )
|
||||||
LIB_FIELD* reference = kpart->GetField(REFERENCE);
|
LIB_FIELD* reference = kpart->GetField(REFERENCE);
|
||||||
if( prefix.length() ==0 )
|
if( prefix.length() ==0 )
|
||||||
{
|
{
|
||||||
std::cout << "length == 0" << '\n';
|
|
||||||
reference->SetVisible( false );
|
reference->SetVisible( false );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
std::cout << "a prefix" << '\n';
|
|
||||||
reference->SetText( prefix );
|
reference->SetText( prefix );
|
||||||
}
|
}
|
||||||
std::cout << "after prefix" << '\n';
|
|
||||||
int gateindex;
|
int gateindex;
|
||||||
bool ispower = false;
|
bool ispower = false;
|
||||||
|
|
||||||
|
@ -1288,10 +1296,10 @@ EAGLE_LIBRARY SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode )
|
||||||
{
|
{
|
||||||
EGATE egate = EGATE( gateNode );
|
EGATE egate = EGATE( gateNode );
|
||||||
|
|
||||||
elib.gate_unit[edeviceset.name + edevice.name + egate.name] = gateindex;
|
elib->gate_unit[edeviceset.name + edevice.name + egate.name] = gateindex;
|
||||||
|
|
||||||
|
|
||||||
ispower = loadSymbol( elib.symbolnodes[egate.symbol],
|
ispower = loadSymbol( elib->symbolnodes[egate.symbol],
|
||||||
kpart, &edevice, gateindex, egate.name );
|
kpart, &edevice, gateindex, egate.name );
|
||||||
|
|
||||||
gateindex++;
|
gateindex++;
|
||||||
|
@ -1303,7 +1311,7 @@ EAGLE_LIBRARY SCH_EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLibraryNode )
|
||||||
|
|
||||||
string name = kpart->GetName().ToStdString();
|
string name = kpart->GetName().ToStdString();
|
||||||
m_partlib->AddPart( kpart.get() );
|
m_partlib->AddPart( kpart.get() );
|
||||||
elib.kicadsymbols.insert( name, kpart.release() );
|
elib->kicadsymbols.insert( name, kpart.release() );
|
||||||
|
|
||||||
deviceNode = deviceNode->GetNext();
|
deviceNode = deviceNode->GetNext();
|
||||||
} // devicenode
|
} // devicenode
|
||||||
|
|
|
@ -137,7 +137,7 @@ private:
|
||||||
void loadSheet( wxXmlNode* aSheetNode, int sheetcount );
|
void loadSheet( wxXmlNode* aSheetNode, int sheetcount );
|
||||||
void loadInstance( wxXmlNode* aInstanceNode );
|
void loadInstance( wxXmlNode* aInstanceNode );
|
||||||
void loadModuleinst( wxXmlNode* aModuleinstNode );
|
void loadModuleinst( wxXmlNode* aModuleinstNode );
|
||||||
EAGLE_LIBRARY loadLibrary( wxXmlNode* aLibraryNode );
|
EAGLE_LIBRARY* loadLibrary( wxXmlNode* aLibraryNode, EAGLE_LIBRARY* elib);
|
||||||
void countNets( wxXmlNode* aSchematicNode );
|
void countNets( wxXmlNode* aSchematicNode );
|
||||||
void moveLabels( SCH_ITEM* wire, wxPoint newendpoint);
|
void moveLabels( SCH_ITEM* wire, wxPoint newendpoint);
|
||||||
void addBusEntries();
|
void addBusEntries();
|
||||||
|
|
Loading…
Reference in New Issue