diff options
author | saurabhb17 | 2020-02-26 16:00:53 +0530 |
---|---|---|
committer | GitHub | 2020-02-26 16:00:53 +0530 |
commit | 886d9cb772e81d2e5262284bc3082664f084337f (patch) | |
tree | 6acee185a4dc19113fcbf0f9a3d6941085dedaf7 /pcbnew/router/pns_itemset.cpp | |
parent | 0db48f6533517ecebfd9f0693f89deca28408b76 (diff) | |
parent | aa35045840b78d3f48212db45da59a2e5c69b223 (diff) | |
download | KiCad-eSim-886d9cb772e81d2e5262284bc3082664f084337f.tar.gz KiCad-eSim-886d9cb772e81d2e5262284bc3082664f084337f.tar.bz2 KiCad-eSim-886d9cb772e81d2e5262284bc3082664f084337f.zip |
Merge pull request #1 from saurabhb17/develop
Added main functions
Diffstat (limited to 'pcbnew/router/pns_itemset.cpp')
-rw-r--r-- | pcbnew/router/pns_itemset.cpp | 138 |
1 files changed, 138 insertions, 0 deletions
diff --git a/pcbnew/router/pns_itemset.cpp b/pcbnew/router/pns_itemset.cpp new file mode 100644 index 0000000..06561a7 --- /dev/null +++ b/pcbnew/router/pns_itemset.cpp @@ -0,0 +1,138 @@ +/* + * KiRouter - a push-and-(sometimes-)shove PCB router + * + * Copyright (C) 2013-2014 CERN + * Author: Tomasz Wlostowski <tomasz.wlostowski@cern.ch> + * + * This program is free software: you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation, either version 3 of the License, or (at your + * option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#include <boost/foreach.hpp> + +#include "pns_itemset.h" +#include "pns_line.h" + + +PNS_ITEMSET::~PNS_ITEMSET() +{ +} + + +void PNS_ITEMSET::Add( const PNS_LINE& aLine ) +{ + PNS_LINE* copy = aLine.Clone(); + m_items.push_back( ENTRY( copy, true ) ); +} + + +void PNS_ITEMSET::Prepend( const PNS_LINE& aLine ) +{ + PNS_LINE* copy = aLine.Clone(); + m_items.insert( m_items.begin(), ENTRY( copy, true ) ); +} + + +PNS_ITEMSET& PNS_ITEMSET::FilterLayers( int aStart, int aEnd, bool aInvert ) +{ + ENTRIES newItems; + PNS_LAYERSET l; + + if( aEnd < 0 ) + l = PNS_LAYERSET( aStart ); + else + l = PNS_LAYERSET( aStart, aEnd ); + + BOOST_FOREACH( const ENTRY& ent, m_items ) + { + if( ent.item->Layers().Overlaps( l ) ^ aInvert ) + { + newItems.push_back( ent ); + } + } + + m_items = newItems; + + return *this; +} + + +PNS_ITEMSET& PNS_ITEMSET::FilterKinds( int aKindMask, bool aInvert ) +{ + ENTRIES newItems; + + BOOST_FOREACH( const ENTRY& ent, m_items ) + { + if( ent.item->OfKind( aKindMask ) ^ aInvert ) + { + newItems.push_back( ent ); + } + } + + m_items = newItems; + + return *this; +} + + +PNS_ITEMSET& PNS_ITEMSET::FilterMarker( int aMarker, bool aInvert ) +{ + ENTRIES newItems; + + BOOST_FOREACH( const ENTRY& ent, m_items ) + { + if( ent.item->Marker() & aMarker ) + { + newItems.push_back( ent ); + } + } + + m_items = newItems; + + return *this; +} + + +PNS_ITEMSET& PNS_ITEMSET::FilterNet( int aNet, bool aInvert ) +{ + ENTRIES newItems; + + BOOST_FOREACH( const ENTRY& ent, m_items ) + { + if( ( ent.item->Net() == aNet ) ^ aInvert ) + { + newItems.push_back( ent ); + } + } + + m_items = newItems; + + return *this; +} + + +PNS_ITEMSET& PNS_ITEMSET::ExcludeItem( const PNS_ITEM* aItem ) +{ + ENTRIES newItems; + + BOOST_FOREACH( const ENTRY& ent, m_items ) + { + if( ent.item != aItem ) + + newItems.push_back( ent ); + } + + m_items = newItems; + + return *this; +} |