KiCad PCB EDA Suite
Loading...
Searching...
No Matches
net_settings.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) 2020 CERN
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 * @author Jon Evans <[email protected]>
7 *
8 * This program is free software: you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by the
10 * Free Software Foundation, either version 3 of the License, or (at your
11 * option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * 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, see <https://www.gnu.org/licenses/>.
20 */
21
22#ifndef KICAD_NET_SETTINGS_H
23#define KICAD_NET_SETTINGS_H
24
25#include <functional>
26#include <map>
27#include <memory>
28#include <set>
29#include <vector>
30
31#include <netclass.h>
33#include <eda_pattern_match.h>
34
40{
41public:
42 NET_SETTINGS( JSON_SETTINGS* aParent, const std::string& aPath );
43
44 virtual ~NET_SETTINGS();
45
46 bool operator==( const NET_SETTINGS& aOther ) const;
47
48 bool operator!=( const NET_SETTINGS& aOther ) const { return !operator==( aOther ); }
49
74 void CopyFrom( NET_SETTINGS& aOther );
75
78 void SetDefaultNetclass( std::shared_ptr<NETCLASS> netclass );
79
81 std::shared_ptr<NETCLASS> GetDefaultNetclass() const;
82
84 bool HasNetclass( const wxString& netclassName ) const;
85
88 void SetNetclass( const wxString& netclassName, std::shared_ptr<NETCLASS>& netclass );
89
92 void SetNetclasses( const std::map<wxString, std::shared_ptr<NETCLASS>>& netclasses );
93
95 const std::map<wxString, std::shared_ptr<NETCLASS>>& GetNetclasses() const;
96
98 // Note the full connectivity or board net synchronisation must be run before calling
99 // this, otherwise resolved netclasses may be missing
100 const std::map<wxString, std::shared_ptr<NETCLASS>>& GetCompositeNetclasses() const;
101
104 void ClearNetclasses();
105
107 const std::map<wxString, std::set<wxString>>& GetNetclassLabelAssignments() const;
108
111 void ClearNetclassLabelAssignments();
112
115 void ClearNetclassLabelAssignment( const wxString& netName );
116
119 void SetNetclassLabelAssignment( const wxString& netName,
120 const std::set<wxString>& netclasses );
121
124 void AppendNetclassLabelAssignment( const wxString& netName,
125 const std::set<wxString>& netclasses );
126
128 bool HasNetclassLabelAssignment( const wxString& netName ) const;
129
132 void SetNetclassPatternAssignment( const wxString& pattern, const wxString& netclass );
133
136 void SetNetclassPatternAssignments(
137 std::vector<std::pair<std::unique_ptr<EDA_COMBINED_MATCHER>, wxString>>&&
138 netclassPatterns );
139
141 std::vector<std::pair<std::unique_ptr<EDA_COMBINED_MATCHER>, wxString>>&
142 GetNetclassPatternAssignments();
143
145 void ClearNetclassPatternAssignments();
146
153 void SetChainPatternAssignment( const wxString& pattern, const wxString& netclass );
154
157 void ClearChainPatternAssignments();
158
161
163 void ClearCacheForNet( const wxString& netName );
164
166 void ClearAllCaches();
167
170 void SetNetColorAssignment( const wxString& netName, const KIGFX::COLOR4D& color );
171
173 const std::map<wxString, KIGFX::COLOR4D>& GetNetColorAssignments() const;
174
177 void ClearNetColorAssignments();
178
180 void SetNetChainClass( const wxString& aChain, const wxString& aClass )
181 {
182 if( aClass.IsEmpty() )
183 m_netChainClasses.erase( aChain );
184 else
185 m_netChainClasses[aChain] = aClass;
186 }
187
189 wxString GetNetChainClass( const wxString& aChain ) const
190 {
191 auto it = m_netChainClasses.find( aChain );
192 return it != m_netChainClasses.end() ? it->second : wxString();
193 }
194
195 const std::map<wxString, wxString>& GetNetChainClasses() const
196 {
197 return m_netChainClasses;
198 }
199
202 {
203 m_netChainClasses.clear();
204 }
205
207 bool HasEffectiveNetClass( const wxString& aNetName ) const;
208
211 std::shared_ptr<NETCLASS> GetCachedEffectiveNetClass( const wxString& aNetName ) const;
212
214 // If the effective netclass has not been computed, it will be created and cached.
215 std::shared_ptr<NETCLASS> GetEffectiveNetClass( const wxString& aNetName );
216
220 void RecomputeEffectiveNetclasses();
221
228 std::shared_ptr<NETCLASS> GetNetClassByName( const wxString& aNetName ) const;
229
240 static bool ParseBusVector( const wxString& aBus, wxString* aName,
241 std::vector<wxString>* aMemberList );
242
251 static bool ParseBusGroup( const wxString& aGroup, wxString* name,
252 std::vector<wxString>* aMemberList );
253
266 static void ForEachBusMember( const wxString& aBusPattern,
267 const std::function<void( const wxString& )>& aFunction );
268
269private:
270 bool migrateSchema0to1();
271 bool migrateSchema1to2();
272 bool migrateSchema2to3();
273 bool migrateSchema3to4();
274 bool migrateSchema4to5();
275
285 void makeEffectiveNetclass( std::shared_ptr<NETCLASS>& effectiveNetclass,
286 std::vector<NETCLASS*>& netclasses ) const;
287
290 bool addMissingDefaults( NETCLASS* nc ) const;
291
293 void addSinglePatternAssignment( const wxString& pattern, const wxString& netclass );
294
296 void addSingleChainPatternAssignment( const wxString& pattern, const wxString& netclass );
297
299 std::shared_ptr<NETCLASS> m_defaultNetClass;
300
302 std::map<wxString, std::shared_ptr<NETCLASS>> m_netClasses;
303
305 std::map<wxString, std::set<wxString>> m_netClassLabelAssignments;
306
308 std::vector<std::pair<std::unique_ptr<EDA_COMBINED_MATCHER>, wxString>>
310
316 std::vector<std::pair<std::unique_ptr<EDA_COMBINED_MATCHER>, wxString>>
318
320 // composite (multiple netclass assignment / missing defaults) netclasses
321 std::map<wxString, std::shared_ptr<NETCLASS>> m_compositeNetClasses;
322
328 // to the effective netclasses which contain them.
329 std::map<wxString, std::shared_ptr<NETCLASS>> m_impicitNetClasses;
330
332 std::map<wxString, std::shared_ptr<NETCLASS>> m_effectiveNetclassCache;
333
340 std::map<wxString, KIGFX::COLOR4D> m_netColorAssignments;
341
348 std::map<wxString, wxString> m_netChainClasses;
349
350 // TODO: Add diff pairs, bus information, etc.
351};
352
353#endif // KICAD_NET_SETTINGS_H
const char * name
bool operator==(const wxAuiPaneInfo &aLhs, const wxAuiPaneInfo &aRhs)
JSON_SETTINGS(const wxString &aFilename, SETTINGS_LOC aLocation, int aSchemaVersion)
A color representation with 4 components: red, green, blue, alpha.
Definition color4d.h:101
NESTED_SETTINGS(const std::string &aName, int aSchemaVersion, JSON_SETTINGS *aParent, const std::string &aPath, bool aLoadFromFile=true)
A collection of nets and the parameters used to route or test these nets.
Definition netclass.h:38
NET_SETTINGS stores various net-related settings in a project context.
std::map< wxString, std::shared_ptr< NETCLASS > > m_compositeNetClasses
Map of netclass names to netclass definitions for.
void SetNetChainClass(const wxString &aChain, const wxString &aClass)
Assign a net chain to a named class (used by inNetChainClass() DRC scope).
wxString GetNetChainClass(const wxString &aChain) const
Look up the class assigned to a chain. Empty string means "no class".
std::map< wxString, KIGFX::COLOR4D > m_netColorAssignments
A map of fully-qualified net names to colors used in the board context.
std::shared_ptr< NETCLASS > m_defaultNetClass
The default netclass.
std::map< wxString, std::shared_ptr< NETCLASS > > m_impicitNetClasses
Map of netclass names to netclass definitions for implicit netclasses.
std::vector< std::pair< std::unique_ptr< EDA_COMBINED_MATCHER >, wxString > > m_netClassPatternAssignments
List of net class pattern assignments.
std::map< wxString, std::shared_ptr< NETCLASS > > m_effectiveNetclassCache
Cache of nets to pattern-matched netclasses.
std::map< wxString, std::shared_ptr< NETCLASS > > m_netClasses
Map of netclass names to netclass definitions.
std::vector< std::pair< std::unique_ptr< EDA_COMBINED_MATCHER >, wxString > > m_netClassChainPatternAssignments
List of chain-derived netclass pattern assignments.
const std::map< wxString, wxString > & GetNetChainClasses() const
bool HasChainPatternAssignments() const
Returns true if any chain-derived pattern assignment is present.
bool operator!=(const NET_SETTINGS &aOther) const
void ClearNetChainClasses()
Removes all chain-to-class assignments.
std::map< wxString, std::set< wxString > > m_netClassLabelAssignments
Map of net names to resolved netclasses.
NET_SETTINGS(JSON_SETTINGS *aParent, const std::string &aPath)
std::map< wxString, wxString > m_netChainClasses
Map of net-chain name -> chain-class name.
Abstract pattern-matching tool and implementations.
#define KICOMMON_API
Definition kicommon.h:27