KiCad PCB EDA Suite
Loading...
Searching...
No Matches
layer_utils.cpp
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 The KiCad Developers.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, you may find one here:
18 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
19 * or you may search the http://www.gnu.org website for the version 2 license,
20 * or you may write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
22 */
23
24#include "layer_utils.h"
25
26
27wxString LAYER_UTILS::AccumulateNames( const LSEQ& aLayers, const BOARD* aBoard )
28{
29 wxString result;
30
31 for( const PCB_LAYER_ID layer : aLayers )
32 {
33 if( !result.IsEmpty() )
34 result += ", ";
35
36 result += aBoard ? aBoard->GetLayerName( layer ) : LayerName( layer );
37 }
38
39 return result;
40}
41
42
44{
45 LSET usedLayers{};
46
47 aFootprint.RunOnChildren(
48 [&]( BOARD_ITEM* aSubItem )
49 {
50 wxCHECK2( aSubItem, /*void*/ );
51 usedLayers |= aSubItem->GetLayerSet();
52 },
54
55 return usedLayers;
56}
57
58
60 const LSET& aCustomUserLayers )
61{
62 LSET usedLayers = GetAllFootprintLayers( aFootprint );
63
64 usedLayers &= ~aCustomUserLayers;
65 usedLayers &= ~LSET::AllTechMask();
66 usedLayers &= ~LSET::UserMask();
67
68 // Rescue is a pseudo-layer used as a fallback for items referencing unknown layer
69 // names at load time. It is not exposed in any layer-selection UI, so the user has no
70 // way to "keep" it. Items on Rescue are an orphan state that predates any Footprint
71 // Properties edit and are surfaced through library-parity DRC instead.
72 usedLayers.reset( Rescue );
73
74 return usedLayers;
75}
BASE_SET & reset(size_t pos)
Definition base_set.h:143
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition board_item.h:84
virtual LSET GetLayerSet() const
Return a std::bitset of all layers on which the item physically resides.
Definition board_item.h:288
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:323
const wxString GetLayerName(PCB_LAYER_ID aLayer) const
Return the name of a aLayer.
Definition board.cpp:745
void RunOnChildren(const std::function< void(BOARD_ITEM *)> &aFunction, RECURSE_MODE aMode) const override
Invoke a function on all children.
LSEQ is a sequence (and therefore also a set) of PCB_LAYER_IDs.
Definition lseq.h:47
LSET is a set of PCB_LAYER_IDs.
Definition lset.h:37
@ RECURSE
Definition eda_item.h:53
wxString LayerName(int aLayer)
Returns the default display name for a given layer.
Definition layer_id.cpp:31
PCB_LAYER_ID
A quick note on layer IDs:
Definition layer_ids.h:60
@ Rescue
Definition layer_ids.h:121
wxString AccumulateNames(const LSEQ &aLayers, const BOARD *aBoard)
Accumulate layer names from a layer set into a comma separated string.
LSET GetAllFootprintLayers(const FOOTPRINT &aFootprint)
Return the union of layers referenced by every item inside the footprint (including graphic items,...
LSET GetOrphanedFootprintLayers(const FOOTPRINT &aFootprint, const LSET &aCustomUserLayers)
Compute the set of footprint-used layers that would be orphaned if the footprint's allowed layer set ...
wxString result
Test unit parsing edge cases and error handling.