Load sheet content after a paste.
Fixes: lp:1830633 * https://bugs.launchpad.net/kicad/+bug/1830633
This commit is contained in:
parent
1dd1ddf83b
commit
c7fa5c567f
|
@ -874,7 +874,10 @@ public:
|
||||||
*/
|
*/
|
||||||
bool EditSheet( SCH_SHEET* aSheet, SCH_SHEET_PATH* aHierarchy, bool* aClearAnnotationNewItems );
|
bool EditSheet( SCH_SHEET* aSheet, SCH_SHEET_PATH* aHierarchy, bool* aClearAnnotationNewItems );
|
||||||
|
|
||||||
void InitSheet( SCH_SHEET* aSheet, const wxString& aFilename );
|
void InitSheet( SCH_SHEET* aSheet, const wxString& aNewFilename );
|
||||||
|
|
||||||
|
void LoadSheetFromFile( SCH_SHEET* aSheet, SCH_SHEET_PATH* aHierarchy,
|
||||||
|
const wxString& aExistingFilename );
|
||||||
|
|
||||||
wxPoint GetLastSheetPinPosition() const { return m_lastSheetPinPosition; }
|
wxPoint GetLastSheetPinPosition() const { return m_lastSheetPinPosition; }
|
||||||
|
|
||||||
|
|
|
@ -38,12 +38,59 @@
|
||||||
#include <dialogs/dialog_sch_edit_sheet_pin.h>
|
#include <dialogs/dialog_sch_edit_sheet_pin.h>
|
||||||
|
|
||||||
|
|
||||||
void SCH_EDIT_FRAME::InitSheet( SCH_SHEET* aSheet, const wxString& aFilename )
|
void SCH_EDIT_FRAME::InitSheet( SCH_SHEET* aSheet, const wxString& aNewFilename )
|
||||||
{
|
{
|
||||||
aSheet->SetScreen( new SCH_SCREEN( &Kiway() ) );
|
aSheet->SetScreen( new SCH_SCREEN( &Kiway() ) );
|
||||||
aSheet->GetScreen()->SetModify();
|
aSheet->GetScreen()->SetModify();
|
||||||
aSheet->GetScreen()->SetMaxUndoItems( m_UndoRedoCountMax );
|
aSheet->GetScreen()->SetMaxUndoItems( m_UndoRedoCountMax );
|
||||||
aSheet->GetScreen()->SetFileName( aFilename );
|
aSheet->GetScreen()->SetFileName( aNewFilename );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void SCH_EDIT_FRAME::LoadSheetFromFile( SCH_SHEET* aSheet, SCH_SHEET_PATH* aHierarchy,
|
||||||
|
const wxString& aExistingFilename )
|
||||||
|
{
|
||||||
|
SCH_PLUGIN::SCH_PLUGIN_RELEASER pi( SCH_IO_MGR::FindPlugin( SCH_IO_MGR::SCH_LEGACY ) );
|
||||||
|
|
||||||
|
wxFileName fileName( aExistingFilename );
|
||||||
|
|
||||||
|
if( !fileName.IsAbsolute() )
|
||||||
|
{
|
||||||
|
const SCH_SCREEN* currentScreen = aHierarchy->LastScreen();
|
||||||
|
wxFileName currentSheetFileName = currentScreen->GetFileName();
|
||||||
|
fileName.Normalize( wxPATH_NORM_ALL, currentSheetFileName.GetPath() );
|
||||||
|
}
|
||||||
|
|
||||||
|
wxString fullFilename = fileName.GetFullPath();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
pi->Load( fullFilename, &Kiway(), aSheet );
|
||||||
|
|
||||||
|
if( !pi->GetError().IsEmpty() )
|
||||||
|
{
|
||||||
|
DisplayErrorMessage( this, _( "The entire schematic could not be loaded.\n"
|
||||||
|
"Errors occurred loading hierarchical sheets." ),
|
||||||
|
pi->GetError() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch( const IO_ERROR& ioe )
|
||||||
|
{
|
||||||
|
wxString msg;
|
||||||
|
|
||||||
|
msg.Printf( _( "Error occurred loading schematic file \"%s\"." ), fullFilename );
|
||||||
|
DisplayErrorMessage( this, msg, ioe.What() );
|
||||||
|
|
||||||
|
msg.Printf( _( "Failed to load schematic \"%s\"" ), fullFilename );
|
||||||
|
AppendMsgPanel( wxEmptyString, msg, CYAN );
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
SCH_SCREEN* screen = aSheet->GetScreen();
|
||||||
|
|
||||||
|
if( screen )
|
||||||
|
screen->UpdateSymbolLinks( true );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -98,8 +145,6 @@ bool SCH_EDIT_FRAME::EditSheet( SCH_SHEET* aSheet, SCH_SHEET_PATH* aHierarchy,
|
||||||
// Inside Eeschema, filenames are stored using unix notation
|
// Inside Eeschema, filenames are stored using unix notation
|
||||||
newFilename.Replace( wxT( "\\" ), wxT( "/" ) );
|
newFilename.Replace( wxT( "\\" ), wxT( "/" ) );
|
||||||
|
|
||||||
SCH_PLUGIN::SCH_PLUGIN_RELEASER pi( SCH_IO_MGR::FindPlugin( SCH_IO_MGR::SCH_LEGACY ) );
|
|
||||||
|
|
||||||
if( aSheet->GetScreen() == NULL ) // New sheet.
|
if( aSheet->GetScreen() == NULL ) // New sheet.
|
||||||
{
|
{
|
||||||
if( useScreen || loadFromFile ) // Load from existing file.
|
if( useScreen || loadFromFile ) // Load from existing file.
|
||||||
|
@ -187,6 +232,8 @@ bool SCH_EDIT_FRAME::EditSheet( SCH_SHEET* aSheet, SCH_SHEET_PATH* aHierarchy,
|
||||||
|
|
||||||
if( renameFile )
|
if( renameFile )
|
||||||
{
|
{
|
||||||
|
SCH_PLUGIN::SCH_PLUGIN_RELEASER pi( SCH_IO_MGR::FindPlugin( SCH_IO_MGR::SCH_LEGACY ) );
|
||||||
|
|
||||||
// If the the associated screen is shared by more than one sheet, do not
|
// If the the associated screen is shared by more than one sheet, do not
|
||||||
// change the filename of the corresponding screen here.
|
// change the filename of the corresponding screen here.
|
||||||
// (a new screen will be created later)
|
// (a new screen will be created later)
|
||||||
|
@ -230,33 +277,7 @@ bool SCH_EDIT_FRAME::EditSheet( SCH_SHEET* aSheet, SCH_SHEET_PATH* aHierarchy,
|
||||||
}
|
}
|
||||||
else if( loadFromFile )
|
else if( loadFromFile )
|
||||||
{
|
{
|
||||||
try
|
LoadSheetFromFile( aSheet, aHierarchy, newFilename );
|
||||||
{
|
|
||||||
aSheet = pi->Load( newFilename, &Kiway(), aSheet );
|
|
||||||
|
|
||||||
if( !pi->GetError().IsEmpty() )
|
|
||||||
{
|
|
||||||
DisplayErrorMessage( this,
|
|
||||||
_( "The entire schematic could not be loaded.\n"
|
|
||||||
"Errors occurred loading hierarchical sheets." ),
|
|
||||||
pi->GetError() );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch( const IO_ERROR& ioe )
|
|
||||||
{
|
|
||||||
msg.Printf( _( "Error occurred loading schematic file \"%s\"." ), newFilename );
|
|
||||||
DisplayErrorMessage( this, msg, ioe.What() );
|
|
||||||
|
|
||||||
msg.Printf( _( "Failed to load schematic \"%s\"" ), newFilename );
|
|
||||||
AppendMsgPanel( wxEmptyString, msg, CYAN );
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
SCH_SCREEN* screen = aSheet->GetScreen();
|
|
||||||
|
|
||||||
if( screen )
|
|
||||||
screen->UpdateSymbolLinks( true );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
aSheet->SetFileNameSize( dlg.GetFileNameTextSize() );
|
aSheet->SetFileNameSize( dlg.GetFileNameTextSize() );
|
||||||
|
|
|
@ -972,7 +972,7 @@ int SCH_EDITOR_CONTROL::Paste( const TOOL_EVENT& aEvent )
|
||||||
else if( item->Type() == SCH_SHEET_T )
|
else if( item->Type() == SCH_SHEET_T )
|
||||||
{
|
{
|
||||||
SCH_SHEET* sheet = (SCH_SHEET*) item;
|
SCH_SHEET* sheet = (SCH_SHEET*) item;
|
||||||
m_frame->InitSheet( sheet, sheet->GetFileName() );
|
m_frame->LoadSheetFromFile( sheet, g_CurrentSheet, sheet->GetFileName() );
|
||||||
}
|
}
|
||||||
|
|
||||||
item->SetFlags( IS_NEW | IS_PASTED | IS_MOVED );
|
item->SetFlags( IS_NEW | IS_PASTED | IS_MOVED );
|
||||||
|
|
Loading…
Reference in New Issue