42#include <wx/filedlg.h>
43#include <fmt/format.h>
49#include <wx/filedlg.h>
54#define FORCE_REFRESH_FROM_MODEL true
57bool equivalent( SIM_MODEL::DEVICE_T a, SIM_MODEL::DEVICE_T b )
68 std::vector<SCH_FIELD>& aFields ) :
86 if constexpr (std::is_same_v<T, SCH_SYMBOL>)
92 if(
EMBEDDED_FILES* symbolEmbeddedFiles = aSymbol.GetEmbeddedFiles() )
94 m_filesStack.push_back( symbolEmbeddedFiles );
96 if constexpr (std::is_same_v<T, SCH_SYMBOL>)
98 SCH_SYMBOL* symbol = static_cast<SCH_SYMBOL*>( &aSymbol );
99 symbol->GetLibSymbolRef()->AppendParentEmbeddedFiles( m_filesStack );
101 else if constexpr (std::is_same_v<T, LIB_SYMBOL>)
108 m_libraryModelsMgr.SetFilesStack( m_filesStack );
109 m_builtinModelsMgr.SetFilesStack( m_filesStack );
114 if( !pin->GetParentSymbol()->IsMultiBodyStyle() || pin->GetBodyStyle() < 2 )
115 m_sortedPartPins.push_back( pin );
118 std::sort( m_sortedPartPins.begin(), m_sortedPartPins.end(),
122 return StrNumCmp( lhs->GetNumber(), rhs->GetNumber(), true ) < 0;
125 m_waveformChoice->Clear();
126 m_deviceChoice->Clear();
127 m_deviceSubtypeChoice->Clear();
129 m_scintillaTricksCode =
new SCINTILLA_TRICKS( m_codePreview, wxT(
"{}" ),
false );
130 m_scintillaTricksSubckt =
new SCINTILLA_TRICKS( m_subckt, wxT(
"()" ),
false );
134 wxPropertyGrid*
grid = m_paramGrid->GetGrid();
135 grid->SetCellDisabledTextColour( wxSystemSettings::GetColour( wxSYS_COLOUR_GRAYTEXT ) );
139 grid->DedicateKey( WXK_RETURN );
140 grid->DedicateKey( WXK_NUMPAD_ENTER );
141 grid->DedicateKey( WXK_UP );
142 grid->DedicateKey( WXK_DOWN );
144#if wxCHECK_VERSION( 3, 3, 0 )
145 grid->AddActionTrigger( wxPGKeyboardAction::Edit, WXK_RETURN );
146 grid->AddActionTrigger( wxPGKeyboardAction::NextProperty, WXK_RETURN );
147 grid->AddActionTrigger( wxPGKeyboardAction::Edit, WXK_NUMPAD_ENTER );
148 grid->AddActionTrigger( wxPGKeyboardAction::NextProperty, WXK_NUMPAD_ENTER );
150 grid->AddActionTrigger( wxPG_ACTION_EDIT, WXK_RETURN );
151 grid->AddActionTrigger( wxPG_ACTION_NEXT_PROPERTY, WXK_RETURN );
152 grid->AddActionTrigger( wxPG_ACTION_EDIT, WXK_NUMPAD_ENTER );
153 grid->AddActionTrigger( wxPG_ACTION_NEXT_PROPERTY, WXK_NUMPAD_ENTER );
156 m_pinAssignmentsGrid->ClearRows();
157 m_pinAssignmentsGrid->PushEventHandler(
new GRID_TRICKS( m_pinAssignmentsGrid ) );
160 finishDialogSettings();
169 for( wxPropertyGridIterator it =
m_paramGrid->GetIterator(); !it.AtEnd(); ++it )
186 wxCommandEvent dummyEvent;
189 wxString modelParams;
191 bool storeInValue =
false;
197 &deviceType, &modelType, &modelParams, &pinMap ) )
201 if( !modelType.IsEmpty() )
216 wxFileName tmp( libraryFilename );
218 if( !tmp.GetFullName().IsEmpty() )
242 if( modelIdx == wxNOT_FOUND )
244 m_infoBar->ShowMessage( wxString::Format(
_(
"No model named '%s' in library." ),
276 for(
const std::pair<std::string, std::string>& strs : ibismodel->
GetIbisPins() )
282 ibismodel->
ChangePin( *ibisLibrary, strs.first );
289 if( i <
static_cast<int>( ibismodel->
GetIbisPins().size() ) )
316 if( ibisLibrary && !pinNum.empty() && !modelNm.empty() )
317 ibismodel->
SetIbisModel( *ibisLibrary, pinNum, modelNm );
334 for( SIM_MODEL::TYPE type : SIM_MODEL::TYPE_ITERATOR() )
344 + wxT(
"\n\n" ) +
reporter.GetMessages() );
359 curModel().SetIsStoredInValue(
true );
364 return DIALOG_SIM_MODEL_BASE::TransferDataToWindow();
374 if( !
m_paramGrid->GetGrid()->CommitChangesFromEditor() )
377 if( !DIALOG_SIM_MODEL_BASE::TransferDataFromWindow() )
387 wxFileName fn(
path );
390 && !fn.GetFullPath().StartsWith(
".." ) )
392 path = fn.GetFullPath();
419 std::string differential;
422 pins = ibismodel->GetIbisPins().at(
m_pinCombobox->GetSelection() ).first;
433 if(
model.GetType() == SIM_MODEL::TYPE::RAWSPICE )
438 wxString code =
m_codePreview->GetText().Trim(
true ).Trim(
false );
439 model.SetParamValue(
"model", std::string( code.ToUTF8() ) );
450 std::string( symbolPinName.ToUTF8() ) );
506 SendSizeEvent( wxSEND_EVENT_POST );
530 for( SIM_MODEL::TYPE type : { SIM_MODEL::TYPE::KIBIS_DEVICE,
531 SIM_MODEL::TYPE::KIBIS_DRIVER_DC,
532 SIM_MODEL::TYPE::KIBIS_DRIVER_RECT,
533 SIM_MODEL::TYPE::KIBIS_DRIVER_PRBS } )
543 if( type == aModel->
GetType() )
566 for( SIM_MODEL::DEVICE_T deviceType : SIM_MODEL::DEVICE_T_ITERATOR() )
577 for( SIM_MODEL::TYPE type : SIM_MODEL::TYPE_ITERATOR() )
579 if( type == SIM_MODEL::TYPE::KIBIS_DEVICE
580 || type == SIM_MODEL::TYPE::KIBIS_DRIVER_DC
581 || type == SIM_MODEL::TYPE::KIBIS_DRIVER_RECT
582 || type == SIM_MODEL::TYPE::KIBIS_DRIVER_PRBS )
595 if( type == aModel->
GetType() )
652 m_paramGrid->Append(
new wxPropertyCategory(
"AC" ) );
655 m_paramGrid->Append(
new wxPropertyCategory(
"DC" ) );
658 m_paramGrid->Append(
new wxPropertyCategory(
"S-Parameters" ) );
661 m_paramGrid->Append(
new wxPropertyCategory(
"Capacitance" ) );
664 m_paramGrid->Append(
new wxPropertyCategory(
"Temperature" ) );
667 m_paramGrid->Append(
new wxPropertyCategory(
"Noise" ) );
670 m_paramGrid->Append(
new wxPropertyCategory(
"Distributed Quantities" ) );
671 m_paramGrid->HideProperty(
"Distributed Quantities" );
673 m_paramGrid->Append(
new wxPropertyCategory(
"Waveform" ) );
676 m_paramGrid->Append(
new wxPropertyCategory(
"Limiting Values" ) );
679 m_paramGrid->Append(
new wxPropertyCategory(
"Advanced" ) );
682 m_paramGrid->Append(
new wxPropertyCategory(
"Flags" ) );
699 for( wxPropertyGridIterator it =
m_paramGrid->GetIterator(); !it.AtEnd(); ++it )
701 wxColour bgCol =
m_paramGrid->GetGrid()->GetPropertyDefaultCell().GetBgCol();
702 wxColour fgCol =
m_paramGrid->GetGrid()->GetPropertyDefaultCell().GetFgCol();
706 ( *it )->GetCell( col ).SetBgCol( bgCol );
707 ( *it )->GetCell( col ).SetFgCol( fgCol );
721 ( *it )->SetValueFromString( param.
value );
762 aForceRefreshFromModel =
true;
765 if( aForceRefreshFromModel )
772 for(
int modelPinIndex = 0; modelPinIndex < aModel->
GetPinCount(); ++modelPinIndex )
776 if( symbolPinNumber ==
"" )
781 if( symbolPinRow == -1 )
792 std::vector<BITMAPS> modelPinIcons;
793 wxArrayString modelPinChoices;
795 for(
int jj = 0; jj < aModel->
GetPinCount(); ++jj )
806 modelPinChoices.Add(
_(
"Not Connected" ) );
815 if( modelPinIndex >= 0 )
821 if( aModel->
GetType() == SIM_MODEL::TYPE::SUBCKT )
867 wxArrayString emptyArray;
880 for(
const auto& [baseModelName, baseModel] :
library()->GetModels() )
882 if( baseModelName == modelName )
890 wxArrayString modelNames;
892 bool modelNameExists =
false;
895 modelNames.Add(
name );
898 if(
name == modelName )
899 modelNameExists =
true;
907 if( !modelNameExists )
909 m_infoBar->ShowMessage( wxString::Format(
_(
"No model named '%s' in '%s'." ),
917 wxArrayString emptyArray;
954 case CATEGORY::S_PARAM:
955 m_paramGrid->HideProperty(
"S-Parameters",
false );
959 case CATEGORY::CAPACITANCE:
964 case CATEGORY::TEMPERATURE:
969 case CATEGORY::NOISE:
974 case CATEGORY::DISTRIBUTED_QUANTITIES:
975 m_paramGrid->HideProperty(
"Distributed Quantities",
false );
979 case CATEGORY::WAVEFORM:
984 case CATEGORY::GEOMETRY:
989 case CATEGORY::LIMITING_VALUES:
990 m_paramGrid->HideProperty(
"Limiting Values",
false );
994 case CATEGORY::ADVANCED:
999 case CATEGORY::FLAGS:
1008 case CATEGORY::INITIAL_CONDITIONS:
1009 case CATEGORY::SUPERFLUOUS:
1015template <
typename T>
1019 wxString paramDescription;
1022 paramDescription = wxString::Format(
"%s", param.
info.
name );
1026 wxPGProperty* prop =
nullptr;
1032 prop->SetAttribute( wxPG_BOOL_USE_CHECKBOX,
true );
1054 wxArrayString inductors;
1065 if( item.model->GetDeviceType() == SIM_MODEL::DEVICE_T::L )
1066 inductors.push_back( item.refName );
1070 [](
const wxString& a,
const wxString& b ) ->
int
1076 if( inductors.empty() )
1094 wxArrayString values;
1097 values.Add(
string );
1105 prop =
new wxStringProperty( paramDescription, param.
info.
name );
1109 prop->SetAttribute( wxPG_ATTR_UNITS, wxString::FromUTF8( param.
info.
unit.c_str() ) );
1135template <
typename T>
1138 for(
int row = 0; row < static_cast<int>(
m_sortedPartPins.size() ); ++row )
1142 if(
pin->GetNumber() == aSymbolPinNumber )
1150template <
typename T>
1175template <
typename T>
1185template <
typename T>
1194 pinNumber =
pin->GetShownNumber();
1195 pinName =
pin->GetShownName();
1198 if( !pinName.IsEmpty() && pinName != pinNumber )
1199 pinNumber += wxString::Format( wxT(
" (\"%s\")" ), pinName );
1205template <
typename T>
1208 wxString modelPinName;
1210 if( aModelPinIndex >= 0 && aModelPinIndex < aModel->GetPinCount() )
1213 wxString modelPinNumber = wxString::Format(
"%d", aModelPinIndex + 1 );
1215 if( !modelPinName.IsEmpty() && modelPinName != modelPinNumber )
1216 modelPinNumber += wxString::Format( wxT(
" (\"%s\")" ), modelPinName );
1218 return modelPinNumber;
1222template <
typename T>
1225 if( aModelPinString ==
"Not Connected" )
1228 int length = aModelPinString.Find(
" " );
1230 if( length == wxNOT_FOUND )
1231 length =
static_cast<int>( aModelPinString.Length() );
1234 aModelPinString.Mid( 0, length ).ToCLong( &
result );
1236 return static_cast<int>(
result - 1 );
1240template <
typename T>
1248template <
typename T>
1255template <
typename T>
1272template <
typename T>
1282 wxCommandEvent
dummy;
1290template <
typename T>
1293 static wxString s_mruPath;
1296 wxFileDialog dlg(
this,
_(
"Browse Models" ),
path );
1299 dlg.SetCustomizeHook( customize );
1303 if( dlg.ShowModal() == wxID_CANCEL )
1308 path = dlg.GetPath();
1309 wxFileName fn(
path );
1310 s_mruPath = fn.GetPath();
1317 else if( fn.MakeRelativeTo(
Prj().GetProjectPath() ) && !fn.GetFullPath().StartsWith( wxS(
".." ) ) )
1319 path = fn.GetFullPath();
1333template <
typename T>
1346 switch( aKeyStroke.GetKeyCode() )
1349 if( sel == wxNOT_FOUND )
1352 sel = std::max( sel - 1, 0 );
1357 if( sel == wxNOT_FOUND )
1360 sel = std::min( sel + 1, count - 1 );
1365 wxPostEvent(
this, wxCommandEvent( wxEVT_COMMAND_BUTTON_CLICKED, wxID_OK ) );
1377template <
typename T>
1383 wxArrayString modelNames;
1389 wxString wx_name(
name );
1391 if( wx_name.Matches(
filter ) )
1392 modelNames.Add( wx_name );
1408template <
typename T>
1413 wxArrayString pinLabels;
1416 wxCHECK2( modelkibis,
return );
1418 for( std::pair<wxString, wxString> strs : modelkibis->
GetIbisPins() )
1419 pinLabels.Add( strs.first + wxT(
" - " ) + strs.second );
1423 wxArrayString emptyArray;
1432 wxArrayString lines = wxSplit( fallback->GetSpiceCode(),
'\n' );
1435 for(
const wxString& line : lines )
1437 if( !line.StartsWith(
'*' ) )
1439 if( !code.IsEmpty() )
1446 m_infoBar->ShowMessage( wxString::Format(
_(
"Failed to parse:\n\n"
1448 "Using generic SPICE model." ),
1460template <
typename T>
1463 wxArrayString modelLabels;
1467 std::vector<std::pair<std::string, std::string>> strs = ibisModel.
GetIbisPins();
1468 std::string pinNumber = strs.at(
m_pinCombobox->GetSelection() ).first;
1472 ibisModel.
ChangePin( *ibisLibrary, pinNumber );
1477 modelLabels.Add( modelName );
1490template <
typename T>
1499template <
typename T>
1511 std::string pinNumber = ibismodel->GetIbisPins()
1516 ibismodel->SetIbisModel( *ibisLibrary, pinNumber, modelName );
1524template <
typename T>
1531template <
typename T>
1537 modelibis->SwitchSingleEndedDiff( diff );
1544template <
typename T>
1549 for( SIM_MODEL::DEVICE_T deviceType : SIM_MODEL::DEVICE_T_ITERATOR() )
1562template <
typename T>
1565 SIM_MODEL::DEVICE_T deviceType =
curModel().GetDeviceType();
1568 for( SIM_MODEL::TYPE type : { SIM_MODEL::TYPE::KIBIS_DEVICE,
1569 SIM_MODEL::TYPE::KIBIS_DRIVER_DC,
1570 SIM_MODEL::TYPE::KIBIS_DRIVER_RECT,
1571 SIM_MODEL::TYPE::KIBIS_DRIVER_PRBS } )
1584 m_libraryModelsMgr.SetModel( idx, std::make_unique<SIM_MODEL_IBIS>( type, baseModel ) );
1605template <
typename T>
1608 SIM_MODEL::DEVICE_T deviceType =
curModel().GetDeviceType();
1611 for( SIM_MODEL::TYPE type : SIM_MODEL::TYPE_ITERATOR() )
1626template <
typename T>
1633template <
typename T>
1636 int symbolPinIndex = aEvent.GetRow();
1637 wxString oldModelPinName = aEvent.GetString();
1638 wxString modelPinName =
m_pinAssignmentsGrid->GetCellValue( aEvent.GetRow(), aEvent.GetCol() );
1644 curModel().AssignSymbolPinNumberToModelPin( oldModelPinIndex,
"" );
1659template <
typename T>
1672template <
typename T>
1679 wxPGProperty* selected =
grid->GetSelection();
1682 selected =
grid->wxPropertyGridInterface::GetFirst();
1684#if wxCHECK_VERSION( 3, 3, 0 )
1686 grid->DoSelectProperty( selected, wxPGSelectPropertyFlags::Focus );
1689 grid->DoSelectProperty( selected, wxPG_SEL_FOCUS );
1696template <
typename T>
1702 if(
grid->GetSelection() &&
grid->GetSelection()->IsCategory() )
1704 wxPGProperty* selection =
grid->GetSelection();
1709 wxPropertyGridIterator it =
grid->GetIterator( wxPG_ITERATE_VISIBLE, selection );
1712 wxKeyEvent* keyEvent =
new wxKeyEvent( wxEVT_KEY_DOWN );
1716 if( !selection->IsExpanded() )
1718 grid->Expand( selection );
1719 keyEvent->m_keyCode = WXK_DOWN;
1720 wxQueueEvent(
grid, keyEvent );
1728 keyEvent->m_keyCode = WXK_UP;
1729 wxQueueEvent(
grid, keyEvent );
1734 if( !selection->IsExpanded() )
1735 grid->Expand( selection );
1737 keyEvent->m_keyCode = WXK_DOWN;
1738 wxQueueEvent(
grid, keyEvent );
1745 wxWindow* editorControl =
grid->GetEditorControl();
1747 if( !editorControl )
1754 editorControl->SetFocus();
1759template <
typename T>
1771 wxTextCtrl* ctrl =
grid->GetEditorTextCtrl();
1775 wxRect ctrlRect = ctrl->GetScreenRect();
1776 wxRect gridRect =
grid->GetScreenRect();
1778 if( ctrlRect.GetTop() < gridRect.GetTop() || ctrlRect.GetBottom() > gridRect.GetBottom() )
1779 grid->ClearSelection();
1785template <
typename T>
1798 std::vector<int> colWidths;
1800 for(
size_t ii = 0; ii <
grid->GetColumnCount(); ii++ )
1803 colWidths.push_back(
grid->GetState()->GetColumnWidth( ii ) + margin + indent );
1805 colWidths.push_back( std::max( 72,
grid->GetState()->GetColumnWidth( ii ) ) + margin );
1807 colWidths.push_back( 60 + margin );
1809 aWidth -= colWidths[ ii ];
1812 for(
size_t ii = 0; ii <
grid->GetColumnCount(); ii++ )
1813 grid->SetColumnProportion( ii, colWidths[ ii ] );
1815 grid->ResetColumnSizes();
1816 grid->RefreshEditor();
1821template <
typename T>
wxBitmapBundle KiBitmapBundle(BITMAPS aBitmap, int aMinHeight)
wxNotebook * m_modelNotebook
wxStaticText * m_subcktLabel
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_waveformChoice
wxStaticText * m_deviceLabel
WX_GRID * m_pinAssignmentsGrid
wxStaticText * m_pinModelLabel
wxPanel * m_parametersPanel
wxStaticText * m_deviceSubtypeLabel
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)
void adjustParamGridColumns(int aWidth, bool aForce)
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
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
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 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
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.
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_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.
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.