KiCad PCB EDA Suite
Loading...
Searching...
No Matches
pcb_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 (C) 2012 Jean-Pierre Charras.
5 * Copyright (C) 2013-2016 Wayne Stambaugh <[email protected]>.
6 * Copyright (C) 2012-2022 KiCad Developers, see AUTHORS.txt for contributors.
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License
10 * as published by the Free Software Foundation; either version 2
11 * of the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, you may find one here:
20 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
21 * or you may search the http://www.gnu.org website for the version 2 license,
22 * or you may write to the Free Software Foundation, Inc.,
23 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
24 */
25
26#ifndef PCB_NETLIST_H
27#define PCB_NETLIST_H
28
29#include <boost/ptr_container/ptr_vector.hpp>
30#include <wx/arrstr.h>
31#include <nlohmann/json.hpp>
32#include <unordered_set>
33
34#include <lib_id.h>
35#include <footprint.h>
36#include <ctl_flags.h>
37
38
39class REPORTER;
40
41
47{
48public:
50
51 COMPONENT_NET( const wxString& aPinName, const wxString& aNetName,
52 const wxString& aPinFunction, const wxString& aPinType ) :
53 m_pinName( aPinName ),
54 m_netName( aNetName ),
55 m_pinFunction( aPinFunction ),
56 m_pinType( aPinType )
57 {
58 }
59
60 const wxString& GetPinName() const { return m_pinName; }
61 const wxString& GetNetName() const { return m_netName; }
62 const wxString& GetPinFunction() const { return m_pinFunction; }
63 const wxString& GetPinType() const { return m_pinType; }
64
65 bool IsValid() const { return !m_pinName.IsEmpty(); }
66
67 bool operator <( const COMPONENT_NET& aNet ) const
68 {
69 return m_pinName < aNet.m_pinName;
70 }
71
72 int Format( OUTPUTFORMATTER* aOut, int aNestLevel, int aCtl );
73
74private:
75 wxString m_pinName;
76 wxString m_netName;
77 wxString m_pinFunction;
78 wxString m_pinType;
79};
80
81
82typedef std::vector< COMPONENT_NET > COMPONENT_NETS;
83
88{
89public:
90 COMPONENT( const LIB_ID& aFPID,
91 const wxString& aReference,
92 const wxString& aValue,
93 const KIID_PATH& aPath,
94 const std::vector<KIID>& aKiids )
95 {
96 m_fpid = aFPID;
97 m_reference = aReference;
98 m_value = aValue;
99 m_pinCount = 0;
100 m_path = aPath;
101 m_kiids = aKiids;
102 }
103
104 virtual ~COMPONENT() { };
105
106 void AddNet( const wxString& aPinName, const wxString& aNetName, const wxString& aPinFunction,
107 const wxString& aPinType )
108 {
109 m_nets.emplace_back( aPinName, aNetName, aPinFunction, aPinType );
110 }
111
112 unsigned GetNetCount() const { return m_nets.size(); }
113
114 const COMPONENT_NET& GetNet( unsigned aIndex ) const { return m_nets[aIndex]; }
115
116 const COMPONENT_NET& GetNet( const wxString& aPinName ) const;
117
118 void ClearNets() { m_nets.clear(); }
119
120 void SortPins() { sort( m_nets.begin(), m_nets.end() ); }
121
122 void SetName( const wxString& aName ) { m_name = aName;}
123 const wxString& GetName() const { return m_name; }
124
125 void SetLibrary( const wxString& aLibrary ) { m_library = aLibrary; }
126 const wxString& GetLibrary() const { return m_library; }
127
128 void SetReference( const wxString& aReference ) { m_reference = aReference; }
129 const wxString& GetReference() const { return m_reference; }
130
131 void SetValue( const wxString& aValue ) { m_value = aValue; }
132 const wxString& GetValue() const { return m_value; }
133
134 void SetFields( nlohmann::ordered_map<wxString, wxString>& aFields )
135 {
136 m_fields = std::move( aFields );
137 }
138 const nlohmann::ordered_map<wxString, wxString>& GetFields() const { return m_fields; }
139
140 void SetProperties( std::map<wxString, wxString>& aProps )
141 {
142 m_properties = std::move( aProps );
143 }
144 const std::map<wxString, wxString>& GetProperties() const { return m_properties; }
145
146 void SetFPID( const LIB_ID& aFPID ) { m_fpid = aFPID; }
147 const LIB_ID& GetFPID() const { return m_fpid; }
148
149 void SetAltFPID( const LIB_ID& aFPID ) { m_altFpid = aFPID; }
150 const LIB_ID& GetAltFPID() const { return m_altFpid; }
151
152 const KIID_PATH& GetPath() const { return m_path; }
153
154 const std::vector<KIID>& GetKIIDs() const { return m_kiids; }
155
156 void SetFootprintFilters( const wxArrayString& aFilters ) { m_footprintFilters = aFilters; }
157 const wxArrayString& GetFootprintFilters() const { return m_footprintFilters; }
158
159 void SetPinCount( int aPinCount ) { m_pinCount = aPinCount; }
160 int GetPinCount() const { return m_pinCount; }
161
162 FOOTPRINT* GetFootprint( bool aRelease = false )
163 {
164 return ( aRelease ) ? m_footprint.release() : m_footprint.get();
165 }
166
167 void SetFootprint( FOOTPRINT* aFootprint );
168
169 bool IsLibSource( const wxString& aLibrary, const wxString& aName ) const
170 {
171 return aLibrary == m_library && aName == m_name;
172 }
173
174 void Format( OUTPUTFORMATTER* aOut, int aNestLevel, int aCtl );
175
176 void SetHumanReadablePath( const wxString& aPath ) { m_humanReadablePath = aPath; }
177 const wxString& GetHumanReadablePath() const { return m_humanReadablePath; }
178
179 void SetComponentClassNames( const std::unordered_set<wxString>& aClassNames )
180 {
181 m_componentClassNames = aClassNames;
182 }
183
184 std::unordered_set<wxString>& GetComponentClassNames() { return m_componentClassNames; }
185
186private:
187 std::vector<COMPONENT_NET> m_nets;
188
189 wxArrayString m_footprintFilters;
191 wxString m_reference;
192 wxString m_value;
193
194 // human-readable hierarchical sheet path (e.g. /root/block0/sheet1)
196
199
201 std::vector<KIID> m_kiids;
202
204 wxString m_name;
205
207 wxString m_library;
208
211
216
218 std::unique_ptr<FOOTPRINT> m_footprint;
219
221 std::map<wxString, wxString> m_properties;
222
224 nlohmann::ordered_map<wxString, wxString> m_fields;
225
227 std::unordered_set<wxString> m_componentClassNames;
228
230};
231
232
233typedef boost::ptr_vector< COMPONENT > COMPONENTS;
234
235
241{
242public:
244 m_findByTimeStamp( false ),
245 m_replaceFootprints( false )
246 {
247 }
248
252 bool IsEmpty() const { return m_components.empty(); }
253
257 void Clear() { m_components.clear(); }
258
262 unsigned GetCount() const { return m_components.size(); }
263
270 COMPONENT* GetComponent( unsigned aIndex ) { return &m_components[ aIndex ]; }
271
280 void AddComponent( COMPONENT* aComponent );
281
288 COMPONENT* GetComponentByReference( const wxString& aReference );
289
296 COMPONENT* GetComponentByPath( const KIID_PATH& aPath );
297
298 void SortByFPID();
299 void SortByReference();
300
301 void SetFindByTimeStamp( bool aFindByTimeStamp ) { m_findByTimeStamp = aFindByTimeStamp; }
302 bool IsFindByTimeStamp() const { return m_findByTimeStamp; }
303
304 void SetReplaceFootprints( bool aReplace ) { m_replaceFootprints = aReplace; }
306
310 bool AnyFootprintsLinked() const;
311
312 void Format( const char* aDocName, OUTPUTFORMATTER* aOut, int aNestLevel, int aCtl = 0 );
313
314#define CTL_FOR_CVPCB (CTL_OMIT_NETS | CTL_OMIT_FILTERS | CTL_OMIT_EXTRA)
315
317 {
318 Format( "cvpcb_netlist", aOut, 0, CTL_FOR_CVPCB );
319 }
320
321private:
322 COMPONENTS m_components; // Components found in the netlist.
323
324 bool m_findByTimeStamp; // Associate components by KIID (or refdes if false)
325 bool m_replaceFootprints; // Update footprints to match footprints defined in netlist
326};
327
328
329#endif // PCB_NETLIST_H
Used to store the component pin name to net name (and pin function) associations stored in a netlist.
Definition: pcb_netlist.h:47
const wxString & GetNetName() const
Definition: pcb_netlist.h:61
wxString m_pinName
Definition: pcb_netlist.h:75
wxString m_pinType
Definition: pcb_netlist.h:78
COMPONENT_NET(const wxString &aPinName, const wxString &aNetName, const wxString &aPinFunction, const wxString &aPinType)
Definition: pcb_netlist.h:51
wxString m_pinFunction
Definition: pcb_netlist.h:77
int Format(OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl)
Definition: pcb_netlist.cpp:34
wxString m_netName
Definition: pcb_netlist.h:76
bool operator<(const COMPONENT_NET &aNet) const
Definition: pcb_netlist.h:67
bool IsValid() const
Definition: pcb_netlist.h:65
const wxString & GetPinFunction() const
Definition: pcb_netlist.h:62
const wxString & GetPinName() const
Definition: pcb_netlist.h:60
const wxString & GetPinType() const
Definition: pcb_netlist.h:63
Store all of the related footprint information found in a netlist.
Definition: pcb_netlist.h:88
const wxString & GetHumanReadablePath() const
Definition: pcb_netlist.h:177
const COMPONENT_NET & GetNet(unsigned aIndex) const
Definition: pcb_netlist.h:114
const KIID_PATH & GetPath() const
Definition: pcb_netlist.h:152
void SetValue(const wxString &aValue)
Definition: pcb_netlist.h:131
void SetFields(nlohmann::ordered_map< wxString, wxString > &aFields)
Definition: pcb_netlist.h:134
nlohmann::ordered_map< wxString, wxString > m_fields
Component-specific user fields found in the netlist.
Definition: pcb_netlist.h:224
void SetLibrary(const wxString &aLibrary)
Definition: pcb_netlist.h:125
void SetProperties(std::map< wxString, wxString > &aProps)
Definition: pcb_netlist.h:140
std::unordered_set< wxString > m_componentClassNames
Component classes for this footprint.
Definition: pcb_netlist.h:227
wxArrayString m_footprintFilters
Definition: pcb_netlist.h:189
const wxString & GetReference() const
Definition: pcb_netlist.h:129
virtual ~COMPONENT()
Definition: pcb_netlist.h:104
void SetAltFPID(const LIB_ID &aFPID)
Definition: pcb_netlist.h:149
void Format(OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl)
Definition: pcb_netlist.cpp:75
int m_pinCount
Definition: pcb_netlist.h:190
const wxString & GetValue() const
Definition: pcb_netlist.h:132
KIID_PATH m_path
A fully specified path to the component (but not the component: [ sheetUUID, sheetUUID,...
Definition: pcb_netlist.h:198
const nlohmann::ordered_map< wxString, wxString > & GetFields() const
Definition: pcb_netlist.h:138
wxString m_value
Definition: pcb_netlist.h:192
std::vector< KIID > m_kiids
A vector of possible KIIDs corresponding to all units in a symbol.
Definition: pcb_netlist.h:201
const std::map< wxString, wxString > & GetProperties() const
Definition: pcb_netlist.h:144
int GetPinCount() const
Definition: pcb_netlist.h:160
void SetFPID(const LIB_ID &aFPID)
Definition: pcb_netlist.h:146
void SortPins()
Definition: pcb_netlist.h:120
void SetPinCount(int aPinCount)
Definition: pcb_netlist.h:159
wxString m_reference
Definition: pcb_netlist.h:191
void ClearNets()
Definition: pcb_netlist.h:118
wxString m_name
The name of the component in m_library used when it was placed on the schematic.
Definition: pcb_netlist.h:204
LIB_ID m_altFpid
The alt LIB_ID of the footprint, when there are 2 different assigned footprints, One from the netlist...
Definition: pcb_netlist.h:215
const LIB_ID & GetAltFPID() const
Definition: pcb_netlist.h:150
wxString m_humanReadablePath
Definition: pcb_netlist.h:195
void SetFootprint(FOOTPRINT *aFootprint)
Definition: pcb_netlist.cpp:42
bool IsLibSource(const wxString &aLibrary, const wxString &aName) const
Definition: pcb_netlist.h:169
FOOTPRINT * GetFootprint(bool aRelease=false)
Definition: pcb_netlist.h:162
void SetFootprintFilters(const wxArrayString &aFilters)
Definition: pcb_netlist.h:156
void AddNet(const wxString &aPinName, const wxString &aNetName, const wxString &aPinFunction, const wxString &aPinType)
Definition: pcb_netlist.h:106
wxString m_library
The name of the component library where m_name was found.
Definition: pcb_netlist.h:207
LIB_ID m_fpid
The LIB_ID of the footprint assigned to the component.
Definition: pcb_netlist.h:210
const wxArrayString & GetFootprintFilters() const
Definition: pcb_netlist.h:157
std::vector< COMPONENT_NET > m_nets
list of nets shared by the component pins
Definition: pcb_netlist.h:187
const std::vector< KIID > & GetKIIDs() const
Definition: pcb_netlist.h:154
COMPONENT(const LIB_ID &aFPID, const wxString &aReference, const wxString &aValue, const KIID_PATH &aPath, const std::vector< KIID > &aKiids)
Definition: pcb_netlist.h:90
void SetHumanReadablePath(const wxString &aPath)
Definition: pcb_netlist.h:176
static COMPONENT_NET m_emptyNet
Definition: pcb_netlist.h:229
std::unique_ptr< FOOTPRINT > m_footprint
The FOOTPRINT loaded for #m_FPID.
Definition: pcb_netlist.h:218
std::map< wxString, wxString > m_properties
Component-specific properties found in the netlist.
Definition: pcb_netlist.h:221
const LIB_ID & GetFPID() const
Definition: pcb_netlist.h:147
unsigned GetNetCount() const
Definition: pcb_netlist.h:112
std::unordered_set< wxString > & GetComponentClassNames()
Definition: pcb_netlist.h:184
const wxString & GetLibrary() const
Definition: pcb_netlist.h:126
void SetComponentClassNames(const std::unordered_set< wxString > &aClassNames)
Definition: pcb_netlist.h:179
const wxString & GetName() const
Definition: pcb_netlist.h:123
void SetName(const wxString &aName)
Definition: pcb_netlist.h:122
void SetReference(const wxString &aReference)
Definition: pcb_netlist.h:128
A logical library item identifier and consists of various portions much like a URI.
Definition: lib_id.h:49
Store information read from a netlist along with the flags used to update the NETLIST in the BOARD.
Definition: pcb_netlist.h:241
void Format(const char *aDocName, OUTPUTFORMATTER *aOut, int aNestLevel, int aCtl=0)
bool GetReplaceFootprints() const
Definition: pcb_netlist.h:305
void SetReplaceFootprints(bool aReplace)
Definition: pcb_netlist.h:304
void SortByFPID()
bool m_findByTimeStamp
Definition: pcb_netlist.h:324
unsigned GetCount() const
Definition: pcb_netlist.h:262
void AddComponent(COMPONENT *aComponent)
Add aComponent to the NETLIST.
bool IsEmpty() const
Definition: pcb_netlist.h:252
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.
Definition: pcb_netlist.h:257
void SetFindByTimeStamp(bool aFindByTimeStamp)
Definition: pcb_netlist.h:301
COMPONENT * GetComponent(unsigned aIndex)
Return the COMPONENT at aIndex.
Definition: pcb_netlist.h:270
bool m_replaceFootprints
Definition: pcb_netlist.h:325
COMPONENTS m_components
Definition: pcb_netlist.h:322
bool IsFindByTimeStamp() const
Definition: pcb_netlist.h:302
void SortByReference()
void FormatCvpcbNetlist(OUTPUTFORMATTER *aOut)
Definition: pcb_netlist.h:316
bool AnyFootprintsLinked() const
An interface used to output 8 bit text in a convenient way.
Definition: richio.h:322
A pure virtual class used to derive REPORTER objects from.
Definition: reporter.h:72
std::vector< COMPONENT_NET > COMPONENT_NETS
Definition: pcb_netlist.h:82
boost::ptr_vector< COMPONENT > COMPONENTS
Definition: pcb_netlist.h:233
#define CTL_FOR_CVPCB
Definition: pcb_netlist.h:314