KiCad PCB EDA Suite
|
Container for NETINFO_ITEM elements, which are the nets. More...
#include <netinfo.h>
Classes | |
class | iterator |
Wrapper class, so you can iterate through NETINFO_ITEM*s, not std::pair<int/wxString, NETINFO_ITEM*> More... | |
Public Member Functions | |
NETINFO_LIST (BOARD *aParent) | |
~NETINFO_LIST () | |
NETINFO_ITEM * | GetNetItem (int aNetCode) const |
NETINFO_ITEM * | GetNetItem (const wxString &aNetName) const |
unsigned | GetNetCount () const |
const NETNAMES_MAP & | NetsByName () const |
Return the name map, at least for python. | |
const NETCODES_MAP & | NetsByNetcode () const |
Return the netcode map, at least for python. | |
void | RebuildDisplayNetnames () const |
iterator | begin () const |
iterator | end () const |
BOARD * | GetParent () const |
Static Public Member Functions | |
static NETINFO_ITEM * | OrphanedItem () |
NETINFO_ITEM meaning that there was no net assigned for an item, as there was no board storing net list available. | |
Public Attributes | |
bool | m_DisplayNetnamesDirty |
Static Public Attributes | |
static const int | UNCONNECTED = 0 |
Constant that holds the "unconnected net" number (typically 0) all items "connected" to this net are actually not connected items. | |
static const int | ORPHANED = -1 |
Constant that forces initialization of a netinfo item to the NETINFO_ITEM ORPHANED (typically -1) when calling SetNetCode on board connected items. | |
Protected Member Functions | |
void | AppendNet (NETINFO_ITEM *aNewElement) |
Add aNewElement to the end of the net list. | |
void | RemoveNet (NETINFO_ITEM *aNet) |
Remove a net from the net list. | |
void | RemoveUnusedNets (BOARD_COMMIT *aCommit) |
Private Member Functions | |
void | clear () |
Delete the list of nets (and free memory). | |
void | buildListOfNets () |
Rebuild the list of NETINFO_ITEMs. | |
int | getFreeNetCode () |
Return the first available net code that is not used by any other net. | |
Private Attributes | |
BOARD * | m_parent |
NETNAMES_MAP | m_netNames |
map of <wxString, NETINFO_ITEM*>, is NETINFO_ITEM owner | |
NETCODES_MAP | m_netCodes |
map of <int, NETINFO_ITEM*> is NOT owner | |
int | m_newNetCode |
possible value for new net code assignment | |
Friends | |
class | BOARD |
Container for NETINFO_ITEM elements, which are the nets.
NETINFO_LIST::NETINFO_LIST | ( | BOARD * | aParent | ) |
Definition at line 37 of file netinfo_list.cpp.
References AppendNet().
NETINFO_LIST::~NETINFO_LIST | ( | ) |
Definition at line 46 of file netinfo_list.cpp.
References clear().
|
protected |
Add aNewElement to the end of the net list.
Negative net code means it is going to be auto-assigned.
Definition at line 146 of file netinfo_list.cpp.
References getFreeNetCode(), NETINFO_ITEM::GetNetCode(), GetNetItem(), NETINFO_ITEM::GetNetname(), m_DisplayNetnamesDirty, NETINFO_ITEM::m_netCode, m_netCodes, and m_netNames.
Referenced by BOARD::Add(), and NETINFO_LIST().
|
inline |
Definition at line 452 of file netinfo.h.
References m_netNames.
Referenced by BOARD::BeginNets(), and DSN::SPECCTRA_DB::FromBOARD().
|
private |
Rebuild the list of NETINFO_ITEMs.
The list is sorted by names.
Definition at line 176 of file netinfo_list.cpp.
References NETINFO_ITEM::Clear(), m_parent, BOARD::SetAreasNetCodesFromNetNames(), and BOARD::SynchronizeNetsAndNetClasses().
Referenced by BOARD::BuildListOfNets().
|
private |
Delete the list of nets (and free memory).
Definition at line 52 of file netinfo_list.cpp.
References m_netCodes, m_netNames, and m_newNetCode.
Referenced by BOARD::RemoveAll(), and ~NETINFO_LIST().
|
inline |
Definition at line 457 of file netinfo.h.
References m_netNames.
Referenced by BOARD::EndNets(), and DSN::SPECCTRA_DB::FromBOARD().
|
private |
Return the first available net code that is not used by any other net.
Definition at line 263 of file netinfo_list.cpp.
References m_netCodes, and m_newNetCode.
Referenced by AppendNet().
|
inline |
Definition at line 369 of file netinfo.h.
References m_netNames.
Referenced by BOARD::FindNet(), BOARD::GetNetCount(), FABMASTER::loadZones(), BOARD::operator==(), and DIALOG_COPPER_ZONE::readNetInformation().
NETINFO_ITEM * NETINFO_LIST::GetNetItem | ( | const wxString & | aNetName | ) | const |
aNetName | net name to identify a given NETINFO_ITEM. |
Definition at line 76 of file netinfo_list.cpp.
References m_netNames.
NETINFO_ITEM * NETINFO_LIST::GetNetItem | ( | int | aNetCode | ) | const |
aNetCode | netcode to identify a given NETINFO_ITEM. |
Definition at line 65 of file netinfo_list.cpp.
References m_netCodes.
Referenced by NET_SELECTOR_COMBOPOPUP::Accept(), AppendNet(), BOARD_EDITOR_CONTROL::AssignNetclass(), DRAWING_TOOL::DrawVia(), BOARD::FindNet(), PCB_IO_IPC2581::generateLogicalNets(), NET_SELECTOR_COMBOPOPUP::getListContent(), NET_SELECTOR_COMBOPOPUP::GetSelectedNetname(), NET_SELECTOR_COMBOPOPUP::GetStringValue(), PCB_EDIT_FRAME::LoadProjectSettings(), BOARD::Remove(), test::DRC_TEST_PROVIDER_DIFF_PAIR_COUPLING::Run(), DRC_TEST_PROVIDER_MATCHED_LENGTH::runInternal(), PCB_EDIT_FRAME::SaveProjectLocalSettings(), PCB_EDIT_FRAME::saveProjectSettings(), and NET_SELECTOR_COMBOPOPUP::SetSelectedNet().
|
inline |
Definition at line 463 of file netinfo.h.
References m_parent.
Referenced by NET_SELECTOR_COMBOPOPUP::Accept().
|
inline |
Return the name map, at least for python.
Definition at line 372 of file netinfo.h.
References m_netNames.
Referenced by FABMASTER::loadEtch(), FABMASTER::loadFootprints(), FABMASTER::loadVias(), FABMASTER::loadZone(), BOARD::operator==(), NET_GRID_TABLE::Rebuild(), and FOOTPRINT_EDIT_FRAME::SaveFootprintToBoard().
|
inline |
Return the netcode map, at least for python.
Definition at line 375 of file netinfo.h.
References m_netCodes.
Referenced by PCB_NET_INSPECTOR_PANEL::buildNetsList(), DRC_TEST_PROVIDER_CREEPAGE::CollectNetCodes(), and PCB_PROPERTIES_PANEL::updateLists().
|
inlinestatic |
NETINFO_ITEM meaning that there was no net assigned for an item, as there was no board storing net list available.
Definition at line 389 of file netinfo.h.
References UNCONNECTED.
Referenced by PNS_KICAD_IFACE::createBoardItem(), BOARD::FindNet(), PNS_KICAD_IFACE_BASE::GetOrphanedNetHandle(), PCB_CONTROL::Paste(), and BOARD_CONNECTED_ITEM::SetNetCode().
void NETINFO_LIST::RebuildDisplayNetnames | ( | ) | const |
Definition at line 187 of file netinfo_list.cpp.
References NETINFO_ITEM::m_displayNetname, m_DisplayNetnamesDirty, NETINFO_ITEM::m_netname, NETINFO_ITEM::m_shortNetname, and UnescapeString().
|
protected |
Remove a net from the net list.
Definition at line 87 of file netinfo_list.cpp.
References m_DisplayNetnamesDirty, NETINFO_ITEM::m_netCode, m_netCodes, m_netNames, and m_newNetCode.
Referenced by BOARD::Remove().
|
protected |
Definition at line 120 of file netinfo_list.cpp.
References m_DisplayNetnamesDirty, m_netCodes, m_netNames, and COMMIT::Removed().
Referenced by BOARD::RemoveUnusedNets().
|
mutable |
Definition at line 500 of file netinfo.h.
Referenced by AppendNet(), RebuildDisplayNetnames(), RemoveNet(), and RemoveUnusedNets().
|
private |
map of <int, NETINFO_ITEM*> is NOT owner
Definition at line 506 of file netinfo.h.
Referenced by AppendNet(), clear(), getFreeNetCode(), GetNetItem(), NetsByNetcode(), RemoveNet(), and RemoveUnusedNets().
|
private |
map of <wxString, NETINFO_ITEM*>, is NETINFO_ITEM owner
Definition at line 505 of file netinfo.h.
Referenced by AppendNet(), begin(), clear(), end(), GetNetCount(), GetNetItem(), NetsByName(), RemoveNet(), and RemoveUnusedNets().
|
private |
possible value for new net code assignment
Definition at line 508 of file netinfo.h.
Referenced by clear(), getFreeNetCode(), and RemoveNet().
|
private |
Definition at line 503 of file netinfo.h.
Referenced by buildListOfNets(), and GetParent().
|
static |
Constant that forces initialization of a netinfo item to the NETINFO_ITEM ORPHANED (typically -1) when calling SetNetCode on board connected items.
Definition at line 385 of file netinfo.h.
Referenced by FOOTPRINT::ClearAllNets(), DRAWING_TOOL::DrawVia(), PCB_IO_KICAD_SEXPR_PARSER::parsePAD(), and BOARD::SanitizeNetcodes().
|
static |
Constant that holds the "unconnected net" number (typically 0) all items "connected" to this net are actually not connected items.
Definition at line 381 of file netinfo.h.
Referenced by KIGFX::PCB_PAINTER::draw(), PCB_EDIT_FRAME::ExchangeFootprint(), BOARD::FindNet(), PCB_IO_KICAD_SEXPR::format(), ALTIUM_PCB::GetNetCode(), PCB_IO_EAGLE::loadPlain(), PCB_IO_EAGLE::loadSignals(), PCB_IO_KICAD_LEGACY::loadZONE_CONTAINER(), OrphanedItem(), PCB_IO_KICAD_SEXPR_PARSER::parseNETINFO_ITEM(), PCB_IO_KICAD_SEXPR_PARSER::parseZONE(), BOARD::Remove(), PCB_SELECTION_CONDITIONS::sameNetFunc(), BOARD::SetAreasNetCodesFromNetNames(), PAD::SetAttribute(), DIALOG_PAD_PROPERTIES::TransferDataFromWindow(), DIALOG_PAD_PROPERTIES::transferDataToPad(), BOARD_NETLIST_UPDATER::updateComponentPadConnections(), and PCB_TRACK::ViewGetLOD().