Eeschema Eagle Import: Set subsheet name based on original Eagle schematic file name.
This commit is contained in:
parent
4a4954dd82
commit
3f738b661e
|
@ -528,7 +528,8 @@ void SCH_EAGLE_PLUGIN::loadSchematic( wxXmlNode* aSchematicNode )
|
||||||
if( sheet_count > 1 )
|
if( sheet_count > 1 )
|
||||||
{
|
{
|
||||||
// TODO: set up a heirachical sheet for each Eagle sheet.
|
// TODO: set up a heirachical sheet for each Eagle sheet.
|
||||||
int x, y;
|
int x, y, i;
|
||||||
|
i = 1;
|
||||||
x = 1;
|
x = 1;
|
||||||
y = 1;
|
y = 1;
|
||||||
|
|
||||||
|
@ -538,12 +539,12 @@ void SCH_EAGLE_PLUGIN::loadSchematic( wxXmlNode* aSchematicNode )
|
||||||
std::unique_ptr<SCH_SHEET> sheet( new SCH_SHEET( pos ) );
|
std::unique_ptr<SCH_SHEET> sheet( new SCH_SHEET( pos ) );
|
||||||
SCH_SCREEN* screen = new SCH_SCREEN( m_kiway );
|
SCH_SCREEN* screen = new SCH_SCREEN( m_kiway );
|
||||||
|
|
||||||
sheet->SetTimeStamp( GetNewTimeStamp() );
|
sheet->SetTimeStamp( GetNewTimeStamp()-i ); // minus the sheet index to make it unique.
|
||||||
sheet->SetParent( m_rootSheet->GetScreen() );
|
sheet->SetParent( m_rootSheet->GetScreen() );
|
||||||
sheet->SetScreen( screen );
|
sheet->SetScreen( screen );
|
||||||
|
|
||||||
m_currentSheet = sheet.get();
|
m_currentSheet = sheet.get();
|
||||||
loadSheet( sheetNode );
|
loadSheet( sheetNode, i);
|
||||||
sheet->GetScreen()->SetFileName( sheet->GetFileName() );
|
sheet->GetScreen()->SetFileName( sheet->GetFileName() );
|
||||||
m_rootSheet->GetScreen()->Append( sheet.release() );
|
m_rootSheet->GetScreen()->Append( sheet.release() );
|
||||||
|
|
||||||
|
@ -555,6 +556,7 @@ void SCH_EAGLE_PLUGIN::loadSchematic( wxXmlNode* aSchematicNode )
|
||||||
x = 1;
|
x = 1;
|
||||||
y += 2;
|
y += 2;
|
||||||
}
|
}
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -562,14 +564,14 @@ void SCH_EAGLE_PLUGIN::loadSchematic( wxXmlNode* aSchematicNode )
|
||||||
while( sheetNode )
|
while( sheetNode )
|
||||||
{
|
{
|
||||||
m_currentSheet = m_rootSheet;
|
m_currentSheet = m_rootSheet;
|
||||||
loadSheet( sheetNode );
|
loadSheet( sheetNode, 0 );
|
||||||
sheetNode = sheetNode->GetNext();
|
sheetNode = sheetNode->GetNext();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void SCH_EAGLE_PLUGIN::loadSheet( wxXmlNode* aSheetNode )
|
void SCH_EAGLE_PLUGIN::loadSheet( wxXmlNode* aSheetNode, int sheetcount )
|
||||||
{
|
{
|
||||||
// Map all children into a readable dictionary
|
// Map all children into a readable dictionary
|
||||||
NODE_MAP sheetChildren = mapChildren( aSheetNode );
|
NODE_MAP sheetChildren = mapChildren( aSheetNode );
|
||||||
|
@ -578,20 +580,27 @@ void SCH_EAGLE_PLUGIN::loadSheet( wxXmlNode* aSheetNode )
|
||||||
|
|
||||||
wxXmlNode* descriptionNode = getChildrenNodes( sheetChildren, "description" );
|
wxXmlNode* descriptionNode = getChildrenNodes( sheetChildren, "description" );
|
||||||
|
|
||||||
|
wxString des;
|
||||||
|
std::string filename;
|
||||||
if( descriptionNode )
|
if( descriptionNode )
|
||||||
{
|
{
|
||||||
wxString des = descriptionNode->GetContent();
|
des = descriptionNode->GetContent();
|
||||||
m_currentSheet->SetName( des );
|
m_currentSheet->SetName( des );
|
||||||
|
filename = des.ToStdString();
|
||||||
std::string filename = des.ToStdString();
|
|
||||||
ReplaceIllegalFileNameChars( &filename );
|
|
||||||
replace( filename.begin(), filename.end(), ' ', '_' );
|
|
||||||
|
|
||||||
wxString fn = wxString( filename + ".sch" );
|
|
||||||
m_currentSheet->SetFileName( fn );
|
|
||||||
wxFileName fileName = m_currentSheet->GetFileName();
|
|
||||||
m_currentSheet->GetScreen()->SetFileName( fileName.GetFullPath() );
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
filename = m_filename.GetName().ToStdString() + "_" + std::to_string(sheetcount);
|
||||||
|
m_currentSheet->SetName( filename );
|
||||||
|
}
|
||||||
|
|
||||||
|
ReplaceIllegalFileNameChars( &filename );
|
||||||
|
replace( filename.begin(), filename.end(), ' ', '_' );
|
||||||
|
|
||||||
|
wxString fn = wxString( filename + ".sch" );
|
||||||
|
m_currentSheet->SetFileName( fn );
|
||||||
|
wxFileName fileName = m_currentSheet->GetFileName();
|
||||||
|
m_currentSheet->GetScreen()->SetFileName( fileName.GetFullPath() );
|
||||||
|
|
||||||
// Loop through all busses
|
// Loop through all busses
|
||||||
// From the DTD: "Buses receive names which determine which signals they include.
|
// From the DTD: "Buses receive names which determine which signals they include.
|
||||||
|
@ -797,7 +806,7 @@ void SCH_EAGLE_PLUGIN::loadSegments( wxXmlNode* aSegmentsNode, const wxString& n
|
||||||
std::unique_ptr<SCH_GLOBALLABEL> glabel( new SCH_GLOBALLABEL );
|
std::unique_ptr<SCH_GLOBALLABEL> glabel( new SCH_GLOBALLABEL );
|
||||||
glabel->SetPosition( wire->GetStartPoint() );
|
glabel->SetPosition( wire->GetStartPoint() );
|
||||||
glabel->SetText( netname);
|
glabel->SetText( netname);
|
||||||
glabel->SetTextSize( wxSize( GetDefaultTextSize(), GetDefaultTextSize() ) );
|
glabel->SetTextSize( wxSize( 10, 10 ) );
|
||||||
screen->Append( glabel.release() );
|
screen->Append( glabel.release() );
|
||||||
}
|
}
|
||||||
else if ( segmentCount > 1)
|
else if ( segmentCount > 1)
|
||||||
|
@ -805,7 +814,7 @@ void SCH_EAGLE_PLUGIN::loadSegments( wxXmlNode* aSegmentsNode, const wxString& n
|
||||||
std::unique_ptr<SCH_LABEL> label( new SCH_LABEL );
|
std::unique_ptr<SCH_LABEL> label( new SCH_LABEL );
|
||||||
label->SetPosition( wire->GetStartPoint() );
|
label->SetPosition( wire->GetStartPoint() );
|
||||||
label->SetText( netname );
|
label->SetText( netname );
|
||||||
label->SetTextSize( wxSize( GetDefaultTextSize(), GetDefaultTextSize() ) );
|
label->SetTextSize( wxSize( 10, 10 ) );
|
||||||
screen->Append( label.release() );
|
screen->Append( label.release() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -134,7 +134,7 @@ private:
|
||||||
void loadDrawing( wxXmlNode* aDrawingNode );
|
void loadDrawing( wxXmlNode* aDrawingNode );
|
||||||
void loadLayerDefs( wxXmlNode* aLayers );
|
void loadLayerDefs( wxXmlNode* aLayers );
|
||||||
void loadSchematic( wxXmlNode* aSchematicNode );
|
void loadSchematic( wxXmlNode* aSchematicNode );
|
||||||
void loadSheet( wxXmlNode* aSheetNode );
|
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 );
|
||||||
|
|
Loading…
Reference in New Issue