KiCad PCB EDA Suite
Loading...
Searching...
No Matches
common/netlist_reader/netlist.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <https://www.gnu.org/licenses/>.
18 */
19
20#ifndef NETLIST_H
21#define NETLIST_H
22
23#include <boost/ptr_container/ptr_vector.hpp>
24#include <wx/arrstr.h>
25#include <wx/string.h>
26#include <json_common.h>
27#include <unordered_set>
28#include <set>
29
30#include <lib_id.h>
31#include <kiid.h>
32#include <ctl_flags.h>
33
34
35class OUTPUTFORMATTER;
36
37
43{
44public:
46
47 COMPONENT_NET( const wxString& aPinName, const wxString& aNetName,
48 const wxString& aPinFunction, const wxString& aPinType ) :
49 m_pinName( aPinName ),
50 m_netName( aNetName ),
51 m_pinFunction( aPinFunction ),
52 m_pinType( aPinType )
53 {
54 }
55
56 const wxString& GetPinName() const { return m_pinName; }
57 const wxString& GetNetName() const { return m_netName; }
58 const wxString& GetPinFunction() const { return m_pinFunction; }
59 const wxString& GetPinType() const { return m_pinType; }
60
61 bool IsValid() const { return !m_pinName.IsEmpty(); }
62
63 bool operator <( const COMPONENT_NET& aNet ) const
64 {
65 return m_pinName < aNet.m_pinName;
66 }
67
68 int Format( OUTPUTFORMATTER* aOut, int aNestLevel, int aCtl );
69
70private:
71 wxString m_pinName;
72 wxString m_netName;
73 wxString m_pinFunction;
74 wxString m_pinType;
75};
76
77
78typedef std::vector< COMPONENT_NET > COMPONENT_NETS;
79
80
82{
83 wxString name;
86 std::vector<KIID> members;
87};
88
89typedef boost::ptr_vector< NETLIST_GROUP > NETLIST_GROUPS;
90
91
100{
101public:
102 COMPONENT( const LIB_ID& aFPID,
103 const wxString& aReference,
104 const wxString& aValue,
105 const KIID_PATH& aPath,
106 const std::vector<KIID>& aKiids )
107 {
108 m_fpid = aFPID;
109 m_reference = aReference;
110 m_value = aValue;
111 m_pinCount = 0;
112 m_path = aPath;
113 m_kiids = aKiids;
115 m_group = nullptr;
116 }
117
118 virtual ~COMPONENT() { };
119
120 void AddNet( const wxString& aPinName, const wxString& aNetName, const wxString& aPinFunction,
121 const wxString& aPinType )
122 {
123 m_nets.emplace_back( aPinName, aNetName, aPinFunction, aPinType );
124 }
125
126 unsigned GetNetCount() const { return m_nets.size(); }
127
128 const COMPONENT_NET& GetNet( unsigned aIndex ) const { return m_nets[aIndex]; }
129
130 const COMPONENT_NET& GetNet( const wxString& aPinName ) const;
131
132 void ClearNets() { m_nets.clear(); }
133
134 void SortPins() { sort( m_nets.begin(), m_nets.end() ); }
135
136 void SetName( const wxString& aName ) { m_name = aName;}
137 const wxString& GetName() const { return m_name; }
138
139 void SetLibrary( const wxString& aLibrary ) { m_library = aLibrary; }
140 const wxString& GetLibrary() const { return m_library; }
141
142 void SetReference( const wxString& aReference ) { m_reference = aReference; }
143 const wxString& GetReference() const { return m_reference; }
144
145 void SetValue( const wxString& aValue ) { m_value = aValue; }
146 const wxString& GetValue() const { return m_value; }
147
148 void SetFields( nlohmann::ordered_map<wxString, wxString> aFields )
149 {
150 m_fields = std::move( aFields );
151 }
152 const nlohmann::ordered_map<wxString, wxString>& GetFields() const { return m_fields; }
153
154 void SetProperties( std::map<wxString, wxString> aProps )
155 {
156 m_properties = std::move( aProps );
157 }
158 const std::map<wxString, wxString>& GetProperties() const { return m_properties; }
159
160 void SetFPID( const LIB_ID& aFPID ) { m_fpid = aFPID; }
161 const LIB_ID& GetFPID() const { return m_fpid; }
162
163 void SetAltFPID( const LIB_ID& aFPID ) { m_altFpid = aFPID; }
164 const LIB_ID& GetAltFPID() const { return m_altFpid; }
165
166 const KIID_PATH& GetPath() const { return m_path; }
167
168 const std::vector<KIID>& GetKIIDs() const { return m_kiids; }
169
170 void SetFootprintFilters( const wxArrayString& aFilters ) { m_footprintFilters = aFilters; }
171 const wxArrayString& GetFootprintFilters() const { return m_footprintFilters; }
172
173 void SetPinCount( int aPinCount ) { m_pinCount = aPinCount; }
174 int GetPinCount() const { return m_pinCount; }
175
176 bool IsLibSource( const wxString& aLibrary, const wxString& aName ) const
177 {
178 return aLibrary == m_library && aName == m_name;
179 }
180
181 void Format( OUTPUTFORMATTER* aOut, int aNestLevel, int aCtl );
182
183 void SetHumanReadablePath( const wxString& aPath ) { m_humanReadablePath = aPath; }
184 const wxString& GetHumanReadablePath() const { return m_humanReadablePath; }
185
186 void SetComponentClassNames( const std::unordered_set<wxString>& aClassNames )
187 {
188 m_componentClassNames = aClassNames;
189 }
190
191 std::unordered_set<wxString>& GetComponentClassNames() { return m_componentClassNames; }
192
195
196 std::vector<std::set<wxString>>& JumperPadGroups() { return m_jumperPadGroups; }
197 const std::vector<std::set<wxString>>& JumperPadGroups() const { return m_jumperPadGroups; }
198
199 NETLIST_GROUP* GetGroup() const { return m_group; }
200 void SetGroup( NETLIST_GROUP* aGroup ) { m_group = aGroup; }
201
202 // Unit info for multi-unit symbols
204 {
205 wxString m_unitName; // e.g. A
206 std::vector<wxString> m_pins; // pin numbers in this unit
207 };
208
209 void SetUnitInfo( const std::vector<UNIT_INFO>& aUnits ) { m_units = aUnits; }
210 const std::vector<UNIT_INFO>& GetUnitInfo() const { return m_units; }
211
212protected:
213 std::vector<COMPONENT_NET> m_nets;
214
215 wxArrayString m_footprintFilters;
217 wxString m_reference;
218 wxString m_value;
219
220 // human-readable hierarchical sheet path (e.g. /root/block0/sheet1)
222
225
227 std::vector<KIID> m_kiids;
228
230 wxString m_name;
231
233 wxString m_library;
234
237
242
244 std::map<wxString, wxString> m_properties;
245
247 nlohmann::ordered_map<wxString, wxString> m_fields;
248
250 std::unordered_set<wxString> m_componentClassNames;
251
253 std::vector<std::set<wxString>> m_jumperPadGroups;
254
258
261
263
264 // Unit information parsed from the netlist (optional)
265 std::vector<UNIT_INFO> m_units;
266};
267
268
269typedef boost::ptr_vector< COMPONENT > COMPONENTS;
270
271
277{
278public:
280 m_findByTimeStamp( false ),
281 m_replaceFootprints( false )
282 {
283 }
284
285 virtual ~NETLIST() = default;
286
290 bool IsEmpty() const { return m_components.empty(); }
291
295 void Clear() { m_components.clear(); }
296
300 unsigned GetCount() const { return m_components.size(); }
301
308 COMPONENT* GetComponent( unsigned aIndex ) { return &m_components[ aIndex ]; }
309
318 void AddComponent( COMPONENT* aComponent );
319
326 void AddGroup( NETLIST_GROUP* aGroup );
327
335 NETLIST_GROUP* GetGroupByUuid( const KIID& aUuid );
336
342
349 COMPONENT* GetComponentByReference( const wxString& aReference );
350
357 COMPONENT* GetComponentByPath( const KIID_PATH& aPath );
358
365 COMPONENT* GetComponentByUuid( const KIID& aUuid );
366
367 void SortByFPID();
368 void SortByReference();
369
370 void SetFindByTimeStamp( bool aFindByTimeStamp ) { m_findByTimeStamp = aFindByTimeStamp; }
371 bool IsFindByTimeStamp() const { return m_findByTimeStamp; }
372
373 void SetReplaceFootprints( bool aReplace ) { m_replaceFootprints = aReplace; }
375
379 bool AnyFootprintsLinked() const;
380
381 void Format( const char* aDocName, OUTPUTFORMATTER* aOut, int aNestLevel, int aCtl = 0 );
382
383#define CTL_FOR_CVPCB (CTL_OMIT_NETS | CTL_OMIT_FILTERS | CTL_OMIT_EXTRA)
384
386 {
387 Format( "cvpcb_netlist", aOut, 0, CTL_FOR_CVPCB );
388 }
389
390protected:
391 COMPONENTS m_components; // Components found in the netlist.
392 NETLIST_GROUPS m_groups; // Groups found in the netlist.
393
394 bool m_findByTimeStamp; // Associate components by KIID (or refdes if false)
395 bool m_replaceFootprints; // Update footprints to match footprints defined in netlist
396};
397
398
399#endif // NETLIST_H
Used to store the component pin name to net name (and pin function) associations stored in a netlist.
const wxString & GetNetName() const
COMPONENT_NET(const wxString &aPinName, const wxString &aNetName, const wxString &aPinFunction, const wxString &aPinType)
int Format(OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl)
bool operator<(const COMPONENT_NET &aNet) const
const wxString & GetPinFunction() const
const wxString & GetPinName() const
const wxString & GetPinType() const
Store all of the related component information found in a netlist.
const std::vector< std::set< wxString > > & JumperPadGroups() const
const std::vector< UNIT_INFO > & GetUnitInfo() const
const wxString & GetHumanReadablePath() const
const COMPONENT_NET & GetNet(unsigned aIndex) const
const KIID_PATH & GetPath() const
void SetValue(const wxString &aValue)
std::vector< COMPONENT_NET > m_nets
list of nets shared by the component pins
void SetLibrary(const wxString &aLibrary)
std::map< wxString, wxString > m_properties
Component-specific properties found in the netlist.
wxArrayString m_footprintFilters
const wxString & GetReference() const
void SetAltFPID(const LIB_ID &aFPID)
void Format(OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl)
const wxString & GetValue() const
void SetProperties(std::map< wxString, wxString > aProps)
KIID_PATH m_path
A fully specified path to the component (but not the component: [ sheetUUID, sheetUUID,...
const nlohmann::ordered_map< wxString, wxString > & GetFields() const
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 ...
const std::map< wxString, wxString > & GetProperties() const
nlohmann::ordered_map< wxString, wxString > m_fields
Component-specific user fields found in the netlist.
void SetFPID(const LIB_ID &aFPID)
void SetPinCount(int aPinCount)
void SetUnitInfo(const std::vector< UNIT_INFO > &aUnits)
std::unordered_set< wxString > m_componentClassNames
Component classes for this footprint.
wxString m_name
The name of the component in m_library used when it was placed on the schematic.
LIB_ID m_altFpid
The alt LIB_ID of the footprint, when there are 2 different assigned footprints, One from the netlist...
const LIB_ID & GetAltFPID() const
bool IsLibSource(const wxString &aLibrary, const wxString &aName) const
std::vector< KIID > m_kiids
A vector of possible KIIDs corresponding to all units in a symbol.
NETLIST_GROUP * GetGroup() const
void SetFootprintFilters(const wxArrayString &aFilters)
void AddNet(const wxString &aPinName, const wxString &aNetName, const wxString &aPinFunction, const wxString &aPinType)
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.
const wxArrayString & GetFootprintFilters() const
static COMPONENT_NET m_emptyNet
void SetFields(nlohmann::ordered_map< wxString, wxString > aFields)
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)
void SetHumanReadablePath(const wxString &aPath)
void SetDuplicatePadNumbersAreJumpers(bool aEnabled)
bool GetDuplicatePadNumbersAreJumpers() const
const LIB_ID & GetFPID() const
void SetGroup(NETLIST_GROUP *aGroup)
std::vector< UNIT_INFO > m_units
std::vector< std::set< wxString > > m_jumperPadGroups
Jumper pad groups for this footprint.
unsigned GetNetCount() const
std::unordered_set< wxString > & GetComponentClassNames()
const wxString & GetLibrary() const
void SetComponentClassNames(const std::unordered_set< wxString > &aClassNames)
const wxString & GetName() const
std::vector< std::set< wxString > > & JumperPadGroups()
void SetName(const wxString &aName)
void SetReference(const wxString &aReference)
Definition kiid.h:44
A logical library item identifier and consists of various portions much like a URI.
Definition lib_id.h:45
void Format(const char *aDocName, OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl=0)
bool GetReplaceFootprints() const
void SetReplaceFootprints(bool aReplace)
unsigned GetCount() const
void AddGroup(NETLIST_GROUP *aGroup)
virtual ~NETLIST()=default
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.
void Clear()
Remove all components from the netlist.
COMPONENT * GetComponentByUuid(const KIID &aUuid)
Return a COMPONENT by aUuid.
void SetFindByTimeStamp(bool aFindByTimeStamp)
NETLIST_GROUP * GetGroupByUuid(const KIID &aUuid)
Return a NETLIST_GROUP by aUuid.
COMPONENT * GetComponent(unsigned aIndex)
Return the COMPONENT at aIndex.
void ApplyGroupMembership()
After groups and components are parsed, apply the group memberships to the internal components based ...
bool IsFindByTimeStamp() const
void FormatCvpcbNetlist(OUTPUTFORMATTER *aOut)
An interface used to output 8 bit text in a convenient way.
Definition richio.h:291
std::vector< COMPONENT_NET > COMPONENT_NETS
boost::ptr_vector< COMPONENT > COMPONENTS
boost::ptr_vector< NETLIST_GROUP > NETLIST_GROUPS
#define CTL_FOR_CVPCB
std::vector< KIID > members