32#include <wx/tokenzr.h>
38 return aOut->
Print( aNestLevel,
"(pin_net %s %s)",
52 if( aFootprint ==
nullptr )
61 std::vector<FOOTPRINT::FP_UNIT_INFO> fpUnits;
64 fpUnits.push_back( { u.m_unitName, u.m_pins } );
78 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
79 wxT(
"Looking for pin '%s' in component '%s'" ),
84 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
85 wxT(
" Checking net pin name '%s'" ),
88 if( net.GetPinName() == aPinName )
90 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
91 wxT(
" Found exact match for pin '%s'" ),
98 if( !expandedPins.empty() )
100 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
101 wxT(
" Pin name '%s' expanded to %zu pins" ),
102 net.GetPinName(), expandedPins.size() );
104 for(
const wxString& expandedPin : expandedPins )
106 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
107 wxT(
" Checking expanded pin '%s'" ),
109 if( expandedPin == aPinName )
111 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
112 wxT(
" Found match for pin '%s' in stacked notation '%s'" ),
113 aPinName, net.GetPinName() );
120 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
121 wxT(
" No net found for pin '%s'" ),
131 return it !=
m_variants.end() ? &it->second :
nullptr;
139 return it !=
m_variants.end() ? &it->second :
nullptr;
145 if( aVariant.
m_name.IsEmpty() )
153 updated.
m_name = it->first;
154 it->second = std::move( updated );
178 path +=
'/' + pathStep.AsString();
186 aOut->
Print( nl + 1,
"(fields" );
188 for( std::pair<wxString, wxString> field :
m_fields )
189 aOut->
Print( nl + 2,
"\n(field (name %s) %s)", aOut->
Quotew( field.first ).c_str(),
190 aOut->
Quotew( field.second ).c_str() );
192 aOut->
Print( 0,
")\n" );
196 aOut->
Print( nl + 1,
"(property (name \"dnp\"))\n" );
199 aOut->
Print( nl + 1,
"(property (name \"exclude_from_bom\"))\n" );
203 aOut->
Print( nl + 1,
"(variants" );
205 for(
const auto& [variantName, variant] :
m_variants )
207 aOut->
Print( nl + 2,
"\n(variant (name %s)",
208 aOut->
Quotew( variantName ).c_str() );
210 if( variant.m_hasDnp )
212 aOut->
Print( 0,
" (property (name \"dnp\") (value %s))",
213 aOut->
Quotew( variant.m_dnp ? wxT(
"1" ) : wxT(
"0" ) ).c_str() );
216 if( variant.m_hasExcludedFromBOM )
218 aOut->
Print( 0,
" (property (name \"exclude_from_bom\") (value %s))",
219 aOut->
Quotew( variant.m_excludedFromBOM ? wxT(
"1" ) : wxT(
"0" ) ).c_str() );
222 if( variant.m_hasExcludedFromSim )
224 aOut->
Print( 0,
" (property (name \"exclude_from_sim\") (value %s))",
225 aOut->
Quotew( variant.m_excludedFromSim ? wxT(
"1" ) : wxT(
"0" ) ).c_str() );
228 if( variant.m_hasExcludedFromPosFiles )
230 aOut->
Print( 0,
" (property (name \"exclude_from_pos_files\") (value %s))",
231 aOut->
Quotew( variant.m_excludedFromPosFiles ? wxT(
"1" ) : wxT(
"0" ) ).c_str() );
234 if( !variant.m_fields.empty() )
236 aOut->
Print( 0,
"\n" );
237 aOut->
Print( nl + 3,
"(fields" );
239 for(
const auto& [fieldName, fieldValue] : variant.m_fields )
241 aOut->
Print( nl + 4,
"\n(field (name %s) %s)",
242 aOut->
Quotew( fieldName ).c_str(),
243 aOut->
Quotew( fieldValue ).c_str() );
246 aOut->
Print( 0,
")" );
249 aOut->
Print( 0,
")" );
252 aOut->
Print( 0,
")\n" );
258 aOut->
Print( nl+1,
"(fp_filters" );
263 aOut->
Print( 0,
")\n" );
268 int llen = aOut->
Print( nl+1,
"(nets " );
270 for(
unsigned i = 0; i <
m_nets.size(); ++i )
274 aOut->
Print( 0,
"\n" );
275 llen = aOut->
Print( nl+1,
" " );
278 llen +=
m_nets[i].Format( aOut, 0, aCtl );
281 aOut->
Print( 0,
")\n" );
284 aOut->
Print( nl,
")\n" );
292 aOut->
Print( nl,
"(%s\n", aDocName );
299 aOut->
Print( nl,
")\n" );
318 if(
group.uuid == aUuid )
345 if( aUuidPath.empty() )
348 KIID comp_uuid = aUuidPath.back();
349 KIID_PATH base = aUuidPath;
356 const std::vector<KIID>& kiids = component.
GetKIIDs();
358 if( base != component.
GetPath() )
361 if( std::find( kiids.begin(), kiids.end(), comp_uuid ) != kiids.end() )
376 for(
const KIID& compUuid : component.
GetKIIDs() )
378 if( aUuid == compUuid )
433 for( KIID& member :
group.members )
Used to store the component pin name to net name (and pin function) associations stored in a netlist.
int Format(OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl)
Store all of the related component information found in a netlist.
const COMPONENT_NET & GetNet(unsigned aIndex) const
const KIID_PATH & GetPath() const
std::vector< COMPONENT_NET > m_nets
list of nets shared by the component pins
std::map< wxString, wxString > m_properties
Component-specific properties found in the netlist.
wxArrayString m_footprintFilters
const wxString & GetReference() const
void AddVariant(const COMPONENT_VARIANT &aVariant)
CASE_INSENSITIVE_MAP< COMPONENT_VARIANT > m_variants
void Format(OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl)
const COMPONENT_VARIANT * GetVariant(const wxString &aVariantName) const
KIID_PATH m_path
A fully specified path to the component (but not the component: [ sheetUUID, sheetUUID,...
nlohmann::ordered_map< wxString, wxString > m_fields
Component-specific user fields found in the netlist.
wxString m_name
The name of the component in m_library used when it was placed on the schematic.
void SetFootprint(FOOTPRINT *aFootprint)
std::vector< KIID > m_kiids
A vector of possible KIIDs corresponding to all units in a symbol.
wxString m_library
The name of the component library where m_name was found.
LIB_ID m_fpid
The LIB_ID of the footprint assigned to the component.
static COMPONENT_NET m_emptyNet
const std::vector< KIID > & GetKIIDs() const
std::unique_ptr< FOOTPRINT > m_footprint
The FOOTPRINT loaded for #m_FPID.
const LIB_ID & GetFPID() const
void SetGroup(NETLIST_GROUP *aGroup)
std::vector< UNIT_INFO > m_units
void Format(const char *aDocName, OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl=0)
void AddGroup(NETLIST_GROUP *aGroup)
void AddComponent(COMPONENT *aComponent)
Add aComponent to the NETLIST.
COMPONENT * GetComponentByPath(const KIID_PATH &aPath)
Return a COMPONENT by aPath.
COMPONENT * GetComponentByReference(const wxString &aReference)
Return a COMPONENT by aReference.
COMPONENT * GetComponentByUuid(const KIID &aUuid)
Return a COMPONENT by aUuid.
NETLIST_GROUP * GetGroupByUuid(const KIID &aUuid)
Return a NETLIST_GROUP by aUuid.
void ApplyGroupMembership()
After groups and components are parsed, apply the group memberships to the internal components based ...
bool AnyFootprintsLinked() const
static bool ByFPID(const COMPONENT &ref, const COMPONENT &cmp)
A helper function used to sort the component list used by loadNewModules.
#define CTL_OMIT_FP_UUID
Don't prefix the footprint UUID to the sheet path.
#define CTL_OMIT_FILTERS
Omit the ki_fp_filters attribute in .kicad_xxx files.
static bool empty(const wxTextEntryBase *aCtrl)
bool operator<(const COMPONENT &item1, const COMPONENT &item2)
Compare two COMPONENT objects by reference designator.
static bool ByFPID(const COMPONENT &ref, const COMPONENT &cmp)
A helper function used to sort the component list used by loadNewModules.
int StrNumCmp(const wxString &aString1, const wxString &aString2, bool aIgnoreCase)
Compare two strings with alphanumerical content.
std::vector< wxString > ExpandStackedPinNotation(const wxString &aPinName, bool *aValid)
Expand stacked pin notation like [1,2,3], [1-4], [A1-A4], or [AA1-AA3,AB4,CD12-CD14] into individual ...