KiCad PCB EDA Suite
Loading...
Searching...
No Matches
zone_settings_bag.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) 2023 Ethan Chien <[email protected]>
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, you may find one here:
19 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20 * or you may search the http://www.gnu.org website for the version 2 license,
21 * or you may write to the Free Software Foundation, Inc.,
22 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
23 */
24
25
26#pragma once
27
28#include "board.h"
29#include <memory>
30#include <unordered_map>
31#include <vector>
32#include <zone.h>
33#include <zone_settings.h>
34
35
37{
38public:
39 ZONE_SETTINGS_BAG( BOARD* aBoard );
40 ZONE_SETTINGS_BAG( ZONE* aZone, ZONE_SETTINGS* aSettings );
41
42 ZONE_SETTINGS_BAG() = default;
43
44 std::shared_ptr<ZONE_SETTINGS> GetZoneSettings( ZONE* aZone );
45 unsigned GetZonePriority( ZONE* aZone );
46
47 void SwapPriority( ZONE* aZOne, ZONE* otherZone );
48
52 void UpdateClonedZones();
53
54 std::vector<ZONE*>& GetOriginalZoneList() { return m_originalZoneList; }
55 std::vector<ZONE*>& GetClonedZoneList() { return m_clonedZoneList; }
56 std::unordered_map<ZONE*, std::shared_ptr<ZONE>>& GetZonesCloneMap() { return m_zonesCloneMap; }
57
58private:
59 std::unordered_map<ZONE*, std::shared_ptr<ZONE>> m_zonesCloneMap; // original : clone
60 std::unordered_map<ZONE*, std::shared_ptr<ZONE_SETTINGS>> m_zoneSettings; // clone : current settings
61 std::unordered_map<ZONE*, std::pair<unsigned, unsigned>> m_zonePriorities; // clone : initial pri, current pri
62 std::vector<ZONE*> m_clonedZoneList;
63 std::vector<ZONE*> m_originalZoneList;
64};
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:322
unsigned GetZonePriority(ZONE *aZone)
std::vector< ZONE * > & GetOriginalZoneList()
std::vector< ZONE * > m_originalZoneList
ZONE_SETTINGS_BAG(BOARD *aBoard)
ZONE_SETTINGS_BAG()=default
std::unordered_map< ZONE *, std::shared_ptr< ZONE > > m_zonesCloneMap
std::unordered_map< ZONE *, std::shared_ptr< ZONE > > & GetZonesCloneMap()
void UpdateClonedZones()
The cloned list is the working storage.
std::vector< ZONE * > m_clonedZoneList
std::vector< ZONE * > & GetClonedZoneList()
void SwapPriority(ZONE *aZOne, ZONE *otherZone)
std::unordered_map< ZONE *, std::shared_ptr< ZONE_SETTINGS > > m_zoneSettings
std::shared_ptr< ZONE_SETTINGS > GetZoneSettings(ZONE *aZone)
std::unordered_map< ZONE *, std::pair< unsigned, unsigned > > m_zonePriorities
ZONE_SETTINGS handles zones parameters.
Handle a list of polygons defining a copper zone.
Definition zone.h:74
Class ZONE_SETTINGS used to handle zones parameters in dialogs.