39#include <wx/filedlg.h>
40#include <fmt/format.h>
46#include <wx/filedlg.h>
51#define FORCE_REFRESH_FROM_MODEL true
54bool equivalent( SIM_MODEL::DEVICE_T a, SIM_MODEL::DEVICE_T b )
65 std::vector<SCH_FIELD>& aFields ) :
84 if constexpr (std::is_same_v<T, SCH_SYMBOL>)
90 if(
EMBEDDED_FILES* symbolEmbeddedFiles = aSymbol.GetEmbeddedFiles() )
92 m_filesStack.push_back( symbolEmbeddedFiles );
94 if constexpr (std::is_same_v<T, SCH_SYMBOL>)
96 SCH_SYMBOL* symbol = static_cast<SCH_SYMBOL*>( &aSymbol );
97 symbol->GetLibSymbolRef()->AppendParentEmbeddedFiles( m_filesStack );
99 else if constexpr (std::is_same_v<T, LIB_SYMBOL>)
106 m_libraryModelsMgr.SetFilesStack( m_filesStack );
107 m_builtinModelsMgr.SetFilesStack( m_filesStack );
112 if( !pin->GetParentSymbol()->IsMultiBodyStyle() || pin->GetBodyStyle() < 2 )
113 m_sortedPartPins.push_back( pin );
116 std::sort( m_sortedPartPins.begin(), m_sortedPartPins.end(),
120 return StrNumCmp( lhs->GetNumber(), rhs->GetNumber(), true ) < 0;
123 m_waveformChoice->Clear();
124 m_deviceChoice->Clear();
125 m_deviceSubtypeChoice->Clear();
127 m_scintillaTricksCode =
new SCINTILLA_TRICKS( m_codePreview, wxT(
"{}" ),
false );
128 m_scintillaTricksSubckt =
new SCINTILLA_TRICKS( m_subckt, wxT(
"()" ),
false );
132 wxPropertyGrid*
grid = m_paramGrid->GetGrid();
133 grid->SetCellDisabledTextColour( wxSystemSettings::GetColour( wxSYS_COLOUR_GRAYTEXT ) );
137 grid->DedicateKey( WXK_RETURN );
138 grid->DedicateKey( WXK_NUMPAD_ENTER );
139 grid->DedicateKey( WXK_UP );
140 grid->DedicateKey( WXK_DOWN );
142#if wxCHECK_VERSION( 3, 3, 0 )
143 grid->AddActionTrigger( wxPGKeyboardAction::Edit, WXK_RETURN );
144 grid->AddActionTrigger( wxPGKeyboardAction::NextProperty, WXK_RETURN );
145 grid->AddActionTrigger( wxPGKeyboardAction::Edit, WXK_NUMPAD_ENTER );
146 grid->AddActionTrigger( wxPGKeyboardAction::NextProperty, WXK_NUMPAD_ENTER );
148 grid->AddActionTrigger( wxPG_ACTION_EDIT, WXK_RETURN );
149 grid->AddActionTrigger( wxPG_ACTION_NEXT_PROPERTY, WXK_RETURN );
150 grid->AddActionTrigger( wxPG_ACTION_EDIT, WXK_NUMPAD_ENTER );
151 grid->AddActionTrigger( wxPG_ACTION_NEXT_PROPERTY, WXK_NUMPAD_ENTER );
154 m_pinAssignmentsGrid->ClearRows();
155 m_pinAssignmentsGrid->PushEventHandler(
new GRID_TRICKS( m_pinAssignmentsGrid ) );
158 finishDialogSettings();
167 for( wxPropertyGridIterator it =
m_paramGrid->GetIterator(); !it.AtEnd(); ++it )
184 wxCommandEvent dummyEvent;
187 wxString modelParams;
189 bool storeInValue =
false;
195 &deviceType, &modelType, &modelParams, &pinMap ) )
199 if( !modelType.IsEmpty() )
214 valueField->
SetText( wxT(
"${SIM.PARAMS}" ) );
218 wxFileName tmp( libraryFilename );
220 if( !tmp.GetFullName().IsEmpty() )
244 if( modelIdx == wxNOT_FOUND )
246 m_infoBar->ShowMessage( wxString::Format(
_(
"No model named '%s' in library." ),
278 for(
const std::pair<std::string, std::string>& strs : ibismodel->
GetIbisPins() )
284 ibismodel->
ChangePin( *ibisLibrary, strs.first );
291 if( i <
static_cast<int>( ibismodel->
GetIbisPins().size() ) )
318 if( ibisLibrary && !pinNum.empty() && !modelNm.empty() )
319 ibismodel->
SetIbisModel( *ibisLibrary, pinNum, modelNm );
336 for( SIM_MODEL::TYPE type : SIM_MODEL::TYPE_ITERATOR() )
346 + wxT(
"\n\n" ) +
reporter.GetMessages() );
361 curModel().SetIsStoredInValue(
true );
368 return DIALOG_SIM_MODEL_BASE::TransferDataToWindow();
378 if( !
m_paramGrid->GetGrid()->CommitChangesFromEditor() )
381 if( !DIALOG_SIM_MODEL_BASE::TransferDataFromWindow() )
391 wxFileName fn(
path );
394 && !fn.GetFullPath().StartsWith(
".." ) )
396 path = fn.GetFullPath();
423 std::string differential;
426 pins = ibismodel->GetIbisPins().at(
m_pinCombobox->GetSelection() ).first;
437 if(
model.GetType() == SIM_MODEL::TYPE::RAWSPICE )
442 wxString code =
m_codePreview->GetText().Trim(
true ).Trim(
false );
443 model.SetParamValue(
"model", std::string( code.ToUTF8() ) );
454 std::string( symbolPinName.ToUTF8() ) );
462 model.IsStoredInValue() );
474 wxStringTokenizer sharedTokens(
m_sharedPinsText->GetValue(), wxS(
", \t" ),
477 while( sharedTokens.HasMoreTokens() )
478 decomposition.
sharedModelPins.push_back( sharedTokens.GetNextToken() );
492 const wxString& aOriginalValue,
bool aOverwritten,
493 bool aStoredInValue )
495 if( !aOverwritten || aStoredInValue )
499 valueField->SetText( aOriginalValue );
506 bool multiUnit =
m_symbol.GetUnitCount() > 1;
526 if( !shared.IsEmpty() )
527 shared += wxS(
", " );
598 SendSizeEvent( wxSEND_EVENT_POST );
622 for( SIM_MODEL::TYPE type : { SIM_MODEL::TYPE::KIBIS_DEVICE,
623 SIM_MODEL::TYPE::KIBIS_DRIVER_DC,
624 SIM_MODEL::TYPE::KIBIS_DRIVER_RECT,
625 SIM_MODEL::TYPE::KIBIS_DRIVER_PRBS } )
635 if( type == aModel->
GetType() )
658 for( SIM_MODEL::DEVICE_T deviceType : SIM_MODEL::DEVICE_T_ITERATOR() )
669 for( SIM_MODEL::TYPE type : SIM_MODEL::TYPE_ITERATOR() )
671 if( type == SIM_MODEL::TYPE::KIBIS_DEVICE
672 || type == SIM_MODEL::TYPE::KIBIS_DRIVER_DC
673 || type == SIM_MODEL::TYPE::KIBIS_DRIVER_RECT
674 || type == SIM_MODEL::TYPE::KIBIS_DRIVER_PRBS )
687 if( type == aModel->
GetType() )
744 m_paramGrid->Append(
new wxPropertyCategory(
"AC" ) );
747 m_paramGrid->Append(
new wxPropertyCategory(
"DC" ) );
750 m_paramGrid->Append(
new wxPropertyCategory(
"S-Parameters" ) );
753 m_paramGrid->Append(
new wxPropertyCategory(
"Capacitance" ) );
756 m_paramGrid->Append(
new wxPropertyCategory(
"Temperature" ) );
759 m_paramGrid->Append(
new wxPropertyCategory(
"Noise" ) );
762 m_paramGrid->Append(
new wxPropertyCategory(
"Distributed Quantities" ) );
763 m_paramGrid->HideProperty(
"Distributed Quantities" );
765 m_paramGrid->Append(
new wxPropertyCategory(
"Waveform" ) );
768 m_paramGrid->Append(
new wxPropertyCategory(
"Limiting Values" ) );
771 m_paramGrid->Append(
new wxPropertyCategory(
"Advanced" ) );
774 m_paramGrid->Append(
new wxPropertyCategory(
"Flags" ) );
791 for( wxPropertyGridIterator it =
m_paramGrid->GetIterator(); !it.AtEnd(); ++it )
793 wxColour bgCol =
m_paramGrid->GetGrid()->GetPropertyDefaultCell().GetBgCol();
794 wxColour fgCol =
m_paramGrid->GetGrid()->GetPropertyDefaultCell().GetFgCol();
798 ( *it )->GetCell( col ).SetBgCol( bgCol );
799 ( *it )->GetCell( col ).SetFgCol( fgCol );
813 ( *it )->SetValueFromString( param.
value );
854 aForceRefreshFromModel =
true;
857 if( aForceRefreshFromModel )
864 for(
int modelPinIndex = 0; modelPinIndex < aModel->
GetPinCount(); ++modelPinIndex )
868 if( symbolPinNumber ==
"" )
873 if( symbolPinRow == -1 )
884 std::vector<BITMAPS> modelPinIcons;
885 wxArrayString modelPinChoices;
887 for(
int jj = 0; jj < aModel->
GetPinCount(); ++jj )
898 modelPinChoices.Add(
_(
"Not Connected" ) );
907 if( modelPinIndex >= 0 )
913 if( aModel->
GetType() == SIM_MODEL::TYPE::SUBCKT )
959 wxArrayString emptyArray;
972 for(
const auto& [baseModelName, baseModel] :
library()->GetModels() )
974 if( baseModelName == modelName )
982 wxArrayString modelNames;
984 bool modelNameExists =
false;
987 modelNames.Add(
name );
990 if(
name == modelName )
991 modelNameExists =
true;
999 if( !modelNameExists )
1001 m_infoBar->ShowMessage( wxString::Format(
_(
"No model named '%s' in '%s'." ),
1009 wxArrayString emptyArray;
1028template <
typename T>
1046 case CATEGORY::S_PARAM:
1047 m_paramGrid->HideProperty(
"S-Parameters",
false );
1051 case CATEGORY::CAPACITANCE:
1052 m_paramGrid->HideProperty(
"Capacitance",
false );
1056 case CATEGORY::TEMPERATURE:
1057 m_paramGrid->HideProperty(
"Temperature",
false );
1061 case CATEGORY::NOISE:
1066 case CATEGORY::DISTRIBUTED_QUANTITIES:
1067 m_paramGrid->HideProperty(
"Distributed Quantities",
false );
1071 case CATEGORY::WAVEFORM:
1076 case CATEGORY::GEOMETRY:
1081 case CATEGORY::LIMITING_VALUES:
1082 m_paramGrid->HideProperty(
"Limiting Values",
false );
1086 case CATEGORY::ADVANCED:
1091 case CATEGORY::FLAGS:
1100 case CATEGORY::INITIAL_CONDITIONS:
1101 case CATEGORY::SUPERFLUOUS:
1107template <
typename T>
1111 wxString paramDescription;
1114 paramDescription = wxString::Format(
"%s", param.
info.
name );
1118 wxPGProperty* prop =
nullptr;
1124 prop->SetAttribute( wxPG_BOOL_USE_CHECKBOX,
true );
1146 wxArrayString inductors;
1157 if( item.model->GetDeviceType() == SIM_MODEL::DEVICE_T::L )
1158 inductors.push_back( item.refName );
1162 [](
const wxString& a,
const wxString& b ) ->
int
1168 if( inductors.empty() )
1186 wxArrayString values;
1189 values.Add(
string );
1197 prop =
new wxStringProperty( paramDescription, param.
info.
name );
1201 prop->SetAttribute( wxPG_ATTR_UNITS, wxString::FromUTF8( param.
info.
unit.c_str() ) );
1227template <
typename T>
1230 for(
int row = 0; row < static_cast<int>(
m_sortedPartPins.size() ); ++row )
1234 if(
pin->GetNumber() == aSymbolPinNumber )
1242template <
typename T>
1267template <
typename T>
1277template <
typename T>
1286 pinNumber =
pin->GetShownNumber();
1287 pinName =
pin->GetShownName();
1290 if( !pinName.IsEmpty() && pinName != pinNumber )
1291 pinNumber += wxString::Format( wxT(
" (\"%s\")" ), pinName );
1297template <
typename T>
1300 wxString modelPinName;
1302 if( aModelPinIndex >= 0 && aModelPinIndex < aModel->GetPinCount() )
1305 wxString modelPinNumber = wxString::Format(
"%d", aModelPinIndex + 1 );
1307 if( !modelPinName.IsEmpty() && modelPinName != modelPinNumber )
1308 modelPinNumber += wxString::Format( wxT(
" (\"%s\")" ), modelPinName );
1310 return modelPinNumber;
1314template <
typename T>
1317 if( aModelPinString ==
"Not Connected" )
1320 int length = aModelPinString.Find(
" " );
1322 if( length == wxNOT_FOUND )
1323 length =
static_cast<int>( aModelPinString.Length() );
1326 aModelPinString.Mid( 0, length ).ToCLong( &
result );
1328 return static_cast<int>(
result - 1 );
1332template <
typename T>
1340template <
typename T>
1347template <
typename T>
1364template <
typename T>
1374 wxCommandEvent
dummy;
1382template <
typename T>
1385 static wxString s_mruPath;
1388 wxFileDialog dlg(
this,
_(
"Browse Models" ),
path );
1391 dlg.SetCustomizeHook( customize );
1395 if( dlg.ShowModal() == wxID_CANCEL )
1400 path = dlg.GetPath();
1401 wxFileName fn(
path );
1402 s_mruPath = fn.GetPath();
1409 else if( fn.MakeRelativeTo(
Prj().GetProjectPath() ) && !fn.GetFullPath().StartsWith( wxS(
".." ) ) )
1411 path = fn.GetFullPath();
1425template <
typename T>
1438 switch( aKeyStroke.GetKeyCode() )
1441 if( sel == wxNOT_FOUND )
1444 sel = std::max( sel - 1, 0 );
1449 if( sel == wxNOT_FOUND )
1452 sel = std::min( sel + 1, count - 1 );
1457 wxPostEvent(
this, wxCommandEvent( wxEVT_COMMAND_BUTTON_CLICKED, wxID_OK ) );
1469template <
typename T>
1475 wxArrayString modelNames;
1481 wxString wx_name(
name );
1483 if( wx_name.Matches(
filter ) )
1484 modelNames.Add( wx_name );
1500template <
typename T>
1505 wxArrayString pinLabels;
1508 wxCHECK2( modelkibis,
return );
1510 for( std::pair<wxString, wxString> strs : modelkibis->
GetIbisPins() )
1511 pinLabels.Add( strs.first + wxT(
" - " ) + strs.second );
1515 wxArrayString emptyArray;
1524 wxArrayString lines = wxSplit( fallback->GetSpiceCode(),
'\n' );
1527 for(
const wxString& line : lines )
1529 if( !line.StartsWith(
'*' ) )
1531 if( !code.IsEmpty() )
1538 m_infoBar->ShowMessage( wxString::Format(
_(
"Failed to parse:\n\n"
1540 "Using generic SPICE model." ),
1552template <
typename T>
1555 wxArrayString modelLabels;
1559 std::vector<std::pair<std::string, std::string>> strs = ibisModel.
GetIbisPins();
1560 std::string pinNumber = strs.at(
m_pinCombobox->GetSelection() ).first;
1564 ibisModel.
ChangePin( *ibisLibrary, pinNumber );
1569 modelLabels.Add( modelName );
1582template <
typename T>
1591template <
typename T>
1603 std::string pinNumber = ibismodel->GetIbisPins()
1608 ibismodel->SetIbisModel( *ibisLibrary, pinNumber, modelName );
1616template <
typename T>
1623template <
typename T>
1629 modelibis->SwitchSingleEndedDiff( diff );
1636template <
typename T>
1641 for( SIM_MODEL::DEVICE_T deviceType : SIM_MODEL::DEVICE_T_ITERATOR() )
1654template <
typename T>
1657 SIM_MODEL::DEVICE_T deviceType =
curModel().GetDeviceType();
1660 for( SIM_MODEL::TYPE type : { SIM_MODEL::TYPE::KIBIS_DEVICE,
1661 SIM_MODEL::TYPE::KIBIS_DRIVER_DC,
1662 SIM_MODEL::TYPE::KIBIS_DRIVER_RECT,
1663 SIM_MODEL::TYPE::KIBIS_DRIVER_PRBS } )
1676 m_libraryModelsMgr.SetModel( idx, std::make_unique<SIM_MODEL_IBIS>( type, baseModel ) );
1697template <
typename T>
1700 SIM_MODEL::DEVICE_T deviceType =
curModel().GetDeviceType();
1703 for( SIM_MODEL::TYPE type : SIM_MODEL::TYPE_ITERATOR() )
1718template <
typename T>
1725template <
typename T>
1728 int symbolPinIndex = aEvent.GetRow();
1729 wxString oldModelPinName = aEvent.GetString();
1730 wxString modelPinName =
m_pinAssignmentsGrid->GetCellValue( aEvent.GetRow(), aEvent.GetCol() );
1736 curModel().AssignSymbolPinNumberToModelPin( oldModelPinIndex,
"" );
1751template <
typename T>
1764template <
typename T>
1771 wxPGProperty* selected =
grid->GetSelection();
1774 selected =
grid->wxPropertyGridInterface::GetFirst();
1776#if wxCHECK_VERSION( 3, 3, 0 )
1778 grid->DoSelectProperty( selected, wxPGSelectPropertyFlags::Focus );
1781 grid->DoSelectProperty( selected, wxPG_SEL_FOCUS );
1788template <
typename T>
1794 if(
grid->GetSelection() &&
grid->GetSelection()->IsCategory() )
1796 wxPGProperty* selection =
grid->GetSelection();
1801 wxPropertyGridIterator it =
grid->GetIterator( wxPG_ITERATE_VISIBLE, selection );
1804 wxKeyEvent* keyEvent =
new wxKeyEvent( wxEVT_KEY_DOWN );
1808 if( !selection->IsExpanded() )
1810 grid->Expand( selection );
1811 keyEvent->m_keyCode = WXK_DOWN;
1812 wxQueueEvent(
grid, keyEvent );
1820 keyEvent->m_keyCode = WXK_UP;
1821 wxQueueEvent(
grid, keyEvent );
1826 if( !selection->IsExpanded() )
1827 grid->Expand( selection );
1829 keyEvent->m_keyCode = WXK_DOWN;
1830 wxQueueEvent(
grid, keyEvent );
1837 wxWindow* editorControl =
grid->GetEditorControl();
1839 if( !editorControl )
1846 editorControl->SetFocus();
1851template <
typename T>
1863 wxTextCtrl* ctrl =
grid->GetEditorTextCtrl();
1867 wxRect ctrlRect = ctrl->GetScreenRect();
1868 wxRect gridRect =
grid->GetScreenRect();
1870 if( ctrlRect.GetTop() < gridRect.GetTop() || ctrlRect.GetBottom() > gridRect.GetBottom() )
1871 grid->ClearSelection();
1877template <
typename T>
1890 std::vector<int> colWidths;
1892 for(
size_t ii = 0; ii <
grid->GetColumnCount(); ii++ )
1895 colWidths.push_back(
grid->GetState()->GetColumnWidth( ii ) + margin + indent );
1897 colWidths.push_back( std::max( 72,
grid->GetState()->GetColumnWidth( ii ) ) + margin );
1899 colWidths.push_back( 60 + margin );
1901 aWidth -= colWidths[ ii ];
1904 for(
size_t ii = 0; ii <
grid->GetColumnCount(); ii++ )
1905 grid->SetColumnProportion( ii, colWidths[ ii ] );
1907 grid->ResetColumnSizes();
1908 grid->RefreshEditor();
1913template <
typename T>
wxBitmapBundle KiBitmapBundle(BITMAPS aBitmap, int aMinHeight)
wxNotebook * m_modelNotebook
wxStaticText * m_subcktLabel
wxStaticText * m_sharedPinsLabel
wxStaticText * m_modelNameLabel
wxPropertyGridManager * m_paramGridMgr
wxStaticText * m_pathLabel
wxRadioButton * m_rbBuiltinModel
wxListBox * m_modelListBox
wxComboBox * m_pinCombobox
DIALOG_SIM_MODEL_BASE(wxWindow *parent, wxWindowID id=wxID_ANY, const wxString &title=_("Simulation Model Editor"), const wxPoint &pos=wxDefaultPosition, const wxSize &size=wxSize(-1,-1), long style=wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER)
wxChoice * m_deviceSubtypeChoice
wxSearchCtrl * m_modelFilter
wxStaticText * m_waveformLabel
wxTextCtrl * m_libraryPathText
wxStaticText * m_pinLabel
wxChoice * m_deviceChoice
wxComboBox * m_pinModelCombobox
wxRadioButton * m_rbLibraryModel
wxChoice * m_decompositionChoice
wxChoice * m_waveformChoice
wxStaticText * m_deviceLabel
wxStaticText * m_decompositionLabel
WX_GRID * m_pinAssignmentsGrid
wxStaticText * m_pinModelLabel
wxPanel * m_parametersPanel
wxStaticText * m_deviceSubtypeLabel
wxTextCtrl * m_sharedPinsText
wxCheckBox * m_saveInValueCheckbox
STD_BITMAP_BUTTON * m_browseButton
wxStyledTextCtrl * m_subckt
wxPropertyGridPage * m_paramGrid
wxPanel * m_pinAssignmentsPanel
wxCheckBox * m_differentialCheckbox
wxStyledTextCtrl * m_codePreview
const SIM_MODEL * m_prevModel
void onTypeChoice(wxCommandEvent &aEvent) override
void onLibraryPathTextKillFocus(wxFocusEvent &aEvent) override
wxString getSymbolPinString(int aSymbolPinNumber) const
void updateBuiltinModelWidgets(SIM_MODEL *aModel)
void onPinAssignmentsGridCellChange(wxGridEvent &aEvent) override
void onFilterCharHook(wxKeyEvent &aKeyStroke) override
int findSymbolPinRow(const wxString &aSymbolPinNumber) const
void onModelNameChoice(wxCommandEvent &aEvent) override
void onRadioButton(wxCommandEvent &aEvent) override
SCINTILLA_TRICKS * m_scintillaTricksSubckt
bool loadLibrary(const wxString &aLibraryPath, REPORTER &aReporter, bool aForceReload=false)
SIM_LIB_MGR m_builtinModelsMgr
int getModelPinIndex(const wxString &aModelPinString) const
void onModelFilter(wxCommandEvent &aEvent) override
void onLibraryPathText(wxCommandEvent &aEvent) override
void onDifferentialCheckbox(wxCommandEvent &event) override
void onParamGridSelectionChange(wxPropertyGridEvent &aEvent)
void removeOrphanedPinAssignments(SIM_MODEL *aModel)
bool m_inferredValueOverwritten
void adjustParamGridColumns(int aWidth, bool aForce)
Show/populate the decomposition controls (multi-unit only) and sync their enabled state.
std::vector< SCH_FIELD > & m_fields
std::vector< SCH_PIN * > m_sortedPartPins
Pins of the current part.
wxPGProperty * newParamProperty(SIM_MODEL *aModel, int aParamIndex) const
void onDecompositionModeChoice(wxCommandEvent &aEvent) override
wxPGProperty * m_prevParamGridSelection
void onPinModelCombobox(wxCommandEvent &event) override
const SIM_LIBRARY * library() const
SIM_MODEL & curModel() const
SIM_LIB_MGR m_libraryModelsMgr
void onBrowseButtonClick(wxCommandEvent &aEvent) override
void onPinComboboxTextEnter(wxCommandEvent &event) override
void onPinCombobox(wxCommandEvent &event) override
wxPGProperty * m_firstCategory
SCINTILLA_TRICKS * m_scintillaTricksCode
wxString m_inferredValueRestore
std::map< wxString, int > m_modelListBoxEntryToLibraryIdx
void updatePinAssignments(SIM_MODEL *aModel, bool aForceUpdatePins)
void onUpdateUI(wxUpdateUIEvent &aEvent)
DIALOG_SIM_MODEL(wxWindow *aParent, EDA_BASE_FRAME *aFrame, T &aSymbol, std::vector< SCH_FIELD > &aFields)
wxString getModelPinString(SIM_MODEL *aModel, int aModelPinIndex) const
void onPinAssignmentsGridSize(wxSizeEvent &aEvent) override
void updateIbisWidgets(SIM_MODEL *aModel)
void onParamGridSetFocus(wxFocusEvent &aEvent)
void updateModelParamsTab(SIM_MODEL *aModel)
bool TransferDataFromWindow() override
SIM_MODEL::TYPE m_curModelType
void updateModelCodeTab(SIM_MODEL *aModel)
void onSizeParamGrid(wxSizeEvent &event) override
void onPageChanging(wxNotebookEvent &event) override
std::vector< EMBEDDED_FILES * > m_filesStack
void updateDecompositionControls()
void onWaveformChoice(wxCommandEvent &aEvent) override
std::map< SIM_MODEL::DEVICE_T, SIM_MODEL::TYPE > m_curModelTypeOfDeviceType
void onPinModelComboboxTextEnter(wxCommandEvent &event) override
void onLibraryPathTextEnter(wxCommandEvent &aEvent) override
static void RestoreInferredValue(std::vector< SCH_FIELD > &aFields, const wxString &aOriginalValue, bool aOverwritten, bool aStoredInValue)
Restore an inferred passive's Value field after WriteFields().
void onDeviceTypeChoice(wxCommandEvent &aEvent) override
bool TransferDataToWindow() override
void addParamPropertyIfRelevant(SIM_MODEL *aModel, int aParamIndex)
The base frame for deriving all KiCad main window classes.
Add mouse and command handling (such as cut, copy, and paste) to a WX_GRID instance.
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()
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
Define a library symbol object.
void AppendParentEmbeddedFiles(std::vector< EMBEDDED_FILES * > &aStack) const
virtual bool ReadSchematicAndLibraries(unsigned aNetlistOptions, REPORTER &aReporter)
Process the schematic and Spice libraries to create net mapping and a list of SPICE_ITEMs.
const std::list< SPICE_ITEM > & GetItems() const
Return the list of items representing schematic symbols in the Spice world.
A singleton reporter that reports to nowhere.
virtual const wxString GetProjectPath() const
Return the full path of the project.
A pure virtual class used to derive REPORTER objects from.
virtual bool HasMessageOfSeverity(int aSeverityMask) const
Returns true if the reporter has one or more messages matching the specified severity mask.
EMBEDDED_FILES * GetEmbeddedFiles() override
Schematic editor (Eeschema) main window.
virtual const wxString & GetText() const override
Return the string associated with the text object.
void SetText(const wxString &aText) override
SCHEMATIC * Schematic() const
Search the item hierarchy to find a SCHEMATIC.
const wxString & GetShownNumber() const
Add cut/copy/paste, dark theme, autocomplete and brace highlighting to a wxStyleTextCtrl instance.
static constexpr auto MODEL_FIELD
static constexpr auto PIN_FIELD
static constexpr auto DIFF_FIELD
bool isPinDiff(const std::string &aComp, const std::string &aPinNumber) const
static constexpr auto LIBRARY_FIELD
static constexpr auto NAME_FIELD
bool SetIbisModel(const SIM_LIBRARY_IBIS &aLib, const std::string &aPinNumber, const std::string &aModelName)
Bind to a KIBIS model, set IO mode from its type, manage sw_state.
std::vector< std::pair< std::string, std::string > > GetIbisPins() const
void SwitchSingleEndedDiff(bool aDiff) override
bool CanDifferential() const
std::vector< std::string > GetIbisModels() const
bool ChangePin(const SIM_LIBRARY_IBIS &aLib, const std::string &aPinNumber)
update the list of available models based on the pin number.
std::string GetComponentName() const
static INFO TypeInfo(TYPE aType)
static bool InferSimModel(T &aSymbol, std::vector< SCH_FIELD > *aFields, bool aResolve, int aDepth, SIM_VALUE_GRAMMAR::NOTATION aNotation, wxString *aDeviceType, wxString *aModelType, wxString *aModelParams, wxString *aPinMap)
const SPICE_GENERATOR & SpiceGenerator() const
virtual const PARAM & GetParam(unsigned aParamIndex) const
static TYPE ReadTypeFromFields(const std::vector< SCH_FIELD > &aFields, bool aResolve, int aDepth, REPORTER &aReporter)
int GetParamCount() const
void AssignSymbolPinNumberToModelPin(int aPinIndex, const wxString &aSymbolPinNumber)
DEVICE_INFO GetDeviceInfo() const
DEVICE_T GetDeviceType() const
static DEVICE_INFO DeviceInfo(DEVICE_T aDeviceType)
virtual bool HasAutofill() const
const SIM_MODEL_PIN & GetPin(unsigned aIndex) const
virtual bool HasPrimaryValue() const
const SIM_MODEL::PARAM & GetParam() const
Special netlist exporter flavor that allows one to override simulation commands.
virtual std::string Preview(const SPICE_ITEM &aItem) const
A wrapper for reporting to a wxString object.
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
This file is part of the common library.
static bool empty(const wxTextEntryBase *aCtrl)
bool equivalent(SIM_MODEL::DEVICE_T a, SIM_MODEL::DEVICE_T b)
#define FORCE_REFRESH_FROM_MODEL
SIM_MODEL::PARAM::CATEGORY CATEGORY
static const std::string KiCadUriPrefix
KICOMMON_API wxFont GetStatusFont(wxWindow *aWindow)
BITMAPS PinShapeGetBitmap(GRAPHIC_PINSHAPE shape)
void SetFieldValue(std::vector< SCH_FIELD > &aFields, const wxString &aFieldName, const std::string &aValue, bool aIsVisible=true, const SCH_SHEET_PATH *aSheetPath=nullptr, const wxString &aVariantName=wxEmptyString)
wxString GetFieldValue(const std::vector< SCH_FIELD > *aFields, FIELD_T aFieldType)
const SCH_FIELD * FindField(const std::vector< SCH_FIELD > &aFields, FIELD_T aFieldId)
#define SIM_REFERENCE_FIELD
#define SIM_DECOMPOSITION_FIELD
#define SIM_DEVICE_SUBTYPE_FIELD
std::vector< FAB_LAYER_COLOR > dummy
int StrNumCmp(const wxString &aString1, const wxString &aString2, bool aIgnoreCase)
Compare two strings with alphanumerical content.
Per-component decomposition descriptor stored in the Sim.Decomposition field.
static SIM_DECOMPOSITION Parse(const wxString &aField)
std::vector< wxString > sharedModelPins
std::vector< std::string > enumValues
static constexpr auto NOT_CONNECTED
const std::string modelPinName
@ REFERENCE
Field Reference of part, i.e. "IC21".
@ VALUE
Field Value of part, i.e. "3.3K".
IbisParser parser & reporter
wxString result
Test unit parsing edge cases and error handling.