30#include <pegtl/contrib/parse_tree.hpp>
60 std::vector<std::string> currentNames;
63 currentNames.push_back( fmt::format(
"I({}:{})",
ItemName( aItem ),
pin.modelPinName ) );
70 const std::string& aSpiceCode )
72 tao::pegtl::string_input<> in( aSpiceCode,
"from_content" );
73 std::unique_ptr<tao::pegtl::parse_tree::node> root;
82 catch(
const tao::pegtl::parse_error& e )
89 for(
const auto& node : root->children )
93 for(
const auto& subnode : node->children )
100 model.
AddPin( { subnode->string(), fmt::format(
"{}", model.
GetPinCount() + 1 ) } );
104 for(
const auto& subsubnode : subnode->children )
108 model.
m_paramInfos.push_back( std::make_unique<SIM_MODEL::PARAM::INFO>() );
118 model.
m_paramInfos.back()->defaultValue = subsubnode->string();
122 wxFAIL_MSG(
"Unhandled parse tree subsubnode" );
130 wxFAIL_MSG(
"Unhandled parse tree node" );
165 return baseModel->GetSpiceCode();
std::string GetSpiceCode() const
void SetBaseModel(const SIM_MODEL &aBaseModel) override
std::vector< std::unique_ptr< PARAM::INFO > > m_paramInfos
const SIM_MODEL * GetBaseModel() const
void AddParam(const PARAM::INFO &aInfo)
void AddPin(const SIM_MODEL_PIN &aPin)
virtual const PARAM & GetParam(unsigned aParamIndex) const
virtual void SetBaseModel(const SIM_MODEL &aBaseModel)
int GetParamCount() const
std::vector< std::reference_wrapper< const SIM_MODEL_PIN > > GetPins() const
const SIM_MODEL * m_baseModel
std::vector< std::string > CurrentNames(const SPICE_ITEM &aItem) const override
std::string ModelLine(const SPICE_ITEM &aItem) const override
virtual std::string ItemName(const SPICE_ITEM &aItem) const
virtual std::vector< std::reference_wrapper< const SIM_MODEL_PIN > > GetPins() const
void ReadModel(const SIM_LIBRARY_SPICE &aLibrary, const std::string &aSpiceCode) override
SIM_MODEL_SPICE & m_model
#define THROW_IO_ERROR(msg)
must_if< error >::control< Rule > control