add more constness to connecivity algo
also make ForEachAnchor inlineable, like ForEachItem. remove some unused function declarations.
This commit is contained in:
parent
3de5b98316
commit
4c7471eb79
|
@ -747,16 +747,6 @@ void CN_CONNECTIVITY_ALGO::Clear()
|
|||
|
||||
}
|
||||
|
||||
void CN_CONNECTIVITY_ALGO::ForEachAnchor( const std::function<void( CN_ANCHOR& )>& aFunc )
|
||||
{
|
||||
ForEachItem( [aFunc] ( CN_ITEM& item ) {
|
||||
for( const auto& anchor : item.Anchors() )
|
||||
aFunc( *anchor );
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
void CN_CONNECTIVITY_ALGO::SetProgressReporter( PROGRESS_REPORTER* aReporter )
|
||||
{
|
||||
m_progressReporter = aReporter;
|
||||
|
|
|
@ -173,7 +173,7 @@ public:
|
|||
CN_CONNECTIVITY_ALGO() {}
|
||||
~CN_CONNECTIVITY_ALGO() { Clear(); }
|
||||
|
||||
bool ItemExists( const BOARD_CONNECTED_ITEM* aItem )
|
||||
bool ItemExists( const BOARD_CONNECTED_ITEM* aItem ) const
|
||||
{
|
||||
return m_itemMap.find( aItem ) != m_itemMap.end();
|
||||
}
|
||||
|
@ -197,7 +197,7 @@ public:
|
|||
*i = false;
|
||||
}
|
||||
|
||||
void GetDirtyClusters( CLUSTERS& aClusters )
|
||||
void GetDirtyClusters( CLUSTERS& aClusters ) const
|
||||
{
|
||||
for( const auto& cl : m_ratsnestClusters )
|
||||
{
|
||||
|
@ -240,17 +240,25 @@ public:
|
|||
*/
|
||||
void FindIsolatedCopperIslands( std::vector<CN_ZONE_ISOLATED_ISLAND_LIST>& aZones );
|
||||
|
||||
bool CheckConnectivity( std::vector<CN_DISJOINT_NET_ENTRY>& aReport );
|
||||
|
||||
const CLUSTERS& GetClusters();
|
||||
int GetUnconnectedCount();
|
||||
|
||||
CN_LIST& ItemList() { return m_itemList; }
|
||||
|
||||
void ForEachAnchor( const std::function<void( CN_ANCHOR& )>& aFunc );
|
||||
const CN_LIST& ItemList() const
|
||||
{
|
||||
return m_itemList;
|
||||
}
|
||||
|
||||
template <typename Func>
|
||||
void ForEachItem( Func&& aFunc )
|
||||
void ForEachAnchor( Func&& aFunc ) const
|
||||
{
|
||||
for( auto&& item : m_itemList )
|
||||
{
|
||||
for( auto&& anchor : item->Anchors() )
|
||||
aFunc( *anchor );
|
||||
}
|
||||
}
|
||||
|
||||
template <typename Func>
|
||||
void ForEachItem( Func&& aFunc ) const
|
||||
{
|
||||
for( auto&& item : m_itemList )
|
||||
aFunc( *item );
|
||||
|
|
|
@ -504,7 +504,7 @@ unsigned int CONNECTIVITY_DATA::GetPadCount( int aNet ) const
|
|||
{
|
||||
int n = 0;
|
||||
|
||||
for( auto pad : m_connAlgo->ItemList() )
|
||||
for( auto&& pad : m_connAlgo->ItemList() )
|
||||
{
|
||||
if( !pad->Valid() || pad->Parent()->Type() != PCB_PAD_T)
|
||||
continue;
|
||||
|
|
|
@ -425,11 +425,21 @@ public:
|
|||
m_index.RemoveAll();
|
||||
}
|
||||
|
||||
using ITER = decltype(m_items)::iterator;
|
||||
using ITER = decltype( m_items )::iterator;
|
||||
using CONST_ITER = decltype( m_items )::const_iterator;
|
||||
|
||||
ITER begin() { return m_items.begin(); };
|
||||
ITER end() { return m_items.end(); };
|
||||
|
||||
CONST_ITER begin() const
|
||||
{
|
||||
return m_items.begin();
|
||||
}
|
||||
CONST_ITER end() const
|
||||
{
|
||||
return m_items.end();
|
||||
}
|
||||
|
||||
CN_ITEM* operator[] ( int aIndex ) { return m_items[aIndex]; }
|
||||
|
||||
template <class T>
|
||||
|
|
Loading…
Reference in New Issue