/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2012 NBEE Embedded Systems, Miguel Angel Ajo * Copyright (C) 2016 SoftPLC Corporation, Dick Hollenbeck * Copyright (C) 1992-2017 KiCad Developers, see AUTHORS.txt for contributors. * * 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 2 * 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, you may find one here: * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html * or you may search the http://www.gnu.org website for the version 2 license, * or you may write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */ /** * @file board.i * @brief Specific BOARD extensions and templates */ /* By default we do not translate exceptions for EVERY C++ function since not every C++ function throws, and that would be unused and very bulky mapping code. Therefore please help gather the subset of C++ functions for each class that do throw and add each in a separate HANDLE_EXCEPTIONS() invocation before its respective class declaration. i.e. put them inside of their respective *.i file near the top; only class BOARD functions go in board.i. */ HANDLE_EXCEPTIONS(BOARD::TracksInNetBetweenPoints) %include board_item.i %include board_item_container.i %include board_connected_item.i %include board_design_settings.i %include connectivity.i %include pad.i %include track.i %include zone.i %include zone_settings.i %include pcb_text.i %include dimension.i %include drawsegment.i %include marker_pcb.i %include pcb_target.i %include text_mod.i %include edge_mod.i %include netinfo.i %include netclass.i %include pcb_plot_params.i %ignore operator++(SCH_LAYER_ID&); %ignore operator++(GAL_LAYER_ID&); %ignore operator+(const GAL_LAYER_ID&, int); %include layers_id_colors_and_visibility.h // Extend LSET by 2 methods to add or remove layers from the layer list // Mainly used to add or remove layers of a pad layer list %extend LSET { LSET addLayer( PCB_LAYER_ID aLayer) { return self->set(aLayer); } LSET removeLayer( PCB_LAYER_ID aLayer) { return self->reset(aLayer); } LSET addLayerSet( LSET aLayerSet) { return *self |= aLayerSet; } LSET removeLayerSet( LSET aLayerSet) { return *self &= ~aLayerSet; } %pythoncode %{ def AddLayer(self, layer): return self.addLayer( layer ) def AddLayerSet(self, layers): return self.addLayerSet( layers ) def RemoveLayer(self, layer): return self.removeLayer( layer ) def RemoveLayerSet(self, layers): return self.removeLayerSet( layers ) %} } %{ #include %} // std::vector templates %template(VIA_DIMENSION_Vector) std::vector; %include class_board.h %{ #include %} %extend std::deque { %pythoncode %{ def __iter__(self): it = self.iterator() try: while True: item = it.next() # throws StopIteration when iterator reached the end. yield item.Cast() except StopIteration: return %} } %extend BOARD { // BOARD_ITEM_CONTAINER's interface functions will be implemented by SWIG // automatically and inherited by the python wrapper class. %pythoncode %{ def GetModules(self): return self.Modules() def GetDrawings(self): return self.Drawings() def GetTracks(self): return self.Tracks() def Save(self,filename): return SaveBoard(filename,self) def GetNetClasses(self): return self.GetDesignSettings().m_NetClasses def GetCurrentNetClassName(self): return self.GetDesignSettings().m_CurrentNetClassName def GetViasDimensionsList(self): return self.GetDesignSettings().m_ViasDimensionsList def GetTrackWidthList(self): return self.GetDesignSettings().m_TrackWidthList def GetNetsByName(self): """ Return a dictionary like object with key:wxString netname and value:NETINFO_ITEM """ return self.GetNetInfo().NetsByName() def GetNetsByNetcode(self): """ Return a dictionary like object with key:int netcode and value:NETINFO_ITEM """ return self.GetNetInfo().NetsByNetcode() def GetNetcodeFromNetname(self,netname): """ Given a netname, return its netcode """ net = self.GetNetsByName()[netname] return net.GetNet() def GetAllNetClasses(self): """ Return a dictionary like object with net_class_name as key and NETCLASSPTR as value GetNetClasses(BOARD self) -> { wxString net_class_name : NETCLASSPTR } Include the "Default" netclass also. """ # Copy the NETCLASS_MAP so the one in the BOARD isn't modified # when we add the Default net class. netclassmap = {k:v for k,v in self.GetNetClasses().NetClasses().items()} netclassmap['Default'] = self.GetNetClasses().GetDefault() return netclassmap %} }