Cleanup SWIG's board.i, remove scrap *.{ref,orig} files, and add .pyc to .gitignore
This commit is contained in:
parent
3623421912
commit
374808ac5b
|
@ -35,6 +35,7 @@ install_manifest.txt
|
||||||
Documentation/doxygen
|
Documentation/doxygen
|
||||||
Documentation/development/doxygen
|
Documentation/development/doxygen
|
||||||
*.bak
|
*.bak
|
||||||
|
*.pyc
|
||||||
.*.swp
|
.*.swp
|
||||||
*~
|
*~
|
||||||
build-*
|
build-*
|
||||||
|
|
|
@ -1,160 +0,0 @@
|
||||||
/*
|
|
||||||
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
||||||
*
|
|
||||||
* Copyright (C) 2012 NBEE Embedded Systems, Miguel Angel Ajo <miguelangel@nbee.es>
|
|
||||||
* Copyright (C) 1992-2012 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 kicad.i
|
|
||||||
* @brief General wrappers for kicad / wx structures and classes
|
|
||||||
*/
|
|
||||||
|
|
||||||
%include <std_vector.i>
|
|
||||||
%include <std_basic_string.i>
|
|
||||||
%include <std_string.i>
|
|
||||||
%include <std_map.i>
|
|
||||||
%include <std_shared_ptr.i>
|
|
||||||
%include <std_set.i>
|
|
||||||
|
|
||||||
/*
|
|
||||||
http://www.swig.org/Doc3.0/CPlusPlus11.html
|
|
||||||
7.3.3 Hash tables
|
|
||||||
|
|
||||||
The new hash tables in the STL are unordered_set, unordered_multiset,
|
|
||||||
unordered_map, unordered_multimap. These are not available in SWIG, but in
|
|
||||||
principle should be easily implemented by adapting the current STL containers.
|
|
||||||
|
|
||||||
%include <std_unordered_map.i>
|
|
||||||
*/
|
|
||||||
|
|
||||||
// ignore some constructors of EDA_ITEM that will make the build fail
|
|
||||||
|
|
||||||
%nodefaultctor EDA_ITEM;
|
|
||||||
%ignore EDA_ITEM::EDA_ITEM( EDA_ITEM* parent, KICAD_T idType );
|
|
||||||
%ignore EDA_ITEM::EDA_ITEM( KICAD_T idType );
|
|
||||||
%ignore EDA_ITEM::EDA_ITEM( const EDA_ITEM& base );
|
|
||||||
|
|
||||||
|
|
||||||
%warnfilter(401) EDA_ITEM;
|
|
||||||
%warnfilter(509) UTF8;
|
|
||||||
|
|
||||||
/* swig tries to wrap SetBack/SetNext on derived classes, but this method is
|
|
||||||
private for most childs, so if we don't ignore it won't compile */
|
|
||||||
|
|
||||||
%ignore EDA_ITEM::SetBack;
|
|
||||||
%ignore EDA_ITEM::SetNext;
|
|
||||||
|
|
||||||
// ignore other functions that cause trouble
|
|
||||||
|
|
||||||
%ignore InitKiCadAbout;
|
|
||||||
%ignore GetCommandOptions;
|
|
||||||
|
|
||||||
%rename(getWxRect) operator wxRect;
|
|
||||||
%ignore operator <<;
|
|
||||||
%ignore operator=;
|
|
||||||
|
|
||||||
|
|
||||||
// headers/imports that must be included in the _wrapper.cpp at top
|
|
||||||
|
|
||||||
%{
|
|
||||||
#include <macros.h>
|
|
||||||
#include <cstddef>
|
|
||||||
#include <dlist.h>
|
|
||||||
#include <base_struct.h>
|
|
||||||
#include <class_eda_rect.h>
|
|
||||||
#include <common.h>
|
|
||||||
#include <wx_python_helpers.h>
|
|
||||||
#include <cstddef>
|
|
||||||
#include <vector>
|
|
||||||
#include <bitset>
|
|
||||||
|
|
||||||
#include <class_title_block.h>
|
|
||||||
#include <class_colors_design_settings.h>
|
|
||||||
#include <class_marker_base.h>
|
|
||||||
#include <eda_text.h>
|
|
||||||
#include <convert_to_biu.h>
|
|
||||||
%}
|
|
||||||
|
|
||||||
// all the wx wrappers for wxString, wxPoint, wxRect, wxChar ..
|
|
||||||
%include <wx.i>
|
|
||||||
|
|
||||||
// header files that must be wrapped
|
|
||||||
|
|
||||||
%include <macros.h>
|
|
||||||
%include <core/typeinfo.h>
|
|
||||||
%include <dlist.h>
|
|
||||||
%include <base_struct.h>
|
|
||||||
%include <class_eda_rect.h>
|
|
||||||
%include <common.h>
|
|
||||||
%include <class_title_block.h>
|
|
||||||
%include <class_colors_design_settings.h>
|
|
||||||
%include <class_marker_base.h>
|
|
||||||
%include <eda_text.h>
|
|
||||||
|
|
||||||
// special iteration wrapper for DLIST objects
|
|
||||||
%include "dlist.i"
|
|
||||||
|
|
||||||
// std template mappings
|
|
||||||
%template(intVector) std::vector<int>;
|
|
||||||
%template(str_utf8_Map) std::map< std::string,UTF8 >;
|
|
||||||
|
|
||||||
// wrapper of BASE_SEQ (see typedef std::vector<LAYER_ID> BASE_SEQ;)
|
|
||||||
%template(base_seqVect) std::vector<enum LAYER_ID>;
|
|
||||||
|
|
||||||
// TODO: wrapper of BASE_SET (see std::bitset<LAYER_ID_COUNT> BASE_SET;)
|
|
||||||
|
|
||||||
|
|
||||||
// KiCad plugin handling
|
|
||||||
%include "kicadplugins.i"
|
|
||||||
|
|
||||||
// map CPolyLine and classes used in CPolyLine:
|
|
||||||
#include <../polygon/PolyLine.h>
|
|
||||||
%include <../polygon/PolyLine.h>
|
|
||||||
|
|
||||||
// ignore warning relative to operator = and operator ++:
|
|
||||||
#pragma SWIG nowarn=362,383
|
|
||||||
|
|
||||||
// Rename operators defined in utf8.h
|
|
||||||
%rename(utf8_to_charptr) operator char* () const;
|
|
||||||
%rename(utf8_to_wxstring) operator wxString () const;
|
|
||||||
|
|
||||||
#include <utf8.h>
|
|
||||||
%include <utf8.h>
|
|
||||||
|
|
||||||
%extend UTF8
|
|
||||||
{
|
|
||||||
const char* Cast_to_CChar() { return (self->c_str()); }
|
|
||||||
|
|
||||||
%pythoncode
|
|
||||||
%{
|
|
||||||
|
|
||||||
# Get the char buffer of the UTF8 string
|
|
||||||
def GetChars(self):
|
|
||||||
return self.Cast_to_CChar()
|
|
||||||
|
|
||||||
# Convert the UTF8 string to a python string
|
|
||||||
# Same as GetChars(), but more easy to use in print command
|
|
||||||
def __str__(self):
|
|
||||||
return self.GetChars()
|
|
||||||
|
|
||||||
%}
|
|
||||||
}
|
|
||||||
|
|
|
@ -33,37 +33,34 @@
|
||||||
|
|
||||||
By default we do not translate exceptions for EVERY C++ function since not every
|
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.
|
C++ function throws, and that would be unused and very bulky mapping code.
|
||||||
Therefore please help gather the subset of C++ functions for this class that do
|
Therefore please help gather the subset of C++ functions for each class that do
|
||||||
throw and add them here, each before its respective class declaration.
|
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)
|
HANDLE_EXCEPTIONS(BOARD::TracksInNetBetweenPoints)
|
||||||
|
|
||||||
|
|
||||||
%include <class_board_design_settings.h>
|
//%import dlist.h // comes in from kicad.i which wraps & includes board.i
|
||||||
%{
|
|
||||||
#include <class_board.h>
|
|
||||||
#include <class_board_design_settings.h>
|
|
||||||
%}
|
|
||||||
|
|
||||||
|
|
||||||
%import dlist.h
|
|
||||||
|
|
||||||
|
|
||||||
// Organize the two forms of include side by side so that it is easier to
|
|
||||||
// migrate each grouping into a separate *.i file later.
|
|
||||||
|
|
||||||
|
|
||||||
%include board_item.i
|
%include board_item.i
|
||||||
|
|
||||||
%include board_item_container.i
|
%include board_item_container.i
|
||||||
|
%include board_connected_item.i
|
||||||
%include class_board_connected_item.h
|
%include board_design_settings.i
|
||||||
|
|
||||||
|
|
||||||
%include pad.i
|
%include pad.i
|
||||||
%include track.i
|
%include track.i
|
||||||
%include zone.i
|
%include zone.i
|
||||||
|
%include zone_settings.i
|
||||||
|
%include pcb_text.i
|
||||||
|
%include dimension.i
|
||||||
|
%include drawsegment.i
|
||||||
|
%include marker_pcb.i
|
||||||
|
%include mire.i
|
||||||
|
%include text_mod.i
|
||||||
|
%include edge_mod.i
|
||||||
|
%include netinfo.i
|
||||||
|
%include netclass.i
|
||||||
|
|
||||||
|
|
||||||
%include layers_id_colors_and_visibility.h
|
%include layers_id_colors_and_visibility.h
|
||||||
|
@ -96,33 +93,19 @@ HANDLE_EXCEPTIONS(BOARD::TracksInNetBetweenPoints)
|
||||||
%}
|
%}
|
||||||
|
|
||||||
|
|
||||||
%include pcb_text.i
|
|
||||||
%include dimension.i
|
|
||||||
%include drawsegment.i
|
|
||||||
%include marker_pcb.i
|
|
||||||
%include mire.i
|
|
||||||
%include text_mod.i
|
|
||||||
%include edge_mod.i
|
|
||||||
|
|
||||||
|
|
||||||
%include class_zone_settings.h
|
|
||||||
%{
|
|
||||||
#include <class_zone_settings.h>
|
|
||||||
%}
|
|
||||||
|
|
||||||
%include netinfo.i
|
|
||||||
%include netclass.i
|
|
||||||
|
|
||||||
|
|
||||||
// std::vector templates
|
// std::vector templates
|
||||||
|
|
||||||
%template(VIA_DIMENSION_Vector) std::vector<VIA_DIMENSION>;
|
%template(VIA_DIMENSION_Vector) std::vector<VIA_DIMENSION>;
|
||||||
%template(RATSNEST_Vector) std::vector<RATSNEST_ITEM>;
|
%template(RATSNEST_Vector) std::vector<RATSNEST_ITEM>;
|
||||||
|
|
||||||
|
|
||||||
%include class_board.h
|
%include class_board.h
|
||||||
|
%{
|
||||||
|
#include <class_board.h>
|
||||||
|
%}
|
||||||
|
|
||||||
%extend BOARD
|
%extend BOARD
|
||||||
{
|
{
|
||||||
|
// BOARD_ITEM_CONTAINER's interface functions will be implemented by SWIG
|
||||||
|
// automatically and inherited by the python wrapper class.
|
||||||
|
|
||||||
%pythoncode
|
%pythoncode
|
||||||
%{
|
%{
|
||||||
|
|
||||||
|
@ -173,9 +156,9 @@ HANDLE_EXCEPTIONS(BOARD::TracksInNetBetweenPoints)
|
||||||
"""
|
"""
|
||||||
netclassmap = self.GetNetClasses().NetClasses()
|
netclassmap = self.GetNetClasses().NetClasses()
|
||||||
|
|
||||||
# Add the Default one too, but this is probably modifying the dict (aka NETCLASS_MAP)
|
# Add the Default one too, but this is probably modifying the NETCLASS_MAP
|
||||||
# in the BOARD. So change code here to create a dict copy first.
|
# in the BOARD. If that causes trouble, could make a deepcopy() here first.
|
||||||
# netclassmap = dict(netclassmap)
|
# netclassmap = deepcopy(netclassmap)
|
||||||
netclassmap['Default'] = self.GetNetClasses().GetDefault()
|
netclassmap['Default'] = self.GetNetClasses().GetDefault()
|
||||||
return netclassmap
|
return netclassmap
|
||||||
%}
|
%}
|
||||||
|
|
|
@ -1,147 +0,0 @@
|
||||||
--- pcbnew/scripting/board.i
|
|
||||||
+++ pcbnew/swig/board.i
|
|
||||||
@@ -28,38 +28,123 @@
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
-%extend BOARD
|
|
||||||
-{
|
|
||||||
- %pythoncode
|
|
||||||
- %{
|
|
||||||
- def GetModules(self): return self.m_Modules
|
|
||||||
- def GetDrawings(self): return self.m_Drawings
|
|
||||||
- def GetTracks(self): return self.m_Track
|
|
||||||
- def GetFullRatsnest(self): return self.m_FullRatsnest
|
|
||||||
+/*
|
|
||||||
|
|
||||||
- def Save(self,filename):
|
|
||||||
- return SaveBoard(filename,self,IO_MGR.KICAD)
|
|
||||||
+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 this class that do
|
|
||||||
+throw and add them here, before the class declarations.
|
|
||||||
|
|
||||||
- #
|
|
||||||
- # add function, clears the thisown to avoid python from deleting
|
|
||||||
- # the object in the garbage collector
|
|
||||||
- #
|
|
||||||
+*/
|
|
||||||
+HANDLE_EXCEPTIONS(BOARD::TracksInNetBetweenPoints)
|
|
||||||
|
|
||||||
- def Add(self,item):
|
|
||||||
- item.thisown=0
|
|
||||||
- self.AddNative(item)
|
|
||||||
- %}
|
|
||||||
|
|
||||||
-}
|
|
||||||
+%{
|
|
||||||
+#include <class_board.h>
|
|
||||||
|
|
||||||
-// this is to help python with the * accessor of DLIST templates
|
|
||||||
+#include <class_board_design_settings.h>
|
|
||||||
+#include <layers_id_colors_and_visibility.h>
|
|
||||||
+
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+%import dlist.h
|
|
||||||
+
|
|
||||||
+// Organize the two forms of include side by side so that it is easier to
|
|
||||||
+// migrate each grouping into a separate *.i file later.
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+%include class_board_item.h
|
|
||||||
+%{
|
|
||||||
+#include <class_board_item.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include class_board_connected_item.h
|
|
||||||
+%{
|
|
||||||
+#include <class_board_connected_item.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include pad_shapes.h
|
|
||||||
+
|
|
||||||
+%include class_pad.h
|
|
||||||
+%{
|
|
||||||
+#include <class_pad.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include class_module.h
|
|
||||||
+%{
|
|
||||||
+#include <class_module.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include class_track.h
|
|
||||||
+%{
|
|
||||||
+#include <class_track.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include class_zone.h
|
|
||||||
+%include zones.h
|
|
||||||
+%{
|
|
||||||
+#include <class_zone.h>
|
|
||||||
+#include <zones.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+%include layers_id_colors_and_visibility.h
|
|
||||||
+
|
|
||||||
+%include class_pcb_text.h
|
|
||||||
+%{
|
|
||||||
+#include <class_pcb_text.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include class_dimension.h
|
|
||||||
+%{
|
|
||||||
+#include <class_dimension.h>
|
|
||||||
+%}
|
|
||||||
|
|
||||||
+
|
|
||||||
+%include class_drawsegment.h
|
|
||||||
+%{
|
|
||||||
+#include <class_drawsegment.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include class_marker_pcb.h
|
|
||||||
+%{
|
|
||||||
+#include <class_marker_pcb.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+%include class_mire.h
|
|
||||||
+%{
|
|
||||||
+#include <class_mire.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+%include class_text_mod.h
|
|
||||||
+%{
|
|
||||||
+#include <class_text_mod.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include class_edge_mod.h
|
|
||||||
+%{
|
|
||||||
+#include <class_edge_mod.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+%include class_zone_settings.h
|
|
||||||
+
|
|
||||||
+%include class_netinfo.h
|
|
||||||
+%include class_netclass.h
|
|
||||||
+%{
|
|
||||||
+#include <class_netinfo.h>
|
|
||||||
+#include <class_netclass.h>
|
|
||||||
+%}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+// this is to help python with the * accessor of DLIST templates
|
|
||||||
%rename(Get) operator BOARD_ITEM*;
|
|
||||||
%rename(Get) operator TRACK*;
|
|
||||||
%rename(Get) operator D_PAD*;
|
|
||||||
%rename(Get) operator MODULE*;
|
|
||||||
|
|
||||||
-
|
|
||||||
// we must translate C++ templates to scripting languages
|
|
||||||
|
|
||||||
%template(BOARD_ITEM_List) DLIST<BOARD_ITEM>;
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
|
||||||
|
%include class_board_connected_item.h
|
||||||
|
|
||||||
|
%{
|
||||||
|
#include <class_board_connected_item.h>
|
||||||
|
%}
|
||||||
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
%include <class_board_design_settings.h>
|
||||||
|
%{
|
||||||
|
#include <class_board_design_settings.h>
|
||||||
|
%}
|
|
@ -39,7 +39,7 @@
|
||||||
|
|
||||||
|
|
||||||
// BOARD_ITEM_CONTAINER's interface functions will be implemented by SWIG
|
// BOARD_ITEM_CONTAINER's interface functions will be implemented by SWIG
|
||||||
// automatically.
|
// automatically and inherited by the python wrapper class.
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,29 +0,0 @@
|
||||||
--- pcbnew/scripting/pcbnew.i
|
|
||||||
+++ pcbnew/swig/pcbnew.i
|
|
||||||
@@ -87,26 +46,6 @@ class BASE_SET {};
|
|
||||||
#include <kicad_plugin.h>
|
|
||||||
%}
|
|
||||||
|
|
||||||
-%include <class_board_item.h>
|
|
||||||
-%include <class_board_connected_item.h>
|
|
||||||
-%include <pad_shapes.h>
|
|
||||||
-%include <class_pad.h>
|
|
||||||
-%include <class_netinfo.h>
|
|
||||||
-%include <class_module.h>
|
|
||||||
-%include <class_track.h>
|
|
||||||
-%include <class_zone.h>
|
|
||||||
-%include <zones.h>
|
|
||||||
-%include <layers_id_colors_and_visibility.h>
|
|
||||||
-%include <class_pcb_text.h>
|
|
||||||
-%include <class_dimension.h>
|
|
||||||
-%include <class_drawsegment.h>
|
|
||||||
-%include <class_marker_pcb.h>
|
|
||||||
-%include <class_mire.h>
|
|
||||||
-%include <class_text_mod.h>
|
|
||||||
-%include <class_edge_mod.h>
|
|
||||||
-%include <dlist.h>
|
|
||||||
-%include <class_zone_settings.h>
|
|
||||||
-%include <class_netclass.h>
|
|
||||||
|
|
||||||
%include <class_board_design_settings.h>
|
|
||||||
%include <plotcontroller.h>
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
%include class_zone_settings.h
|
||||||
|
%{
|
||||||
|
#include <class_zone_settings.h>
|
||||||
|
%}
|
Loading…
Reference in New Issue