Eeschema Eagle Import: Set subsheet name based on original Eagle schematic file name.

This commit is contained in:
Russell Oliver 2017-08-12 19:18:18 +10:00 committed by Maciej Suminski
parent 4a4954dd82
commit 3f738b661e
2 changed files with 27 additions and 18 deletions

View File

@ -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() );
} }
} }

View File

@ -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 );