67#include <wx/tokenzr.h>
101static int eeschemaMergeExport(
int aKind,
const wxString& aAncestor,
const wxString& aOurs,
102 const wxString& aTheirs,
const wxString& aOutput,
bool aInteractive,
103 bool aSingleFile,
REPORTER* aReporter );
105 const wxString& aLabelA,
const wxString& aLabelB,
106 wxWindow* aParent,
REPORTER* aReporter );
113 SCH_IO* pi = SCH_IO_MGR::FindPlugin( SCH_IO_MGR::SCH_KICAD );
114 std::unique_ptr<SCHEMATIC> schematic = std::make_unique<SCHEMATIC>(
nullptr );
118 wxFileName pro( aFilename );
121 wxString projectPath = pro.GetFullPath();
132 schematic->SetProject(
project );
138 std::vector<SCH_SHEET*> topLevelSheets = schematic->GetTopLevelSheets();
139 bool rootIsTopLevel = std::find( topLevelSheets.begin(), topLevelSheets.end(), rootSheet )
140 != topLevelSheets.end();
141 bool rootIsVirtualRoot = rootSheet == &schematic->Root() || rootSheet->
IsVirtualRootSheet();
143 if( !rootIsTopLevel && !rootIsVirtualRoot )
144 schematic->SetTopLevelSheets( { rootSheet } );
149 screen->UpdateLocalLibSymbolLinks();
156 if( schematic->RootScreen()->GetFileFormatVersionAtLoad() < 20230221 )
159 screen->FixLegacyPowerSymbolMismatches();
163 screen->MigrateSimModels();
169 sheet.UpdateAllScreenReferences();
177 schematic->ConnectionGraph()->Recalculate( sheets,
true );
209 void Reset()
override;
233 return new SYMBOL_EDIT_FRAME( aKiway, aParent );
239 SIMULATOR_FRAME* frame =
new SIMULATOR_FRAME( aKiway, aParent );
255 bool cancelled =
false;
310 return new PANEL_SYM_EDITING_OPTIONS( aParent,
this, frame );
318 std::vector<TOOL_ACTION*> actions;
319 std::vector<ACTION_TOOLBAR_CONTROL*> controls;
322 actions.push_back( action );
325 controls.push_back( control );
331 return new PANEL_SYM_COLOR_SETTINGS( aParent );
350 return new PANEL_GRID_SETTINGS( aParent,
this, frame, cfg,
FRAME_SCH );
366 return new PANEL_EESCHEMA_EDITING_OPTIONS( aParent,
this, frame );
374 std::vector<TOOL_ACTION*> actions;
375 std::vector<ACTION_TOOLBAR_CONTROL*> controls;
378 actions.push_back( action );
381 controls.push_back( control );
383 return new PANEL_TOOLBAR_CUSTOMIZATION( aParent, cfg, tb,
FRAME_SCH, actions, controls );
387 return new PANEL_EESCHEMA_COLOR_SETTINGS( aParent );
390 return new PANEL_TEMPLATE_FIELDNAMES( aParent,
nullptr );
406 return new PANEL_SIMULATOR_PREFERENCES( aParent );
448 void SaveFileAs(
const wxString& aProjectBasePath,
const wxString& aProjectName,
449 const wxString& aNewProjectBasePath,
const wxString& aNewProjectName,
450 const wxString& aSrcFilePath, wxString& aErrors )
override;
459 wxString* aError )
override;
463 wxString* aError )
override;
487 const wxString& aTheirs,
const wxString& aOutput,
bool aInteractive,
488 bool aSingleFile,
REPORTER* aReporter )
491 aOurs, aTheirs, aOutput, aInteractive, aSingleFile,
497 const wxString& aLabelA,
const wxString& aLabelB,
498 wxWindow* aParent,
REPORTER* aReporter )
501 aFileB, aLabelA, aLabelB, aParent, aReporter );
541 m_jobHandler = std::make_unique<EESCHEMA_JOBS_HANDLER>( aKiway );
566 constexpr static int interval = 150;
567 constexpr static int timeLimit = 120000;
585 [
this, aKiway]() ->
void
587 std::shared_ptr<BACKGROUND_JOB_REPORTER>
reporter =
593 bool aborted =
false;
595 reporter->Report(
_(
"Loading Symbol Libraries" ) );
607 std::this_thread::sleep_for( std::chrono::milliseconds( interval ) );
611 float progress = *loadStatus;
612 reporter->SetCurrentProgress( progress );
625 if( elapsed > timeLimit )
646 wxLogTrace(
traceLibraries,
"eeschema PreloadLibraries: errors.IsEmpty()=%d, length=%zu",
647 errors.IsEmpty(), errors.length() );
651 if( !messages.empty() )
653 wxLogTrace(
traceLibraries,
" -> collected %zu messages, calling AddLibraryLoadMessages",
659 wxLogTrace(
traceLibraries,
" -> no errors from symbol libraries" );
664 wxLogTrace(
traceLibraries,
"eeschema PreloadLibraries: aborted, skipping symbol processing" );
674 std::string payload =
"";
681 std::future<void> preloadFuture = std::async( std::launch::async, preload );
712 const wxString& aNewProjectBasePath,
const wxString& aNewProjectName,
713 const wxString& aSrcFilePath, wxString& aErrors )
715 wxFileName destFile( aSrcFilePath );
716 wxString destPath = destFile.GetPathWithSep();
717 wxUniChar pathSep = wxFileName::GetPathSeparator();
718 wxString ext = destFile.GetExt();
720 if( destPath.StartsWith( aProjectBasePath + pathSep ) )
721 destPath.Replace( aProjectBasePath, aNewProjectBasePath,
false );
723 destFile.SetPath( destPath );
730 if( destFile.GetName() == aProjectName )
732 destFile.SetName( aNewProjectName );
734 else if( destFile.GetName() == aNewProjectName )
738 if( !aErrors.empty() )
739 aErrors += wxS(
"\n" );
741 msg.Printf(
_(
"Cannot copy file '%s' as it will be overwritten by the new root "
742 "sheet file." ), destFile.GetFullPath() );
748 [&](
const std::string& token, wxString& value ) ->
bool
750 if( token ==
"project" && value == aProjectName )
752 value = aNewProjectName;
763 KiCopyFile( aSrcFilePath, destFile.GetFullPath(), aErrors );
769 if( destFile.GetName() == aProjectName + wxS(
"-cache" ) )
770 destFile.SetName( aNewProjectName + wxS(
"-cache" ) );
772 if( destFile.GetName() == aProjectName + wxS(
"-rescue" ) )
773 destFile.SetName( aNewProjectName + wxS(
"-rescue" ) );
775 KiCopyFile( aSrcFilePath, destFile.GetFullPath(), aErrors );
779 if( destFile.GetName() == aProjectName )
780 destFile.SetName( aNewProjectName );
783 [&](
const std::string& token, wxString& value ) ->
bool
785 if( token ==
"source" )
787 for( const wxString& extension : { wxString( wxT(
".sch" ) ), wxString( wxT(
".kicad_sch" ) ) } )
789 if( value == aProjectName + extension )
791 value = aNewProjectName + extension;
794 else if( value == aProjectBasePath +
"/" + aProjectName + extension )
796 value = aNewProjectBasePath +
"/" + aNewProjectName + extension;
799 else if( value.StartsWith( aProjectBasePath ) )
801 value.Replace( aProjectBasePath, aNewProjectBasePath, false );
813 wxFileName libTableFn( aSrcFilePath );
815 libTable.SetPath( destFile.GetFullPath() );
818 for( LIBRARY_TABLE_ROW& row : libTable.Rows() )
820 wxString uri = row.URI();
822 uri.Replace( wxS(
"/" ) + aProjectName + wxS(
"-cache.lib" ),
823 wxS(
"/" ) + aNewProjectName + wxS(
"-cache.lib" ) );
824 uri.Replace( wxS(
"/" ) + aProjectName + wxS(
"-rescue.lib" ),
825 wxS(
"/" ) + aNewProjectName + wxS(
"-rescue.lib" ) );
826 uri.Replace( wxS(
"/" ) + aProjectName + wxS(
".lib" ),
827 wxS(
"/" ) + aNewProjectName + wxS(
".lib" ) );
832 libTable.Save().map_error(
833 [&](
const LIBRARY_ERROR& aError )
837 if( !aErrors.empty() )
838 aErrors += wxT(
"\n" );
840 msg.Printf(
_(
"Cannot copy file '%s'." ), destFile.GetFullPath() );
846 wxFAIL_MSG( wxS(
"Unexpected filetype for Eeschema::SaveFileAs()" ) );
853 return m_jobHandler->RunJob( aJob, aReporter, aProgressReporter );
888 wxCHECK( aServer,
false );
890 if( aPath.IsEmpty() )
893 *aError = wxS(
"No path specified to open" );
898 wxFileName projectPath( aPath );
905 projectPath.MakeAbsolute();
914 if( !settingsManager.
LoadProject( projectPath.GetFullPath(),
true ) )
916 wxLogTrace(
traceApi,
"Warning: no project file found for %s", aPath );
924 *aError = wxString::Format( wxS(
"Error loading project for %s" ), aPath );
929 wxFileName schPath( projectPath );
932 if( !schPath.FileExists() )
935 *aError = wxString::Format( wxS(
"File not found: %s" ), schPath.GetFullPath() );
949 *aError = wxS(
"Failed to load schematic" );
957 *aError = wxS(
"Failed to load schematic" );
975 wxCHECK( aServer,
false );
980 *aError = wxS(
"No document is currently open" );
985 if( !aSchFileName.IsEmpty() )
987 wxFileName currentSch(
m_openContext->GetCurrentFileName() );
989 if( currentSch.GetFullName() != aSchFileName )
992 *aError = wxS(
"Requested document does not match the open document" );
constexpr EDA_IU_SCALE schIUScale
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
static std::list< TOOL_ACTION * > & GetActionList()
Return list of TOOL_ACTIONs.
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
std::shared_ptr< BACKGROUND_JOB > Create(const wxString &aName)
Creates a background job with the given name.
void Remove(std::shared_ptr< BACKGROUND_JOB > job)
Removes the given background job from any lists and frees it.
static CLI_PROGRESS_REPORTER & GetInstance()
static CLI_REPORTER & GetInstance()
The base frame for deriving all KiCad main window classes.
static void SetSchEditFrame(SCH_EDIT_FRAME *aSchEditFrame)
static SCHEMATIC * LoadSchematic(const wxString &aFileName, bool aSetActive, bool aForceDefaultProject, PROJECT *aProject=nullptr, bool aCalculateConnectivity=true)
Handle Eeschema job dispatches.
An simple container class that lets us dispatch output jobs to kifaces.
void RegisterHandler(API_HANDLER *aHandler)
Adds a new request handler to the server.
void DeregisterHandler(API_HANDLER *aHandler)
KIFACE_BASE(const char *aKifaceName, KIWAY::FACE_T aId)
void InitSettings(APP_SETTINGS_BASE *aSettings)
void end_common()
Common things to do for a top program module, during OnKifaceEnd();.
APP_SETTINGS_BASE * KifaceSettings() const
bool start_common(int aCtlBits)
Common things to do for a top program module, during OnKifaceStart().
int m_start_flags
flags provided in OnKifaceStart()
bool IsSingle() const
Is this KIFACE running under single_top?
static int Apply(const git_merge_driver_source *aSrc, const char **aPathOut, unsigned int *aModeOut, git_buf *aMergedOut)
void CreateServer(int service, bool local=true)
bool Destroy() override
Our version of Destroy() which is virtual from wxWidgets.
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
virtual KIWAY_PLAYER * Player(FRAME_T aFrameType, bool doCreate=true, wxTopLevelWindow *aParent=nullptr)
Return the KIWAY_PLAYER* given a FRAME_T.
virtual void ExpressMail(FRAME_T aDestination, MAIL_T aCommand, std::string &aPayload, wxWindow *aSource=nullptr, bool aFromOtherThread=false)
Send aPayload to aDestination from aSource.
FACE_T
Known KIFACE implementations.
virtual PROJECT & Prj() const
Return the PROJECT associated with this KIWAY.
std::optional< float > AsyncLoadProgress() const
Returns async load progress between 0.0 and 1.0, or nullopt if load is not in progress.
void AbortAsyncLoad()
Aborts any async load in progress; blocks until fully done aborting.
wxString GetLibraryLoadErrors() const
Returns all library load errors as newline-separated strings for display.
void AsyncLoad()
Loads all available libraries for this adapter type in the background.
Generate the KiCad netlist format supported by Pcbnew.
void Format(OUTPUTFORMATTER *aOutputFormatter, int aCtl)
Output this s-expression netlist into aOutputFormatter.
Container for data for KiCad programs.
virtual BACKGROUND_JOBS_MONITOR & GetBackgroundJobMonitor() const
void ClearLibraryLoadMessages()
Clear library load messages from all registered status bars.
void AddLibraryLoadMessages(const std::vector< LOAD_MESSAGE > &aMessages)
Add library load messages to all registered status bars.
virtual SETTINGS_MANAGER & GetSettingsManager() const
A progress reporter interface for use in multi-threaded environments.
static SYMBOL_LIBRARY_ADAPTER * SymbolLibAdapter(PROJECT *aProject)
Accessor for project symbol library manager adapter.
Container for project specific data.
A pure virtual class used to derive REPORTER objects from.
Holds all the data relating to one schematic.
Schematic editor (Eeschema) main window.
Base class that schematic file and library loading and saving plugins should derive from.
virtual SCH_SHEET * LoadSchematicFile(const wxString &aFileName, SCHEMATIC *aSchematic, SCH_SHEET *aAppendToMe=nullptr, const std::map< std::string, UTF8 > *aProperties=nullptr)
Load information from some input file format that this SCH_IO implementation knows about,...
Container class that holds multiple SCH_SCREEN objects in a hierarchy.
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
void AnnotatePowerSymbols()
Silently annotate the not yet annotated power symbols of the entire hierarchy of the sheet path list.
void UpdateSymbolInstanceData(const std::vector< SCH_SYMBOL_INSTANCE > &aSymbolInstances)
Update all of the symbol instance information using aSymbolInstances.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
bool IsVirtualRootSheet() const
T * RegisterSettings(T *aSettings, bool aLoadNow=true)
Take ownership of the pointer passed in.
bool LoadProject(const wxString &aFullPath, bool aSetActive=true)
Load a project or sets up a new project with a specified path.
PROJECT * GetProject(const wxString &aFullPath) const
Retrieve a loaded project by name.
Simple error container for failure to init the simulation engine and ultimately abort the frame const...
Symbol library viewer main window.
An interface to the global shared library manager that is schematic-specific and linked to one projec...
Symbol library viewer main window.
UNITS_PROVIDER(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits)
EDA_UNITS GetUserUnits() const
void SetUserUnits(EDA_UNITS aUnits)
This file is part of the common library.
#define KICAD_SCH_PORT_SERVICE_NUMBER
Eeschema listens on this port for commands from Pcbnew.
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
@ FRAME_SCH_SYMBOL_EDITOR
@ PANEL_SCH_FIELD_NAME_TEMPLATES
@ DIALOG_SCH_LIBRARY_TABLE
@ DIALOG_DESIGN_BLOCK_LIBRARY_TABLE
void CopySexprFile(const wxString &aSrcPath, const wxString &aDestPath, std::function< bool(const std::string &token, wxString &value)> aCallback, wxString &aErrors)
void KiCopyFile(const wxString &aSrcPath, const wxString &aDestPath, wxString &aErrors)
static const std::string LegacySchematicFileExtension
static const std::string NetlistFileExtension
static const std::string SymbolLibraryTableFileName
static const std::string ProjectFileExtension
static const std::string SchematicSymbolFileExtension
static const std::string KiCadSchematicFileExtension
static const std::string LegacySymbolLibFileExtension
static const std::string KiCadSymbolLibFileExtension
static const std::string BackupFileSuffix
static const std::string LegacySymbolDocumentFileExtension
const wxChar *const traceLibraries
Flag to enable library table and library manager tracing.
const wxChar *const traceApi
Flag to enable debug output related to the IPC API and its plugin system.
@ KIFACE_MERGE_DOCUMENT
int (*)( int aKind, const wxString& aAncestor, const wxString& aOurs, const wxString& aTheirs,...
@ KIFACE_NETLIST_SCHEMATIC
@ KIFACE_OPEN_DIFF_DIALOG
int (*)( int aKind, const wxString& aFileA, const wxString& aFileB, const wxString& aLabelA,...
#define KFCTL_CLI
Running as CLI app.
DOC_KIND
Document type a diff/merge entry point should route to, derived from a file path's extension.
bool RegisterMergeDriver(const char *aName, MERGE_APPLY_FN aApply)
Register a KiCad merge driver with libgit2.
static int eeschemaMergeExport(int aKind, const wxString &aAncestor, const wxString &aOurs, const wxString &aTheirs, const wxString &aOutput, bool aInteractive, bool aSingleFile, REPORTER *aReporter)
static std::unique_ptr< SCHEMATIC > readSchematicFromFile(const std::string &aFilename)
SCH::IFACE KIFACE_BASE, UNITS_PROVIDER kiface("eeschema", KIWAY::FACE_SCH)
bool generateSchematicNetlist(const wxString &aFilename, std::string &aNetlist)
static int eeschemaOpenDiffDialogExport(int aKind, const wxString &aFileA, const wxString &aFileB, const wxString &aLabelA, const wxString &aLabelB, wxWindow *aParent, REPORTER *aReporter)
void InvokeEditDesignBlockLibTable(KIWAY *aKiway, wxWindow *aParent)
void InvokeSchEditSymbolLibTable(KIWAY *aKiway, wxWindow *aParent)
PGM_BASE & Pgm()
The global program "get" accessor.
T * GetToolbarSettings(const wxString &aFilename)
T * GetAppSettings(const char *aFilename)
std::vector< LOAD_MESSAGE > ExtractLibraryLoadErrors(const wxString &aErrorString, int aSeverity)
Parse library load error messages, extracting user-facing information while stripping internal code l...
bool OnKifaceStart(PGM_BASE *aProgram, int aCtlBits, KIWAY *aKiway) override
Typically start_common() is called from here.
Implement a participant in the KIWAY alchemy.
std::future< void > m_libraryPreloadReturn
bool OnKifaceStart(PGM_BASE *aProgram, int aCtlBits, KIWAY *aKiway) override
Typically start_common() is called from here.
std::shared_ptr< BACKGROUND_JOB > m_libraryPreloadBackgroundJob
std::unique_ptr< API_HANDLER_SCH > m_openHandler
void PreloadLibraries(KIWAY *aKiway) override
void SaveFileAs(const wxString &aProjectBasePath, const wxString &aProjectName, const wxString &aNewProjectBasePath, const wxString &aNewProjectName, const wxString &aSrcFilePath, wxString &aErrors) override
Saving a file under a different name is delegated to the various KIFACEs because the project doesn't ...
void ProjectChanged() override
void CancelPreload(bool aBlock=true) override
void closeCurrentDocument(KICAD_API_SERVER *aServer)
wxWindow * CreateKiWindow(wxWindow *aParent, int aClassId, KIWAY *aKiway, int aCtlBits=0) override
Create a wxWindow for the current project.
EESCHEMA_JOBS_HANDLER * JobHandler() const
Accessor for the non-job diff/merge exports (eeschemaMergeExport etc.).
std::atomic_bool m_libraryPreloadAbort
IFACE(const char *aName, KIWAY::FACE_T aType)
void Reset() override
Reloads global state.
bool HandleApiOpenDocument(const wxString &aPath, KICAD_API_SERVER *aServer, wxString *aError) override
bool HandleApiCloseDocument(const wxString &aSchFileName, KICAD_API_SERVER *aServer, wxString *aError) override
void * IfaceOrAddress(int aDataId) override
Return a pointer to the requested object.
int HandleJob(JOB *aJob, REPORTER *aReporter, PROGRESS_REPORTER *aProgressReporter) override
std::unique_ptr< EESCHEMA_JOBS_HANDLER > m_jobHandler
std::atomic_bool m_libraryPreloadInProgress
bool HandleJobConfig(JOB *aJob, wxWindow *aParent) override
std::shared_ptr< HEADLESS_SCH_CONTEXT > m_openContext
SCHEMATIC * m_openSchematic
void OnKifaceEnd() override
Called just once just before the DSO is to be unloaded.
IbisParser parser & reporter
VECTOR3I expected(15, 30, 45)
static const long long MM
wxLogTrace helper definitions.
Definition of file extensions used in Kicad.