Sim: Make library path textbox editable
Load the library from the path if enter is pressed or focus is lost if the library exists. If a library under the same path as previously is to be loaded this way, don't do anything. Fixes https://gitlab.com/kicad/code/kicad/issues/12970
This commit is contained in:
parent
a89102fdfc
commit
6f630f7054
|
@ -613,10 +613,16 @@ void DIALOG_SIM_MODEL<T>::removeOrphanedPinAssignments()
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
void DIALOG_SIM_MODEL<T>::loadLibrary( const wxString& aLibraryPath )
|
void DIALOG_SIM_MODEL<T>::loadLibrary( const wxString& aLibraryPath, bool aForceReload )
|
||||||
{
|
{
|
||||||
m_libraryModelsMgr.Clear();
|
auto libraries = m_libraryModelsMgr.GetLibraries();
|
||||||
m_libraryModelsMgr.CreateLibrary( std::string( aLibraryPath.ToUTF8() ) );
|
|
||||||
|
// Loading the same library as previously should normally be a no-op except when done using the
|
||||||
|
// library browse button.
|
||||||
|
if( !aForceReload && libraries.size() >= 1 && libraries.begin()->first == aLibraryPath )
|
||||||
|
return;
|
||||||
|
|
||||||
|
m_libraryModelsMgr.SetLibrary( std::string( aLibraryPath.ToUTF8() ) );
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -645,7 +651,7 @@ void DIALOG_SIM_MODEL<T>::loadLibrary( const wxString& aLibraryPath )
|
||||||
if( validator )
|
if( validator )
|
||||||
validator->SetIncludes( modelNames );
|
validator->SetIncludes( modelNames );
|
||||||
|
|
||||||
m_tclibraryPathName->ChangeValue( aLibraryPath );
|
m_libraryPathText->ChangeValue( aLibraryPath );
|
||||||
m_modelNameCombobox->Set( modelNames );
|
m_modelNameCombobox->Set( modelNames );
|
||||||
m_useLibraryModelRadioButton->SetValue( true );
|
m_useLibraryModelRadioButton->SetValue( true );
|
||||||
|
|
||||||
|
@ -920,7 +926,7 @@ void DIALOG_SIM_MODEL<T>::onRadioButton( wxCommandEvent& aEvent )
|
||||||
bool fromLibrary = m_useLibraryModelRadioButton->GetValue();
|
bool fromLibrary = m_useLibraryModelRadioButton->GetValue();
|
||||||
|
|
||||||
m_pathLabel->Enable( fromLibrary );
|
m_pathLabel->Enable( fromLibrary );
|
||||||
m_tclibraryPathName->Enable( fromLibrary );
|
m_libraryPathText->Enable( fromLibrary );
|
||||||
m_browseButton->Enable( fromLibrary );
|
m_browseButton->Enable( fromLibrary );
|
||||||
m_modelNameLabel->Enable( fromLibrary );
|
m_modelNameLabel->Enable( fromLibrary );
|
||||||
m_modelNameCombobox->Enable( fromLibrary );
|
m_modelNameCombobox->Enable( fromLibrary );
|
||||||
|
@ -938,6 +944,38 @@ void DIALOG_SIM_MODEL<T>::onRadioButton( wxCommandEvent& aEvent )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void DIALOG_SIM_MODEL<T>::onLibraryPathTextEnter( wxCommandEvent& aEvent )
|
||||||
|
{
|
||||||
|
if( m_useLibraryModelRadioButton->GetValue() )
|
||||||
|
{
|
||||||
|
wxString path = m_libraryPathText->GetValue();
|
||||||
|
wxFileName fn( path );
|
||||||
|
|
||||||
|
if( fn.MakeRelativeTo( Prj().GetProjectPath() ) && !fn.GetFullPath().StartsWith( ".." ) )
|
||||||
|
path = fn.GetFullPath();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
loadLibrary( path );
|
||||||
|
updateWidgets();
|
||||||
|
}
|
||||||
|
catch( const IO_ERROR& )
|
||||||
|
{
|
||||||
|
// TODO: Add an infobar to report the error?
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void DIALOG_SIM_MODEL<T>::onLibraryPathTextKillFocus( wxFocusEvent& aEvent )
|
||||||
|
{
|
||||||
|
wxCommandEvent dummy;
|
||||||
|
onLibraryPathTextEnter( dummy );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
void DIALOG_SIM_MODEL<T>::onBrowseButtonClick( wxCommandEvent& aEvent )
|
void DIALOG_SIM_MODEL<T>::onBrowseButtonClick( wxCommandEvent& aEvent )
|
||||||
{
|
{
|
||||||
|
@ -952,7 +990,7 @@ void DIALOG_SIM_MODEL<T>::onBrowseButtonClick( wxCommandEvent& aEvent )
|
||||||
if( fn.MakeRelativeTo( Prj().GetProjectPath() ) && !fn.GetFullPath().StartsWith( ".." ) )
|
if( fn.MakeRelativeTo( Prj().GetProjectPath() ) && !fn.GetFullPath().StartsWith( ".." ) )
|
||||||
path = fn.GetFullPath();
|
path = fn.GetFullPath();
|
||||||
|
|
||||||
loadLibrary( path );
|
loadLibrary( path, true );
|
||||||
updateWidgets();
|
updateWidgets();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -99,7 +99,7 @@ private:
|
||||||
|
|
||||||
void removeOrphanedPinAssignments();
|
void removeOrphanedPinAssignments();
|
||||||
|
|
||||||
void loadLibrary( const wxString& aLibraryPath );
|
void loadLibrary( const wxString& aLibraryPath, bool aForceReload = false );
|
||||||
|
|
||||||
void addParamPropertyIfRelevant( int aParamIndex );
|
void addParamPropertyIfRelevant( int aParamIndex );
|
||||||
wxPGProperty* newParamProperty( int aParamIndex ) const;
|
wxPGProperty* newParamProperty( int aParamIndex ) const;
|
||||||
|
@ -114,6 +114,8 @@ private:
|
||||||
int getModelPinIndex( const wxString& aModelPinString ) const;
|
int getModelPinIndex( const wxString& aModelPinString ) const;
|
||||||
|
|
||||||
void onRadioButton( wxCommandEvent& aEvent ) override;
|
void onRadioButton( wxCommandEvent& aEvent ) override;
|
||||||
|
void onLibraryPathTextEnter( wxCommandEvent& aEvent ) override;
|
||||||
|
void onLibraryPathTextKillFocus( wxFocusEvent& aEvent ) override;
|
||||||
void onBrowseButtonClick( wxCommandEvent& aEvent ) override;
|
void onBrowseButtonClick( wxCommandEvent& aEvent ) override;
|
||||||
void onModelNameCombobox( wxCommandEvent& aEvent ) override;
|
void onModelNameCombobox( wxCommandEvent& aEvent ) override;
|
||||||
void onModelNameComboboxKillFocus( wxFocusEvent& event ) override;
|
void onModelNameComboboxKillFocus( wxFocusEvent& event ) override;
|
||||||
|
|
|
@ -41,8 +41,8 @@ DIALOG_SIM_MODEL_BASE::DIALOG_SIM_MODEL_BASE( wxWindow* parent, wxWindowID id, c
|
||||||
wxBoxSizer* bSizer7;
|
wxBoxSizer* bSizer7;
|
||||||
bSizer7 = new wxBoxSizer( wxHORIZONTAL );
|
bSizer7 = new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
|
||||||
m_tclibraryPathName = new wxTextCtrl( m_modelPanel, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxTE_READONLY );
|
m_libraryPathText = new wxTextCtrl( m_modelPanel, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxTE_PROCESS_ENTER );
|
||||||
bSizer7->Add( m_tclibraryPathName, 1, wxALIGN_CENTER_VERTICAL|wxRIGHT, 3 );
|
bSizer7->Add( m_libraryPathText, 1, wxALIGN_CENTER_VERTICAL|wxRIGHT, 3 );
|
||||||
|
|
||||||
m_browseButton = new wxBitmapButton( m_modelPanel, wxID_ANY, wxNullBitmap, wxDefaultPosition, wxDefaultSize, wxBU_AUTODRAW|0 );
|
m_browseButton = new wxBitmapButton( m_modelPanel, wxID_ANY, wxNullBitmap, wxDefaultPosition, wxDefaultSize, wxBU_AUTODRAW|0 );
|
||||||
bSizer7->Add( m_browseButton, 0, wxALIGN_CENTER_VERTICAL|wxRIGHT, 5 );
|
bSizer7->Add( m_browseButton, 0, wxALIGN_CENTER_VERTICAL|wxRIGHT, 5 );
|
||||||
|
@ -285,7 +285,9 @@ DIALOG_SIM_MODEL_BASE::DIALOG_SIM_MODEL_BASE( wxWindow* parent, wxWindowID id, c
|
||||||
// Connect Events
|
// Connect Events
|
||||||
m_useLibraryModelRadioButton->Connect( wxEVT_COMMAND_RADIOBUTTON_SELECTED, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onRadioButton ), NULL, this );
|
m_useLibraryModelRadioButton->Connect( wxEVT_COMMAND_RADIOBUTTON_SELECTED, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onRadioButton ), NULL, this );
|
||||||
m_pathLabel->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathLabelUpdate ), NULL, this );
|
m_pathLabel->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathLabelUpdate ), NULL, this );
|
||||||
m_tclibraryPathName->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathUpdate ), NULL, this );
|
m_libraryPathText->Connect( wxEVT_KILL_FOCUS, wxFocusEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathTextKillFocus ), NULL, this );
|
||||||
|
m_libraryPathText->Connect( wxEVT_COMMAND_TEXT_ENTER, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathTextEnter ), NULL, this );
|
||||||
|
m_libraryPathText->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathUpdate ), NULL, this );
|
||||||
m_browseButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onBrowseButtonClick ), NULL, this );
|
m_browseButton->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onBrowseButtonClick ), NULL, this );
|
||||||
m_browseButton->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onBrowseButtonUpdate ), NULL, this );
|
m_browseButton->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onBrowseButtonUpdate ), NULL, this );
|
||||||
m_modelNameLabel->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onModelNameLabelUpdate ), NULL, this );
|
m_modelNameLabel->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onModelNameLabelUpdate ), NULL, this );
|
||||||
|
@ -324,7 +326,9 @@ DIALOG_SIM_MODEL_BASE::~DIALOG_SIM_MODEL_BASE()
|
||||||
// Disconnect Events
|
// Disconnect Events
|
||||||
m_useLibraryModelRadioButton->Disconnect( wxEVT_COMMAND_RADIOBUTTON_SELECTED, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onRadioButton ), NULL, this );
|
m_useLibraryModelRadioButton->Disconnect( wxEVT_COMMAND_RADIOBUTTON_SELECTED, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onRadioButton ), NULL, this );
|
||||||
m_pathLabel->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathLabelUpdate ), NULL, this );
|
m_pathLabel->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathLabelUpdate ), NULL, this );
|
||||||
m_tclibraryPathName->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathUpdate ), NULL, this );
|
m_libraryPathText->Disconnect( wxEVT_KILL_FOCUS, wxFocusEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathTextKillFocus ), NULL, this );
|
||||||
|
m_libraryPathText->Disconnect( wxEVT_COMMAND_TEXT_ENTER, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathTextEnter ), NULL, this );
|
||||||
|
m_libraryPathText->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onLibraryPathUpdate ), NULL, this );
|
||||||
m_browseButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onBrowseButtonClick ), NULL, this );
|
m_browseButton->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_SIM_MODEL_BASE::onBrowseButtonClick ), NULL, this );
|
||||||
m_browseButton->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onBrowseButtonUpdate ), NULL, this );
|
m_browseButton->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onBrowseButtonUpdate ), NULL, this );
|
||||||
m_modelNameLabel->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onModelNameLabelUpdate ), NULL, this );
|
m_modelNameLabel->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_SIM_MODEL_BASE::onModelNameLabelUpdate ), NULL, this );
|
||||||
|
|
|
@ -384,7 +384,7 @@
|
||||||
<property name="minimize_button">0</property>
|
<property name="minimize_button">0</property>
|
||||||
<property name="minimum_size">-1,-1</property>
|
<property name="minimum_size">-1,-1</property>
|
||||||
<property name="moveable">1</property>
|
<property name="moveable">1</property>
|
||||||
<property name="name">m_tclibraryPathName</property>
|
<property name="name">m_libraryPathText</property>
|
||||||
<property name="pane_border">1</property>
|
<property name="pane_border">1</property>
|
||||||
<property name="pane_position"></property>
|
<property name="pane_position"></property>
|
||||||
<property name="pane_size"></property>
|
<property name="pane_size"></property>
|
||||||
|
@ -394,7 +394,7 @@
|
||||||
<property name="resize">Resizable</property>
|
<property name="resize">Resizable</property>
|
||||||
<property name="show">1</property>
|
<property name="show">1</property>
|
||||||
<property name="size"></property>
|
<property name="size"></property>
|
||||||
<property name="style">wxTE_READONLY</property>
|
<property name="style">wxTE_PROCESS_ENTER</property>
|
||||||
<property name="subclass">; ; forward_declare</property>
|
<property name="subclass">; ; forward_declare</property>
|
||||||
<property name="toolbar_pane">0</property>
|
<property name="toolbar_pane">0</property>
|
||||||
<property name="tooltip"></property>
|
<property name="tooltip"></property>
|
||||||
|
@ -406,6 +406,8 @@
|
||||||
<property name="window_extra_style"></property>
|
<property name="window_extra_style"></property>
|
||||||
<property name="window_name"></property>
|
<property name="window_name"></property>
|
||||||
<property name="window_style"></property>
|
<property name="window_style"></property>
|
||||||
|
<event name="OnKillFocus">onLibraryPathTextKillFocus</event>
|
||||||
|
<event name="OnTextEnter">onLibraryPathTextEnter</event>
|
||||||
<event name="OnUpdateUI">onLibraryPathUpdate</event>
|
<event name="OnUpdateUI">onLibraryPathUpdate</event>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
|
|
|
@ -56,7 +56,7 @@ class DIALOG_SIM_MODEL_BASE : public DIALOG_SHIM
|
||||||
wxPanel* m_modelPanel;
|
wxPanel* m_modelPanel;
|
||||||
wxRadioButton* m_useLibraryModelRadioButton;
|
wxRadioButton* m_useLibraryModelRadioButton;
|
||||||
wxStaticText* m_pathLabel;
|
wxStaticText* m_pathLabel;
|
||||||
wxTextCtrl* m_tclibraryPathName;
|
wxTextCtrl* m_libraryPathText;
|
||||||
wxBitmapButton* m_browseButton;
|
wxBitmapButton* m_browseButton;
|
||||||
wxStaticText* m_modelNameLabel;
|
wxStaticText* m_modelNameLabel;
|
||||||
wxComboBox* m_modelNameCombobox;
|
wxComboBox* m_modelNameCombobox;
|
||||||
|
@ -88,6 +88,8 @@ class DIALOG_SIM_MODEL_BASE : public DIALOG_SHIM
|
||||||
// Virtual event handlers, override them in your derived class
|
// Virtual event handlers, override them in your derived class
|
||||||
virtual void onRadioButton( wxCommandEvent& event ) { event.Skip(); }
|
virtual void onRadioButton( wxCommandEvent& event ) { event.Skip(); }
|
||||||
virtual void onLibraryPathLabelUpdate( wxUpdateUIEvent& event ) { event.Skip(); }
|
virtual void onLibraryPathLabelUpdate( wxUpdateUIEvent& event ) { event.Skip(); }
|
||||||
|
virtual void onLibraryPathTextKillFocus( wxFocusEvent& event ) { event.Skip(); }
|
||||||
|
virtual void onLibraryPathTextEnter( wxCommandEvent& event ) { event.Skip(); }
|
||||||
virtual void onLibraryPathUpdate( wxUpdateUIEvent& event ) { event.Skip(); }
|
virtual void onLibraryPathUpdate( wxUpdateUIEvent& event ) { event.Skip(); }
|
||||||
virtual void onBrowseButtonClick( wxCommandEvent& event ) { event.Skip(); }
|
virtual void onBrowseButtonClick( wxCommandEvent& event ) { event.Skip(); }
|
||||||
virtual void onBrowseButtonUpdate( wxUpdateUIEvent& event ) { event.Skip(); }
|
virtual void onBrowseButtonUpdate( wxUpdateUIEvent& event ) { event.Skip(); }
|
||||||
|
|
|
@ -52,6 +52,18 @@ SIM_LIBRARY& SIM_LIB_MGR::CreateLibrary( const std::string& aLibraryPath )
|
||||||
return *it->second;
|
return *it->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SIM_LIBRARY& SIM_LIB_MGR::SetLibrary( const std::string& aLibraryPath )
|
||||||
|
{
|
||||||
|
std::string absolutePath = std::string( m_project.AbsolutePath( aLibraryPath ).ToUTF8() );
|
||||||
|
|
||||||
|
// May throw an exception.
|
||||||
|
std::unique_ptr<SIM_LIBRARY> library = SIM_LIBRARY::Create( absolutePath );
|
||||||
|
|
||||||
|
Clear();
|
||||||
|
m_libraries[aLibraryPath] = std::move( library );
|
||||||
|
return *m_libraries.at( aLibraryPath );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
SIM_MODEL& SIM_LIB_MGR::CreateModel( SIM_MODEL::TYPE aType, int aSymbolPinCount )
|
SIM_MODEL& SIM_LIB_MGR::CreateModel( SIM_MODEL::TYPE aType, int aSymbolPinCount )
|
||||||
{
|
{
|
||||||
|
|
|
@ -46,6 +46,7 @@ public:
|
||||||
void Clear();
|
void Clear();
|
||||||
|
|
||||||
SIM_LIBRARY& CreateLibrary( const std::string& aLibraryPath );
|
SIM_LIBRARY& CreateLibrary( const std::string& aLibraryPath );
|
||||||
|
SIM_LIBRARY& SetLibrary( const std::string& aLibraryPath );
|
||||||
|
|
||||||
SIM_MODEL& CreateModel( SIM_MODEL::TYPE aType, int aSymbolPinCount );
|
SIM_MODEL& CreateModel( SIM_MODEL::TYPE aType, int aSymbolPinCount );
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue