KiCad PCB EDA Suite
Loading...
Searching...
No Matches
connectivity_data.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) 2013-2017 CERN
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 * @author Maciej Suminski <[email protected]>
7 * @author Tomasz Wlostowski <[email protected]>
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program. If not, see <https://www.gnu.org/licenses/>.
21 */
22
23#ifndef __CONNECTIVITY_DATA_H
24#define __CONNECTIVITY_DATA_H
25
26#include <core/typeinfo.h>
27#include <core/spinlock.h>
28
29#include <memory>
30#include <mutex>
31#include <vector>
32#include <wx/string.h>
33
34#include <math/vector2d.h>
35#include <zone.h>
36
37class FROM_TO_CACHE;
38class NET_SETTINGS;
39class CN_CLUSTER;
41class CN_EDGE;
42class BOARD;
43class BOARD_COMMIT;
45class BOARD_ITEM;
46class ZONE;
47class RN_DATA;
48class RN_NET;
49class PCB_ARC;
50class PCB_TRACK;
51class PCB_VIA;
52class PAD;
53class FOOTPRINT;
55
56
63
64
66{
69};
70
71
80
81
82// a wrapper class encompassing the connectivity computation algorithm and the
84{
85public:
88
89 CONNECTIVITY_DATA( std::shared_ptr<CONNECTIVITY_DATA> aGlobalConnectivity,
90 const std::vector<BOARD_ITEM*>& aLocalItems, bool aSkipRatsnestUpdate = false );
91
96 bool Build( BOARD* aBoard, PROGRESS_REPORTER* aReporter = nullptr );
97
102 void Build( std::shared_ptr<CONNECTIVITY_DATA>& aGlobalConnectivity,
103 const std::vector<BOARD_ITEM*>& aLocalItems );
104
111 bool Add( BOARD_ITEM* aItem );
112
119 bool Remove( BOARD_ITEM* aItem );
120
127 bool Update( BOARD_ITEM* aItem );
128
136 void Move( const VECTOR2I& aDelta );
137
142 void ClearRatsnest();
143
148 int GetNetCount() const;
149
154 RN_NET* GetRatsnestForNet( int aNet );
155
161 void PropagateNets( BOARD_COMMIT* aCommit = nullptr );
162
167 void FillIsolatedIslandsMap( std::map<ZONE*, std::map<PCB_LAYER_ID, ISOLATED_ISLANDS>>& aMap,
168 bool aConnectivityAlreadyRebuilt = false );
169
175 void RecalculateRatsnest( BOARD_COMMIT* aCommit = nullptr );
176
181 unsigned int GetUnconnectedCount( bool aVisibileOnly ) const;
182
183 bool IsConnectedOnLayer( const BOARD_CONNECTED_ITEM* aItem, int aLayer,
184 const std::initializer_list<KICAD_T>& aTypes = {} ) const;
185
186 unsigned int GetNodeCount( int aNet = -1 ) const;
187
188 unsigned int GetPadCount( int aNet = -1 ) const;
189
190 const std::vector<PCB_TRACK*> GetConnectedTracks( const BOARD_CONNECTED_ITEM* aItem ) const;
191
192 const std::vector<PAD*> GetConnectedPads( const BOARD_CONNECTED_ITEM* aItem ) const;
193
194 void GetConnectedPads( const BOARD_CONNECTED_ITEM* aItem, std::set<PAD*>* pads ) const;
195
196 void GetConnectedPadsAndVias( const BOARD_CONNECTED_ITEM* aItem, std::vector<PAD*>* pads,
197 std::vector<PCB_VIA*>* vias );
198
209 const std::vector<BOARD_CONNECTED_ITEM*>
210 GetConnectedItemsAtAnchor( const BOARD_CONNECTED_ITEM* aItem, const VECTOR2I& aAnchor,
211 const std::vector<KICAD_T>& aTypes, const int& aMaxError = 0 ) const;
212
213 void RunOnUnconnectedEdges( std::function<bool( CN_EDGE& )> aFunc );
214
215 bool TestTrackEndpointDangling( PCB_TRACK* aTrack, bool aIgnoreTracksInPads,
216 VECTOR2I* aPos = nullptr ) const;
217
223 void ClearLocalRatsnest();
224
228 void HideLocalRatsnest();
229
234 void ComputeLocalRatsnest( const std::vector<BOARD_ITEM*>& aItems,
235 const CONNECTIVITY_DATA* aDynamicData,
236 VECTOR2I aInternalOffset = { 0, 0 } );
237
238 const std::vector<RN_DYNAMIC_LINE>& GetLocalRatsnest() const { return m_dynamicRatsnest; }
239
246#define IGNORE_NETS 0x0001
247#define EXCLUDE_ZONES 0x0002
248 const std::vector<BOARD_CONNECTED_ITEM*> GetConnectedItems( const BOARD_CONNECTED_ITEM* aItem,
249 int aFlags = 0 ) const;
250
257 const std::vector<BOARD_CONNECTED_ITEM*>
258 GetNetItems( int aNetCode, const std::vector<KICAD_T>& aTypes ) const;
259
260 void BlockRatsnestItems( const std::vector<BOARD_ITEM*>& aItems );
261
262 std::shared_ptr<CN_CONNECTIVITY_ALGO> GetConnectivityAlgo() const { return m_connAlgo; }
263
264 KISPINLOCK& GetLock() { return m_lock; }
265
266 void MarkItemNetAsDirty( BOARD_ITEM* aItem );
267 void RemoveInvalidRefs();
268
269 void SetProgressReporter( PROGRESS_REPORTER* aReporter );
270
271 const NET_SETTINGS* GetNetSettings() const;
272
273 bool HasNetNameForNetCode( int nc ) const { return m_netcodeMap.count( nc ) > 0; }
274 const wxString& GetNetNameForNetCode( int nc ) const { return m_netcodeMap.at( nc ); }
275
277 void RefreshNetcodeMap( BOARD* aBoard );
278
279 const std::vector<CN_EDGE> GetRatsnestForItems( const std::vector<BOARD_ITEM*>& aItems );
280
281 const std::vector<CN_EDGE> GetRatsnestForPad( const PAD* aPad );
282
283 const std::vector<CN_EDGE> GetRatsnestForComponent( FOOTPRINT* aComponent,
284 bool aSkipInternalConnections = false );
285
286 std::shared_ptr<FROM_TO_CACHE> GetFromToCache() { return m_fromToCache; }
287
288private:
289
294 void internalRecalculateRatsnest( BOARD_COMMIT* aCommit = nullptr );
295 void updateRatsnest();
296
297 void addRatsnestCluster( const std::shared_ptr<CN_CLUSTER>& aCluster );
298
299private:
300 std::shared_ptr<CN_CONNECTIVITY_ALGO> m_connAlgo;
301
302 std::shared_ptr<FROM_TO_CACHE> m_fromToCache;
303 std::vector<RN_DYNAMIC_LINE> m_dynamicRatsnest;
304 std::vector<RN_NET*> m_nets;
305
308
310
312
314 std::weak_ptr<NET_SETTINGS> m_netSettings;
315
317 std::map<int, wxString> m_netcodeMap;
318};
319
320#endif
A base class derived from BOARD_ITEM for items that can be connected and have a net,...
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition board_item.h:81
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:372
CN_EDGE represents a point-to-point connection, whether realized or unrealized (ie: tracks etc.
void FillIsolatedIslandsMap(std::map< ZONE *, std::map< PCB_LAYER_ID, ISOLATED_ISLANDS > > &aMap, bool aConnectivityAlreadyRebuilt=false)
Fill the isolate islands list for each layer of each zone.
void RecalculateRatsnest(BOARD_COMMIT *aCommit=nullptr)
Function RecalculateRatsnest() Updates the ratsnest for the board.
void ClearLocalRatsnest()
Function ClearLocalRatsnest() Erases the temporary, selection-based ratsnest (i.e.
PROGRESS_REPORTER * m_progressReporter
const std::vector< RN_DYNAMIC_LINE > & GetLocalRatsnest() const
unsigned int GetPadCount(int aNet=-1) const
void MarkItemNetAsDirty(BOARD_ITEM *aItem)
std::weak_ptr< NET_SETTINGS > m_netSettings
Used to get netclass data when drawing ratsnests.
const std::vector< BOARD_CONNECTED_ITEM * > GetConnectedItems(const BOARD_CONNECTED_ITEM *aItem, int aFlags=0) const
void PropagateNets(BOARD_COMMIT *aCommit=nullptr)
Propagates the net codes from the source pads to the tracks/vias.
KISPINLOCK & GetLock()
void RunOnUnconnectedEdges(std::function< bool(CN_EDGE &)> aFunc)
std::vector< RN_DYNAMIC_LINE > m_dynamicRatsnest
bool m_skipRatsnestUpdate
Used to suppress ratsnest calculations on dynamic ratsnests.
const std::vector< CN_EDGE > GetRatsnestForPad(const PAD *aPad)
RN_NET * GetRatsnestForNet(int aNet)
Function GetRatsnestForNet() Returns the ratsnest, expressed as a set of graph edges for a given net.
const std::vector< BOARD_CONNECTED_ITEM * > GetConnectedItemsAtAnchor(const BOARD_CONNECTED_ITEM *aItem, const VECTOR2I &aAnchor, const std::vector< KICAD_T > &aTypes, const int &aMaxError=0) const
Function GetConnectedItemsAtAnchor() Returns a list of items connected to a source item aItem at posi...
const wxString & GetNetNameForNetCode(int nc) const
void ClearRatsnest()
Function Clear() Erases the connectivity database.
bool Remove(BOARD_ITEM *aItem)
Function Remove() Removes an item from the connectivity data.
void GetConnectedPadsAndVias(const BOARD_CONNECTED_ITEM *aItem, std::vector< PAD * > *pads, std::vector< PCB_VIA * > *vias)
const NET_SETTINGS * GetNetSettings() const
void ComputeLocalRatsnest(const std::vector< BOARD_ITEM * > &aItems, const CONNECTIVITY_DATA *aDynamicData, VECTOR2I aInternalOffset={ 0, 0 })
Function ComputeLocalRatsnest() Calculates the temporary (usually selection-based) ratsnest for the s...
bool TestTrackEndpointDangling(PCB_TRACK *aTrack, bool aIgnoreTracksInPads, VECTOR2I *aPos=nullptr) const
unsigned int GetNodeCount(int aNet=-1) const
void SetProgressReporter(PROGRESS_REPORTER *aReporter)
void BlockRatsnestItems(const std::vector< BOARD_ITEM * > &aItems)
bool IsConnectedOnLayer(const BOARD_CONNECTED_ITEM *aItem, int aLayer, const std::initializer_list< KICAD_T > &aTypes={}) const
const std::vector< PCB_TRACK * > GetConnectedTracks(const BOARD_CONNECTED_ITEM *aItem) const
const std::vector< CN_EDGE > GetRatsnestForComponent(FOOTPRINT *aComponent, bool aSkipInternalConnections=false)
const std::vector< BOARD_CONNECTED_ITEM * > GetNetItems(int aNetCode, const std::vector< KICAD_T > &aTypes) const
Function GetNetItems() Returns the list of items that belong to a certain net.
bool Add(BOARD_ITEM *aItem)
Function Add() Adds an item to the connectivity data.
std::shared_ptr< CN_CONNECTIVITY_ALGO > m_connAlgo
bool Build(BOARD *aBoard, PROGRESS_REPORTER *aReporter=nullptr)
Function Build() Builds the connectivity database for the board aBoard.
std::shared_ptr< FROM_TO_CACHE > m_fromToCache
const std::vector< PAD * > GetConnectedPads(const BOARD_CONNECTED_ITEM *aItem) const
unsigned int GetUnconnectedCount(bool aVisibileOnly) const
bool HasNetNameForNetCode(int nc) const
std::map< int, wxString > m_netcodeMap
Used to map netcode to net name.
void internalRecalculateRatsnest(BOARD_COMMIT *aCommit=nullptr)
Updates the ratsnest for the board without locking the connectivity mutex.
void RefreshNetcodeMap(BOARD *aBoard)
Refresh the map of netcodes to net names.
void HideLocalRatsnest()
Hides the temporary, selection-based ratsnest lines.
const std::vector< CN_EDGE > GetRatsnestForItems(const std::vector< BOARD_ITEM * > &aItems)
void addRatsnestCluster(const std::shared_ptr< CN_CLUSTER > &aCluster)
std::vector< RN_NET * > m_nets
std::shared_ptr< FROM_TO_CACHE > GetFromToCache()
bool Update(BOARD_ITEM *aItem)
Function Update() Updates the connectivity data for an item.
void Move(const VECTOR2I &aDelta)
Moves the connectivity list anchors.
int GetNetCount() const
Function GetNetCount() Returns the total number of nets in the connectivity database.
std::shared_ptr< CN_CONNECTIVITY_ALGO > GetConnectivityAlgo() const
A trivial spinlock implementation with no optimization.
Definition spinlock.h:30
NET_SETTINGS stores various net-related settings in a project context.
Definition pad.h:61
A progress reporter interface for use in multi-threaded environments.
Describe ratsnest for a single net.
Handle a list of polygons defining a copper zone.
Definition zone.h:70
PROPAGATE_MODE
Controls how nets are propagated through clusters.
@ SKIP_CONFLICTS
Clusters with conflicting drivers are not updated (default)
@ RESOLVE_CONFLICTS
Clusters with conflicting drivers are updated to the most popular net.
BOARD_CONNECTED_ITEM * b
BOARD_CONNECTED_ITEM * a
int net
VECTOR2I anchorB
VECTOR2I anchorA
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:683