76#include <wx/filedlg.h>
78#include <wx/richmsgdlg.h>
79#include <wx/stdpaths.h>
104 if( aFileSet.size() != 1 )
106 msg.Printf(
"Eeschema:%s() takes only a single filename.", __WXFUNCTION__ );
111 wxString fullFileName( aFileSet[0] );
112 wxFileName wx_filename( fullFileName );
114 if( !
Prj().IsNullProject() )
118 wxASSERT_MSG( wx_filename.IsAbsolute(), wxS(
"Path is not absolute!" ) );
123 if(
Prj().IsLockOverrideGranted() )
129 msg.Printf(
_(
"Schematic '%s' is already open by '%s' at '%s'." ), fullFileName,
146 wxFileName pro = fullFileName;
149 bool is_new = !wxFileName::IsFileReadable( fullFileName );
155 msg.Printf(
_(
"Schematic '%s' does not exist. Do you wish to create it?" ),
158 if( !
IsOK(
this, msg ) )
162 wxCommandEvent e( EDA_EVT_SCHEMATIC_CHANGING );
163 ProcessEventLocally( e );
173 SetStatusText( wxEmptyString );
177 statusBar->ClearWarningMessages(
"load" );
180 :
_(
"Load Schematic" ), 1,
188 if( differentProject )
190 if( !
Prj().IsNullProject() )
202 wxFileName legacyPro( pro );
207 if( !pro.Exists() && !legacyPro.Exists() && !( aCtl &
KICTL_CREATE ) )
217 std::unique_ptr<SCHEMATIC> newSchematic = std::make_unique<SCHEMATIC>( &
Prj() );
222 if( schFileType == SCH_IO_MGR::SCH_LEGACY )
244 rfn.MakeRelativeTo(
Prj().GetProjectPath() );
254 if( is_new || schFileType == SCH_IO_MGR::SCH_FILE_T::SCH_FILE_UNKNOWN )
256 newSchematic->CreateDefaultScreens();
263 if( schFileType == SCH_IO_MGR::SCH_FILE_T::SCH_FILE_UNKNOWN )
265 msg.Printf(
_(
"'%s' is not a KiCad schematic file.\nUse File -> Import for "
266 "non-KiCad schematic files." ),
269 progressReporter.Hide();
279 pi->SetProgressReporter( &progressReporter );
281 bool failedLoad =
false;
291 const std::vector<TOP_LEVEL_SHEET_INFO>& topLevelSheets = projectFile.
GetTopLevelSheets();
293 if( !topLevelSheets.empty() )
295 std::vector<SCH_SHEET*> loadedSheets;
300 wxFileName sheetFileName(
Prj().GetProjectPath(), sheetInfo.filename );
303 if( schFileType == SCH_IO_MGR::SCH_LEGACY )
306 wxString sheetPath = sheetFileName.GetFullPath();
308 if( !wxFileName::FileExists( sheetPath ) )
310 wxLogWarning( wxT(
"Top-level sheet file not found: %s" ), sheetPath );
314 SCH_SHEET* sheet = pi->LoadSchematicFile( sheetPath, newSchematic.get() );
320 if( sheetInfo.uuid !=
niluuid )
322 const_cast<KIID&
>( sheet->
m_Uuid ) = sheetInfo.uuid;
325 sheet->
SetName( sheetInfo.name );
326 loadedSheets.push_back( sheet );
329 wxS(
"Loaded top-level sheet '%s' (UUID %s) from %s" ),
336 if( !loadedSheets.empty() )
338 newSchematic->SetTopLevelSheets( loadedSheets );
343 wxS(
"Loaded multi-root schematic with no top-level sheets!" ) );
344 newSchematic->CreateDefaultScreens();
350 SCH_SHEET* rootSheet = pi->LoadSchematicFile( fullFileName, newSchematic.get() );
354 newSchematic->SetTopLevelSheets( { rootSheet } );
358 if(
SCH_SHEET* topSheet = newSchematic->GetTopLevelSheet() )
359 topSheet->SetName(
_(
"Root" ) );
362 wxS(
"Loaded schematic with root sheet UUID %s" ),
365 "After loading: Current sheet path='%s', size=%zu, empty=%d",
366 newSchematic->CurrentSheet().Path().AsString(),
367 newSchematic->CurrentSheet().size(),
368 newSchematic->CurrentSheet().empty() ? 1 : 0 );
372 newSchematic->CreateDefaultScreens();
378 if( !pi->GetError().IsEmpty() )
381 "occurred attempting to load hierarchical sheets." ),
387 newSchematic->CreateDefaultScreens();
388 msg.Printf(
_(
"Error loading schematic '%s'." ), fullFileName );
389 progressReporter.Hide();
396 newSchematic->CreateDefaultScreens();
397 msg.Printf(
_(
"Error loading schematic '%s'." ), fullFileName );
398 progressReporter.Hide();
403 catch(
const std::bad_alloc& )
405 newSchematic->CreateDefaultScreens();
406 msg.Printf(
_(
"Memory exhausted loading schematic '%s'." ), fullFileName );
407 progressReporter.Hide();
429 statusBar->AddWarningMessages(
"load", loadReporter.
GetMessages() );
431 msg.Printf(
_(
"Failed to load '%s'." ), fullFileName );
448 _(
"An error was found when loading the schematic that has "
449 "been automatically fixed. Please save the schematic to "
450 "repair the broken file or it may not be usable with other "
451 "versions of KiCad." ) );
460 statusBar->AddWarningMessages(
"load", loadReporter.
GetMessages() );
465 if( schFileType == SCH_IO_MGR::SCH_LEGACY )
468 for(
SCH_SCREEN* screen = schematic.GetFirst(); screen; screen = schematic.GetNext() )
470 std::vector<SCH_ITEM*> deleted;
472 for(
SCH_ITEM* item : screen->Items() )
477 std::unique_ptr<SCH_LINE> wire = std::make_unique<SCH_LINE>();
481 wire->SetEndPoint( entry->
GetEnd() );
483 screen->Append( wire.release() );
484 deleted.push_back( item );
489 screen->Remove( item );
494 if( schematic.HasNoFullyDefinedLibIds() )
505 wxArrayString libNames;
509 if( !libNames.IsEmpty() )
511 if(
eeconfig()->m_Appearance.show_illegal_symbol_lib_dialog )
513 wxRichMessageDialog invalidLibDlg(
515 _(
"Illegal entry found in project file symbol library list." ),
516 _(
"Project Load Warning" ),
517 wxOK | wxCENTER | wxICON_EXCLAMATION );
518 invalidLibDlg.ShowDetailedText(
519 _(
"Symbol libraries defined in the project file symbol library "
520 "list are no longer supported and will be removed.\n\n"
521 "This may cause broken symbol library links under certain "
523 invalidLibDlg.ShowCheckBox(
_(
"Do not show this dialog again." ) );
524 invalidLibDlg.ShowModal();
526 !invalidLibDlg.IsCheckBoxChecked();
535 wxFileName cacheFn( fullFileName );
536 cacheFn.SetName( cacheFn.GetName() +
"-cache" );
538 bool cacheExists = cacheFn.FileExists();
549 if( !(*table)->HasRow( nickname ) )
553 row.
SetURI( cacheFn.GetFullPath() );
559 std::vector<wxString> cacheSymbols = adapter->
GetSymbolNames( nickname );
560 std::set<wxString> cacheSymbolSet( cacheSymbols.begin(), cacheSymbols.end() );
562 if( !cacheSymbolSet.empty() )
564 std::vector<wxString> loadedLibs;
568 if( libName == nickname )
574 loadedLibs.push_back( libName );
577 for(
SCH_SCREEN* screen = schematic.GetFirst(); screen; screen = schematic.GetNext() )
585 if( cacheSymbolSet.count( fullLibName.
wx_str() ) )
587 bool alreadyExists =
false;
589 for(
const wxString& libName : loadedLibs )
593 alreadyExists =
true;
614 editor->RescueSymbolLibTableProject(
false );
624 wxFileName cacheFn = pro;
626 wxLogTrace(
traceAutoSave,
"[SetName dbg] cacheFn BEFORE path='%s' name='%s' full='%s' arg='%s'",
627 cacheFn.GetPath(), cacheFn.GetName(), cacheFn.GetFullPath(), cacheFn.GetName() +
"-cache" );
628 cacheFn.SetName( cacheFn.GetName() +
"-cache" );
629 wxLogTrace(
traceAutoSave,
"[SetName dbg] cacheFn AFTER path='%s' name='%s' full='%s'",
630 cacheFn.GetPath(), cacheFn.GetName(), cacheFn.GetFullPath() );
633 msg.Printf(
_(
"The project symbol library cache file '%s' was not found." ),
634 cacheFn.GetFullName() );
635 extMsg =
_(
"This can result in a broken schematic under certain conditions. "
636 "If the schematic does not have any missing symbols upon opening, "
637 "save it immediately before making any changes to prevent data "
638 "loss. If there are missing symbols, either manual recovery of "
639 "the schematic or recovery of the symbol cache library file and "
640 "reloading the schematic is required." );
643 wxOK | wxCANCEL | wxICON_EXCLAMATION | wxCENTER );
644 dlgMissingCache.SetExtendedMessage( extMsg );
645 dlgMissingCache.SetOKCancelLabels( KICAD_MESSAGE_DIALOG::ButtonLabel(
_(
"Load Without Cache File" ) ),
646 KICAD_MESSAGE_DIALOG::ButtonLabel(
_(
"Abort" ) ) );
648 if( dlgMissingCache.ShowModal() == wxID_CANCEL )
657 schematic.UpdateSymbolLinks( &loadReporter );
661 m_infoBar->ShowMessage(
_(
"This file was created by an older version of KiCad. "
662 "It will be converted to the new format when saved." ),
663 wxICON_WARNING, WX_INFOBAR::MESSAGE_TYPE::OUTDATED_SAVE );
667 schematic.ReplaceDuplicateTimeStamps();
669 for(
SCH_SCREEN* screen = schematic.GetFirst(); screen; screen = schematic.GetNext() )
670 screen->FixLegacyPowerSymbolMismatches();
677 SCH_SCREEN* first_screen = schematic.GetFirst();
681 first_screen = schematic.GetNext();
687 m_infoBar->ShowMessage(
_(
"This file was created by an older version of KiCad. "
688 "It will be converted to the new format when saved." ),
689 wxICON_WARNING, WX_INFOBAR::MESSAGE_TYPE::OUTDATED_SAVE );
692 for(
SCH_SCREEN* screen = schematic.GetFirst(); screen; screen = schematic.GetNext() )
705 for(
SCH_SCREEN* screen = schematic.GetFirst(); screen;
706 screen = schematic.GetNext() )
707 screen->FixLegacyPowerSymbolMismatches();
709 for(
SCH_SCREEN* screen = schematic.GetFirst(); screen; screen = schematic.GetNext() )
710 screen->MigrateSimModels();
722 "Before CheckForMissingSymbolInstances: Current sheet path='%s', size=%zu",
730 schematic.PruneOrphanedSymbolInstances(
Prj().GetProjectName(), sheetList );
731 schematic.PruneOrphanedSheetInstances(
Prj().GetProjectName(), sheetList );
738 "After SetScreen: Current sheet path='%s', size=%zu",
744 if(
Schematic().ConnectionGraph()->GetBusesNeedingMigration().size() > 0 )
753 progressReporter.
Report(
_(
"Updating connections..." ) );
758 if( schematic.HasSymbolFieldNamesWithWhiteSpace() )
760 m_infoBar->QueueShowMessage(
_(
"This schematic contains symbols that have leading "
761 "and/or trailing white space field names." ),
783 if( schFileType == SCH_IO_MGR::SCH_LEGACY )
801 wxCommandEvent changedEvt( EDA_EVT_SCHEMATIC_CHANGED );
802 ProcessEventLocally( changedEvt );
804 if( !differentProject )
815 wxCHECK2( listener,
continue );
819 wxWindow* win =
dynamic_cast<wxWindow*
>( listener );
822 win->HandleWindowEvent( e );
824 listener->SafelyProcessEvent( e );
832 if( fn.FileExists() && !fn.IsFileWritable() )
836 m_infoBar->ShowMessage(
_(
"Schematic is read only." ),
837 wxICON_WARNING, WX_INFOBAR::MESSAGE_TYPE::OUTDATED_SAVE );
866 wxString msg =
_(
"This operation replaces the contents of the current schematic, "
867 "which will be permanently lost.\n\n"
868 "Do you want to proceed?" );
870 if( !
IsOK(
this, msg ) )
876 wxString
path = wxPathOnly(
Prj().GetProjectFullName() );
878 wxString fileFiltersStr;
879 wxString allWildcardsStr;
881 for(
const SCH_IO_MGR::SCH_FILE_T&
fileType : SCH_IO_MGR::SCH_FILE_T_vector )
883 if(
fileType == SCH_IO_MGR::SCH_KICAD ||
fileType == SCH_IO_MGR::SCH_LEGACY )
896 if( !fileFiltersStr.IsEmpty() )
897 fileFiltersStr += wxChar(
'|' );
905 fileFiltersStr =
_(
"All supported formats" ) + wxS(
"|" ) + allWildcardsStr + wxS(
"|" )
908 wxFileDialog dlg(
this,
_(
"Import Schematic" ),
path, wxEmptyString, fileFiltersStr,
909 wxFD_OPEN | wxFD_FILE_MUST_EXIST );
912 dlg.SetCustomizeHook( importOptions );
916 if( dlg.ShowModal() == wxID_CANCEL )
936 wxFileName projectFn( dlg.GetPath() );
941 wxFileName fn = dlg.GetPath();
943 if( !fn.IsFileReadable() )
945 wxLogError(
_(
"Insufficient permissions to read file '%s'." ), fn.GetFullPath() );
949 SCH_IO_MGR::SCH_FILE_T pluginType = SCH_IO_MGR::SCH_FILE_T::SCH_FILE_UNKNOWN;
951 for(
const SCH_IO_MGR::SCH_FILE_T&
fileType : SCH_IO_MGR::SCH_FILE_T_vector )
958 if( pi->CanReadSchematicFile( fn.GetFullPath() ) )
965 if( pluginType == SCH_IO_MGR::SCH_FILE_T::SCH_FILE_UNKNOWN )
967 wxLogError(
_(
"No loader can read the specified file: '%s'." ), fn.GetFullPath() );
982 wxFileName schematicFileName;
983 wxFileName oldFileName;
988 wxCHECK( screen,
false );
991 if( aSavePath.IsEmpty() )
996 oldFileName = schematicFileName;
1001 if( !schematicFileName.DirExists() )
1003 if( !wxMkdir( schematicFileName.GetPath() ) )
1005 msg.Printf(
_(
"Error saving schematic file '%s'.\n%s" ),
1006 schematicFileName.GetFullPath(),
1007 "Could not create directory: %s" + schematicFileName.GetPath() );
1017 wxFileName projectFile( schematicFileName );
1021 if( projectFile.FileExists() )
1029 wxLogTrace(
traceAutoSave, wxS(
"Saving file " ) + schematicFileName.GetFullPath() );
1031 if(
m_infoBar->GetMessageType() == WX_INFOBAR::MESSAGE_TYPE::OUTDATED_SAVE )
1035 schematicFileName.GetFullPath() );
1037 if( pluginType == SCH_IO_MGR::SCH_FILE_UNKNOWN )
1038 pluginType = SCH_IO_MGR::SCH_KICAD;
1044 if( schematicFileName.FileExists() )
1049 pi->SaveSchematicFile( schematicFileName.GetFullPath(), aSheet, &
Schematic() );
1054 msg.Printf(
_(
"Error saving schematic file '%s'.\n%s" ),
1055 schematicFileName.GetFullPath(),
1066 msg.Printf(
_(
"File '%s' saved." ), screen->
GetFileName() );
1067 SetStatusText( msg, 0 );
1075 const wxFileName& aOldRoot,
const wxFileName& aNewRoot,
1076 bool aSaveCopy,
bool aCopySubsheets,
bool aIncludeExternSheets,
1077 std::unordered_map<SCH_SCREEN*, wxString>& aFilenameMap,
1078 wxString& aErrorMsg )
1082 for(
size_t i = 0; i < aScreens.
GetCount(); i++ )
1086 wxCHECK2( screen,
continue );
1093 if( !src.IsAbsolute() )
1094 src.MakeAbsolute( aOldRoot.GetPath() );
1096 bool internalSheet = src.GetPath().StartsWith( aOldRoot.GetPath() );
1098 if( aCopySubsheets && ( internalSheet || aIncludeExternSheets ) )
1100 wxFileName dest = src;
1102 if( internalSheet && dest.MakeRelativeTo( aOldRoot.GetPath() ) )
1103 dest.MakeAbsolute( aNewRoot.GetPath() );
1105 dest.Assign( aNewRoot.GetPath(), dest.GetFullName() );
1108 wxS(
"Moving schematic from '%s' to '%s'." ),
1110 dest.GetFullPath() );
1112 if( !dest.DirExists() && !dest.Mkdir() )
1114 aErrorMsg.Printf(
_(
"Folder '%s' could not be created.\n\n"
1115 "Make sure you have write permissions and try again." ),
1121 aFilenameMap[screen] = dest.GetFullPath();
1128 aFilenameMap[screen] = wxString();
1136 if( !sheet.Last()->IsTopLevelSheet() )
1137 sheet.MakeFilePathRelativeToParentSheet();
1149 bool success =
true;
1150 bool updateFileHistory =
false;
1151 bool createNewProject =
false;
1152 bool copySubsheets =
false;
1153 bool includeExternSheets =
false;
1157 wxFileName fn = fileName;
1161 std::unordered_map<SCH_SCREEN*, wxString> filenameMap;
1164 if(
Prj().IsNullProject() || aSaveAs )
1167 wxCHECK(
Kiface().IsSingle() || aSaveAs,
false );
1169 wxFileName newFileName;
1170 wxFileName savePath(
Prj().GetProjectFullName() );
1172 if( !savePath.IsOk() || !savePath.IsDirWritable() )
1176 if( !savePath.IsOk() || !savePath.IsDirWritable() )
1180 if( savePath.HasExt() )
1183 savePath.SetName( wxEmptyString );
1185 wxFileDialog dlg(
this,
_(
"Schematic Files" ), savePath.GetPath(), savePath.GetFullName(),
1187 wxFD_SAVE | wxFD_OVERWRITE_PROMPT );
1192 if(
Kiface().IsSingle() || aSaveAs )
1194 dlg.SetCustomizeHook( newProjectHook );
1199 if( dlg.ShowModal() == wxID_CANCEL )
1204 if( ( !newFileName.DirExists() && !newFileName.Mkdir() ) ||
1205 !newFileName.IsDirWritable() )
1207 msg.Printf(
_(
"Folder '%s' could not be created.\n\n"
1208 "Make sure you have write permissions and try again." ),
1209 newFileName.GetPath() );
1212 wxOK | wxICON_EXCLAMATION | wxCENTER );
1214 dlgBadPath.ShowModal();
1229 updateFileHistory =
true;
1237 copySubsheets, includeExternSheets, filenameMap, msg ) )
1240 wxOK | wxICON_EXCLAMATION | wxCENTER );
1242 dlgBadFilePath.ShowModal();
1246 else if( !fn.FileExists() )
1249 updateFileHistory =
true;
1260 if( filenameMap.empty() || !saveCopy )
1262 for(
size_t i = 0; i < screens.
GetCount(); i++ )
1267 wxArrayString overwrittenFiles;
1268 wxArrayString lockedFiles;
1270 for(
size_t i = 0; i < screens.
GetCount(); i++ )
1274 wxCHECK2( screen,
continue );
1277 wxFileName tmpFn = filenameMap[screen];
1282 if( tmpFn.FileExists() && !tmpFn.IsFileWritable() )
1283 lockedFiles.Add( tmpFn.GetFullPath() );
1290 if( tmpFn.FileExists() )
1291 overwrittenFiles.Add( tmpFn.GetFullPath() );
1294 if( !lockedFiles.IsEmpty() )
1296 for(
const wxString& lockedFile : lockedFiles )
1301 msg +=
"\n" + lockedFile;
1304 wxRichMessageDialog dlg(
this, wxString::Format(
_(
"Failed to save %s." ),
1306 _(
"Locked File Warning" ),
1307 wxOK | wxICON_WARNING | wxCENTER );
1308 dlg.SetExtendedMessage(
_(
"You do not have write permissions to:\n\n" ) + msg );
1314 if( !overwrittenFiles.IsEmpty() )
1316 for(
const wxString& overwrittenFile : overwrittenFiles )
1319 msg = overwrittenFile;
1321 msg +=
"\n" + overwrittenFile;
1324 wxRichMessageDialog dlg(
this,
_(
"Saving will overwrite existing files." ),
1325 _(
"Save Warning" ),
1326 wxOK | wxCANCEL | wxCANCEL_DEFAULT | wxCENTER |
1327 wxICON_EXCLAMATION );
1328 dlg.ShowDetailedText(
_(
"The following files will be overwritten:\n\n" ) + msg );
1329 dlg.SetOKCancelLabels( KICAD_MESSAGE_DIALOG::ButtonLabel(
_(
"Overwrite Files" ) ),
1330 KICAD_MESSAGE_DIALOG::ButtonLabel(
_(
"Abort Project Save" ) ) );
1332 if( dlg.ShowModal() == wxID_CANCEL )
1338 std::vector<wxString> savedSheetPaths;
1340 for(
size_t i = 0; i < screens.
GetCount(); i++ )
1344 wxCHECK2( screen,
continue );
1347 wxFileName tmpFn = filenameMap[screen];
1351 updateFileHistory =
true;
1359 if( !sheetFileName.IsOk()
1364 sheet->
SetFileName( sheetFileName.GetFullPath() );
1368 filenameMap[screen] = tmpFn.GetFullPath();
1380 if( sheets.size() == 1 )
1386 if( !saveCopy && tmpFn.GetFullPath() != screen->
GetFileName() )
1391 if( savedThisSheet )
1392 savedSheetPaths.push_back( tmpFn.GetFullPath() );
1394 success &= savedThisSheet;
1406 if( aSaveAs && success )
1409 if( updateFileHistory )
1420 wxCHECK2( sheet,
continue );
1425 sheets.emplace_back( std::make_pair( sheet->
m_Uuid, sheet->
GetName() ) );
1429 wxASSERT( filenameMap.count(
Schematic().RootScreen() ) );
1430 wxFileName projectPath( filenameMap.at(
Schematic().RootScreen() ) );
1433 if(
Prj().IsNullProject() || ( aSaveAs && !saveCopy ) )
1438 else if( saveCopy && createNewProject )
1451 if( success && !
Prj().IsNullProject() )
1464 if( !
Kiface().IsSingle() )
1474 if(
m_infoBar->GetMessageType() == WX_INFOBAR::MESSAGE_TYPE::OUTDATED_SAVE )
1482 const std::map<std::string, UTF8>* aProperties )
1484 wxFileName filename( aFileName );
1485 wxFileName newfilename;
1486 SCH_IO_MGR::SCH_FILE_T
fileType = (SCH_IO_MGR::SCH_FILE_T) aFileType;
1488 wxCommandEvent changingEvt( EDA_EVT_SCHEMATIC_CHANGING );
1489 ProcessEventLocally( changingEvt );
1492 statusBar->ClearWarningMessages(
"load" );
1497 std::unique_ptr<SCHEMATIC> newSchematic = std::make_unique<SCHEMATIC>( &
Prj() );
1501 case SCH_IO_MGR::SCH_ALTIUM:
1502 case SCH_IO_MGR::SCH_CADSTAR_ARCHIVE:
1503 case SCH_IO_MGR::SCH_EAGLE:
1504 case SCH_IO_MGR::SCH_LTSPICE:
1505 case SCH_IO_MGR::SCH_EASYEDA:
1506 case SCH_IO_MGR::SCH_EASYEDAPRO:
1507 case SCH_IO_MGR::SCH_PADS:
1508 case SCH_IO_MGR::SCH_GEDA:
1509 case SCH_IO_MGR::SCH_DIPTRACE:
1513 wxCHECK_MSG( aFileName.IsEmpty() || filename.IsAbsolute(),
false,
1514 wxS(
"Import schematic: path is not absolute!" ) );
1525 this, std::placeholders::_1 ) );
1528 if(
eeconfig()->m_System.show_import_issues )
1533 pi->SetProgressReporter( &progressReporter );
1535 SCH_SHEET* loadedSheet = pi->LoadSchematicFile( aFileName, newSchematic.get(),
nullptr,
1543 bool loadedIsTopLevel = std::find( topLevelSheets.begin(), topLevelSheets.end(), loadedSheet )
1544 != topLevelSheets.end();
1545 bool loadedIsVirtualRoot = loadedSheet == &
Schematic().
Root()
1550 if( !loadedIsTopLevel && !loadedIsVirtualRoot )
1565 newfilename.SetPath(
Prj().GetProjectPath() );
1566 newfilename.SetName(
Prj().GetProjectName() );
1572 topSheet->SetFileName( newfilename.GetFullName() );
1577 progressReporter.
Report(
_(
"Updating connections..." ) );
1599 wxString msg = wxString::Format(
_(
"Error loading schematic '%s'." ), aFileName );
1602 msg.Printf(
_(
"Failed to load '%s'." ), aFileName );
1605 catch(
const std::exception& exc )
1610 wxString msg = wxString::Format(
_(
"Unhandled exception occurred loading schematic "
1611 "'%s'." ), aFileName );
1614 msg.Printf(
_(
"Failed to load '%s'." ), aFileName );
1638 wxCommandEvent e( EDA_EVT_SCHEMATIC_CHANGED );
1639 ProcessEventLocally( e );
1643 wxCHECK2( listener,
continue );
1647 wxWindow* win =
dynamic_cast<wxWindow*
>( listener );
1650 win->HandleWindowEvent( e );
1652 listener->SafelyProcessEvent( e );
1658 statusBar->AddWarningMessages(
"load", loadReporter.
GetMessages() );
1682 if( simFrame && !simFrame->Close() )
1685 if( screen->IsContentModified() )
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
static TOOL_ACTION zoomFitScreen
void SetVirtualPageNumber(int aPageNumber)
static wxString m_DrawingSheetFileName
the name of the drawing sheet file, or empty to use the default drawing sheet
void SetContentModified(bool aModified=true)
Class DIALOG_HTML_REPORTER.
WX_HTML_REPORT_BOX * m_Reporter
static std::vector< IMPORT_PROJECT_DESC > RunModal(wxWindow *aParent, const std::vector< IMPORT_PROJECT_DESC > &aProjectDesc)
Create and show a dialog (modal) and returns the data from it after completion.
Handle the graphic items list to draw/plot the frame and title block.
static DS_DATA_MODEL & GetTheInstance()
Return the instance of DS_DATA_MODEL used in the application.
void LoadWindowState(const wxString &aFileName)
void CheckForAutosaveFiles(const wxString &aProjectPath, const std::vector< wxString > &aExtensions)
Check for autosave files newer than their source files for the given project.
virtual void ClearUndoRedoList()
Clear the undo and redo list using ClearUndoORRedoList()
SETTINGS_MANAGER * GetSettingsManager() const
wxTimer * m_autoSaveTimer
void UpdateFileHistory(const wxString &FullFileName, FILE_HISTORY *aFileHistory=nullptr)
Update the list of recently opened files.
wxString GetMruPath() const
bool IsWritable(const wxFileName &aFileName, bool aVerbose=true)
Check if aFileName can be written.
std::unique_ptr< LOCKFILE > m_file_checker
void SetMsgPanel(const std::vector< MSG_PANEL_ITEM > &aList)
Clear the message panel and populates it with the contents of aList.
void RefreshCanvas() override
bool LockFile(const wxString &aFileName)
Mark a schematic file as being in use.
A base class for most all the KiCad significant classes used in schematics and boards.
EE_TYPE OfType(KICAD_T aType) const
bool GetCreateNewProject() const
Gets the selected state of the copy subsheets option.
bool GetCopySubsheets() const
Gets the selected state of the include external sheets option.
bool IsAttachedToDialog() const
bool GetIncludeExternSheets() const
Gets if this hook has attached controls to a dialog box.
bool GetShowIssues() const
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
virtual const wxString What() const
A composite of Problem() and Where()
virtual const wxString Problem() const
what was the problem?
APP_SETTINGS_BASE * KifaceSettings() const
bool IsSingle() const
Is this KIFACE running under single_top?
wxString AsString() const
virtual KIWAY_PLAYER * Player(FRAME_T aFrameType, bool doCreate=true, wxTopLevelWindow *aParent=nullptr)
Return the KIWAY_PLAYER* given a FRAME_T.
virtual KIFACE * KiFACE(FACE_T aFaceId, bool doLoad=true)
Return the KIFACE* given a FACE_T.
LOCAL_HISTORY & LocalHistory()
Return the LOCAL_HISTORY associated with this KIWAY.
A collection of #SYMBOL_LIB objects.
static void GetLibNamesAndPaths(PROJECT *aProject, wxString *aPaths, wxArrayString *aNames=nullptr)
static void SetLibNamesAndPaths(PROJECT *aProject, const wxString &aPaths, const wxArrayString &aNames)
std::optional< LIB_STATUS > GetLibraryStatus(const wxString &aNickname) const
Returns the status of a loaded library, or nullopt if the library hasn't been loaded (yet)
std::optional< LIBRARY_TABLE * > ProjectTable() const
Retrieves the project library table for this adapter type, or nullopt if one doesn't exist.
std::vector< wxString > GetLibraryNames() const
Returns a list of library nicknames that are available (skips any that failed to load)
void SetNickname(const wxString &aNickname)
void SetType(const wxString &aType)
void SetDescription(const wxString &aDescription)
void SetURI(const wxString &aUri)
A logical library item identifier and consists of various portions much like a URI.
int SetLibItemName(const UTF8 &aLibItemName)
Override the library item name portion of the LIB_ID to aLibItemName.
int SetLibNickname(const UTF8 &aLibNickname)
Override the logical library name portion of the LIB_ID to aLibNickname.
bool RunRegisteredSaversAndCommit(const wxString &aProjectPath, const wxString &aTitle, const wxString &aTagFileType=wxEmptyString)
Run all registered savers and, if any staged changes differ from HEAD, create a commit.
bool Init(const wxString &aProjectPath)
Initialize the local history repository for the given project path.
void RemoveAutosaveFiles(const wxString &aProjectPath) const
Remove every autosave file under the project at aProjectPath regardless of which source it shadowed.
static REPORTER & GetInstance()
static wxString GetDefaultUserProjectsPath()
Gets the default path we point users to create projects.
void PreloadDesignBlockLibraries(KIWAY *aKiway)
Starts a background job to preload the global and project design block libraries.
A small class to help profiling.
void Show(std::ostream &aStream=std::cerr)
Print the elapsed time (in a suitable unit) to a stream.
virtual void Report(const wxString &aMessage) override
Display aMessage in the progress bar dialog.
bool KeepRefreshing(bool aWait=false) override
Update the UI dialog.
Plugin class for import plugins that support choosing a project.
The backing store for a PROJECT, in JSON format.
std::vector< FILE_INFO_PAIR > & GetSheets()
std::vector< TOP_LEVEL_SHEET_INFO > & GetTopLevelSheets()
static SYMBOL_LIBRARY_ADAPTER * SymbolLibAdapter(PROJECT *aProject)
Accessor for project symbol library manager adapter.
static LEGACY_SYMBOL_LIBS * LegacySchLibs(PROJECT *aProject)
Returns the list of symbol libraries from a legacy (pre-5.x) design This is only used from the remapp...
virtual void SetReadOnly(bool aReadOnly=true)
virtual const wxString GetProjectFullName() const
Return the full path and name of the project.
virtual void SetElem(PROJECT::ELEM aIndex, _ELEM *aElem)
virtual const wxString GetProjectName() const
Return the short name of the project.
virtual PROJECT_FILE & GetProjectFile() const
virtual const wxString AbsolutePath(const wxString &aFileName) const
Fix up aFileName if it is relative to the project's directory to be an absolute path and filename.
Holds all the data relating to one schematic.
void Reset()
Initialize this schematic to a blank one, unloading anything existing.
void ResolveERCExclusionsPostUpdate()
Update markers to match recorded exclusions.
void LoadVariants()
This is a throw away method for variant testing.
int FixupJunctionsAfterImport()
Add junctions to this schematic where required.
SCH_SHEET_LIST Hierarchy() const
Return the full schematic flattened hierarchical sheet list.
void SetProject(PROJECT *aPrj)
CONNECTION_GRAPH * ConnectionGraph() const
SCH_SCREEN * RootScreen() const
Helper to retrieve the screen of the root sheet.
void SetTopLevelSheets(const std::vector< SCH_SHEET * > &aSheets)
std::vector< SCH_SHEET * > GetTopLevelSheets() const
Get the list of top-level sheets.
SCH_DRAW_PANEL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
void SyncView()
Mark all items for refresh.
EESCHEMA_SETTINGS * eeconfig() const
Class for a bus to bus entry.
VECTOR2I GetPosition() const override
void DisplaySheet(SCH_SCREEN *aScreen)
bool IsContentModified() const override
Get if the current schematic has been modified but not saved.
void OnModify() override
Must be called after a schematic change in order to set the "modify" flag and update other data struc...
void SaveProjectLocalSettings() override
Save changes to the project settings to the project (.pro) file.
bool OpenProjectFiles(const std::vector< wxString > &aFileSet, int aCtl=0) override
Open a project or set of files given by aFileList.
SCH_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
void SetScreen(BASE_SCREEN *aScreen) override
bool AskToSaveChanges()
Check if any of the screens has unsaved changes and asks the user whether to save or drop them.
friend class SCH_EDITOR_CONTROL
void SetCurrentVariant(const wxString &aVariantName)
void UpdateVariantSelectionCtrl(const wxArrayString &aVariantNames)
Update the variant name control on the main toolbar.
std::vector< wxEvtHandler * > m_schematicChangeListeners
void CreateDefaultScreens()
PANEL_REMOTE_SYMBOL * m_remoteSymbolPane
SCHEMATIC * m_schematic
The currently loaded schematic.
SCH_SHEET_PATH & GetCurrentSheet() const
void RecalculateConnections(SCH_COMMIT *aCommit, SCH_CLEANUP_FLAGS aCleanupFlags, PROGRESS_REPORTER *aProgressReporter=nullptr)
Generate the connection data for the entire schematic hierarchy.
void ProjectChanged() override
Notification event that the project has changed.
SCHEMATIC & Schematic() const
void updateTitle()
Set the main window title bar text.
void SetSchematic(SCHEMATIC *aSchematic)
bool saveSchematicFile(SCH_SHEET *aSheet, const wxString &aSavePath)
Save aSheet to a schematic file.
bool LoadProjectSettings()
Load the KiCad project file (*.pro) settings specific to Eeschema.
void RefreshNetNavigator(const NET_NAVIGATOR_ITEM_DATA *aSelection=nullptr)
void RecomputeIntersheetRefs()
Update the schematic's page reference map for all global labels, and refresh the labels so that they ...
void UpdateHierarchyNavigator(bool aRefreshNetNavigator=true, bool aClear=false)
Update the hierarchy navigation tree and history.
bool importFile(const wxString &aFileName, int aFileType, const std::map< std::string, UTF8 > *aProperties=nullptr)
Load the given filename but sets the path to the current project path.
void LoadDrawingSheet()
Load the drawing sheet file.
void SetSheetNumberAndCount()
Set the m_ScreenNumber and m_NumberOfScreens members for screens.
void ClearRepeatItemsList()
Clear the list of items which are to be repeated with the insert key.
wxGenericTreeCtrl * m_netNavigator
void initScreenZoom()
Initialize the zoom value of the current screen and mark the screen as zoom-initialized.
void UpdateItem(EDA_ITEM *aItem, bool isAddOrDelete=false, bool aUpdateRtree=false) override
Mark an item for refresh.
wxString GetCurrentFileName() const override
Get the full filename + path of the currently opened file in the frame.
void TestDanglingEnds()
Test all of the connectable objects in the schematic for unused connection points.
bool SaveProject(bool aSaveAs=false)
Save the currently-open schematic (including its hierarchy) and associated project.
void saveProjectSettings() override
Save any design-related project settings associated with this frame.
static const wxString ShowType(SCH_FILE_T aFileType)
Return a brief name for a plugin, given aFileType enum.
static SCH_FILE_T GuessPluginTypeFromSchPath(const wxString &aSchematicPath, int aCtl=0)
Return a plugin type given a schematic using the file extension of aSchematicPath.
Base class for any item which can be embedded within the SCHEMATIC container class,...
Container class that holds multiple SCH_SCREEN objects in a hierarchy.
SCH_SCREEN * GetScreen(unsigned int aIndex) const
void BuildClientSheetPathList()
Build the list of sheet paths sharing a screen for each screen in use.
SCH_SHEET * GetSheet(unsigned int aIndex) const
void ClearDrawingState()
Clear the state flags of all the items in the screen.
std::vector< SCH_SHEET_PATH > & GetClientSheetPaths()
Return the number of times this screen is used.
void TestDanglingEnds(const SCH_SHEET_PATH *aPath=nullptr, std::function< void(SCH_ITEM *)> *aChangedHandler=nullptr) const
Test all of the connectable objects in the schematic for unused connection points.
EE_RTREE & Items()
Get the full RTree, usually for iterating.
const wxString & GetFileName() const
void UpdateLocalLibSymbolLinks()
Initialize the LIB_SYMBOL reference for each SCH_SYMBOL found in this schematic with the local projec...
void SetFileName(const wxString &aFileName)
Set the file name for this screen to aFileName.
const std::vector< SCH_SYMBOL_INSTANCE > & GetSymbolInstances() const
int GetFileFormatVersionAtLoad() const
const std::vector< SCH_SHEET_INSTANCE > & GetSheetInstances() const
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
void UpdateSheetInstanceData(const std::vector< SCH_SHEET_INSTANCE > &aSheetInstances)
Update all of the sheet instance information using aSheetInstances.
void SetInitialPageNumbers()
Set initial sheet page numbers.
bool AllSheetPageNumbersEmpty() const
Check all of the sheet instance for empty page numbers.
bool IsModified() const
Check the entire hierarchy for any modifications.
void UpdateSymbolInstanceData(const std::vector< SCH_SYMBOL_INSTANCE > &aSymbolInstances)
Update all of the symbol instance information using aSymbolInstances.
void CheckForMissingSymbolInstances(const wxString &aProjectName)
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
void UpdateAllScreenReferences() const
Update all the symbol references for this sheet path.
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
void SetFileName(const wxString &aFilename)
wxString GetFileName() const
Return the filename corresponding to this sheet.
void SetName(const wxString &aName)
SCH_SCREEN * GetScreen() const
bool IsVirtualRootSheet() const
void SetLibId(const LIB_ID &aName)
const LIB_ID & GetLibId() const override
void SaveProjectAs(const wxString &aFullPath, PROJECT *aProject=nullptr)
Set the currently loaded project path and saves it (pointers remain valid).
bool SaveProject(const wxString &aFullPath=wxEmptyString, PROJECT *aProject=nullptr)
Save a loaded project.
bool SaveProjectCopy(const wxString &aFullPath, PROJECT *aProject=nullptr)
Save a copy of the current project under the given path.
bool LoadProject(const wxString &aFullPath, bool aSetActive=true)
Load a project or sets up a new project with a specified path.
bool UnloadProject(PROJECT *aProject, bool aSave=true)
Save, unload and unregister the given PROJECT.
The SIMULATOR_FRAME holds the main user-interface for running simulations.
An interface to the global shared library manager that is schematic-specific and linked to one projec...
LIB_SYMBOL * LoadSymbol(const wxString &aNickname, const wxString &aName)
Load a LIB_SYMBOL having aName from the library given by aNickname.
std::vector< wxString > GetSymbolNames(const wxString &aNickname, SYMBOL_TYPE aType=SYMBOL_TYPE::ALL_SYMBOLS)
An 8 bit string that is assuredly encoded in UTF8, and supplies special conversion support to and fro...
Temporarily disable a window, and then re-enable on destruction.
static void ResolvePossibleSymlinks(wxFileName &aFilename)
void Flush()
Build the HTML messages page.
bool HasMessage() const override
Returns true if any messages were reported.
Multi-thread safe progress reporter dialog, intended for use of tasks that parallel reporting back of...
A wrapper for reporting to a wxString object.
const wxString & GetMessages() const
wxString EnsureFileExtension(const wxString &aFilename, const wxString &aExtension)
It's annoying to throw up nag dialogs when the extension isn't right.
bool AskOverrideLock(wxWindow *aParent, const wxString &aMessage)
Display a dialog indicating the file is already open, with an option to reset the lock.
bool IsOK(wxWindow *aParent, const wxString &aMessage)
Display a yes/no dialog with aMessage and returns the user response.
void DisplayInfoMessage(wxWindow *aParent, const wxString &aMessage, const wxString &aExtraInfo)
Display an informational message box with aMessage.
bool HandleUnsavedChanges(wxWindow *aParent, const wxString &aMessage, const std::function< bool()> &aSaveFunction)
Display a dialog with Save, Cancel and Discard Changes buttons.
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
void DisplayError(wxWindow *aParent, const wxString &aText)
Display an error or warning message box with aMessage.
This file is part of the common library.
#define KICAD_MESSAGE_DIALOG
static bool empty(const wxTextEntryBase *aCtrl)
bool PrepareSaveAsFiles(SCHEMATIC &aSchematic, SCH_SCREENS &aScreens, const wxFileName &aOldRoot, const wxFileName &aNewRoot, bool aSaveCopy, bool aCopySubsheets, bool aIncludeExternSheets, std::unordered_map< SCH_SCREEN *, wxString > &aFilenameMap, wxString &aErrorMsg)
static const std::string LegacySchematicFileExtension
static const std::string ProjectFileExtension
static const std::string LegacyProjectFileExtension
static const std::string KiCadSchematicFileExtension
static const std::string LegacySymbolLibFileExtension
static wxString KiCadSchematicFileWildcard()
const wxChar *const traceSchCurrentSheet
Flag to enable debug output of current sheet tracking in the schematic editor.
const wxChar *const traceAutoSave
Flag to enable auto save feature debug tracing.
const wxChar *const tracePathsAndFiles
Flag to enable path and file name debug output.
std::unique_ptr< T > IO_RELEASER
Helper to hold and release an IO_BASE object when exceptions are thrown.
#define THROW_IO_ERROR(msg)
macro which captures the "call site" values of FILE_, __FUNCTION & LINE
#define KICTL_CREATE
caller thinks requested project files may not exist.
#define KICTL_KICAD_ONLY
chosen file is from KiCad according to user
PGM_BASE & Pgm()
The global program "get" accessor.
#define SEXPR_SCHEMATIC_FILE_VERSION
Schematic file version.
Definition of the SCH_SHEET_PATH and SCH_SHEET_LIST classes for Eeschema.
KIWAY Kiway(KFCTL_STANDALONE)
std::vector< FAB_LAYER_COLOR > dummy
MODEL3D_FORMAT_TYPE fileType(const char *aFileName)
bool show_import_issues
Stored value for "show import issues" when importing non-KiCad designs to this application.
bool show_illegal_symbol_lib_dialog
Container that describes file type info.
std::vector< std::string > m_FileExtensions
Filter used for file pickers if m_IsFile is true.
bool m_CanRead
Whether the IO can read this file type.
wxString FileFilter() const
Implement a participant in the KIWAY alchemy.
virtual void PreloadLibraries(KIWAY *aKiway)
Information about a top-level schematic sheet.
std::vector< std::vector< std::string > > table
wxLogTrace helper definitions.
wxString formatWildcardExt(const wxString &aWildcard)
Format wildcard extension to support case sensitive file dialogs.
Definition of file extensions used in Kicad.