28#include <wx/tokenzr.h>
38 return aOut->
Print( aNestLevel,
"(pin_net %s %s)",
44 const wxString& aReference,
45 const wxString& aValue,
47 const std::vector<KIID>& aKiids )
79 if( aFootprint ==
nullptr )
88 std::vector<FOOTPRINT::FP_UNIT_INFO> fpUnits;
91 fpUnits.push_back( { u.m_unitName, u.m_pins } );
105 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
106 wxT(
"Looking for pin '%s' in component '%s'" ),
111 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
112 wxT(
" Checking net pin name '%s'" ),
115 if( net.GetPinName() == aPinName )
117 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
118 wxT(
" Found exact match for pin '%s'" ),
125 if( !expandedPins.empty() )
127 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
128 wxT(
" Pin name '%s' expanded to %zu pins" ),
129 net.GetPinName(), expandedPins.size() );
131 for(
const wxString& expandedPin : expandedPins )
133 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
134 wxT(
" Checking expanded pin '%s'" ),
136 if( expandedPin == aPinName )
138 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
139 wxT(
" Found match for pin '%s' in stacked notation '%s'" ),
140 aPinName, net.GetPinName() );
147 wxLogTrace( wxT(
"NETLIST_STACKED_PINS" ),
148 wxT(
" No net found for pin '%s'" ),
158 return it !=
m_variants.end() ? &it->second :
nullptr;
166 return it !=
m_variants.end() ? &it->second :
nullptr;
172 if( aVariant.
m_name.IsEmpty() )
180 updated.
m_name = it->first;
181 it->second = std::move( updated );
205 path +=
'/' + pathStep.AsString();
213 aOut->
Print( nl + 1,
"(fields" );
215 for( std::pair<wxString, wxString> field :
m_fields )
216 aOut->
Print( nl + 2,
"\n(field (name %s) %s)", aOut->
Quotew( field.first ).c_str(),
217 aOut->
Quotew( field.second ).c_str() );
219 aOut->
Print( 0,
")\n" );
223 aOut->
Print( nl + 1,
"(property (name \"dnp\"))\n" );
226 aOut->
Print( nl + 1,
"(property (name \"exclude_from_bom\"))\n" );
230 aOut->
Print( nl + 1,
"(variants" );
232 for(
const auto& [variantName, variant] :
m_variants )
234 aOut->
Print( nl + 2,
"\n(variant (name %s)",
235 aOut->
Quotew( variantName ).c_str() );
237 if( variant.m_hasDnp )
239 aOut->
Print( 0,
" (property (name \"dnp\") (value %s))",
240 aOut->
Quotew( variant.m_dnp ? wxT(
"1" ) : wxT(
"0" ) ).c_str() );
243 if( variant.m_hasExcludedFromBOM )
245 aOut->
Print( 0,
" (property (name \"exclude_from_bom\") (value %s))",
246 aOut->
Quotew( variant.m_excludedFromBOM ? wxT(
"1" ) : wxT(
"0" ) ).c_str() );
249 if( variant.m_hasExcludedFromSim )
251 aOut->
Print( 0,
" (property (name \"exclude_from_sim\") (value %s))",
252 aOut->
Quotew( variant.m_excludedFromSim ? wxT(
"1" ) : wxT(
"0" ) ).c_str() );
255 if( variant.m_hasExcludedFromPosFiles )
257 aOut->
Print( 0,
" (property (name \"exclude_from_pos_files\") (value %s))",
258 aOut->
Quotew( variant.m_excludedFromPosFiles ? wxT(
"1" ) : wxT(
"0" ) ).c_str() );
261 if( !variant.m_fields.empty() )
263 aOut->
Print( 0,
"\n" );
264 aOut->
Print( nl + 3,
"(fields" );
266 for(
const auto& [fieldName, fieldValue] : variant.m_fields )
268 aOut->
Print( nl + 4,
"\n(field (name %s) %s)",
269 aOut->
Quotew( fieldName ).c_str(),
270 aOut->
Quotew( fieldValue ).c_str() );
273 aOut->
Print( 0,
")" );
276 aOut->
Print( 0,
")" );
279 aOut->
Print( 0,
")\n" );
285 aOut->
Print( nl+1,
"(fp_filters" );
290 aOut->
Print( 0,
")\n" );
295 int llen = aOut->
Print( nl+1,
"(nets " );
297 for(
unsigned i = 0; i <
m_nets.size(); ++i )
301 aOut->
Print( 0,
"\n" );
302 llen = aOut->
Print( nl+1,
" " );
305 llen +=
m_nets[i].Format( aOut, 0, aCtl );
308 aOut->
Print( 0,
")\n" );
311 aOut->
Print( nl,
")\n" );
319 aOut->
Print( nl,
"(%s\n", aDocName );
326 aOut->
Print( nl,
")\n" );
345 if(
group.uuid == aUuid )
372 if( aUuidPath.empty() )
375 KIID comp_uuid = aUuidPath.back();
376 KIID_PATH base = aUuidPath;
383 const std::vector<KIID>& kiids = component.
GetKIIDs();
385 if( base != component.
GetPath() )
388 if( std::find( kiids.begin(), kiids.end(), comp_uuid ) != kiids.end() )
403 for(
const KIID& compUuid : component.
GetKIIDs() )
405 if( aUuid == compUuid )
460 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,...
NETLIST_GROUP * m_group
Group membership for this footprint. Nullptr if none.
bool m_duplicatePadNumbersAreJumpers
Flag that this footprint should automatically treat sets of two or more pads with the same number as ...
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.
FOOTPRINT * GetFootprint(bool aRelease=false)
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
COMPONENT(const LIB_ID &aFPID, const wxString &aReference, const wxString &aValue, const KIID_PATH &aPath, const std::vector< KIID > &aKiids)
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
A logical library item identifier and consists of various portions much like a URI.
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 ...