2013-03-15 13:27:18 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2013 NBEE Embedded Systems SL, Miguel Angel Ajo <miguelangel@ajo.es>
|
2017-05-25 07:05:35 +00:00
|
|
|
* Copyright (C) 2013-2017 KiCad Developers, see AUTHORS.txt for contributors.
|
2013-03-15 13:27:18 +00:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
2012-03-17 15:17:13 +00:00
|
|
|
#ifndef __PCBNEW_SCRIPTING_HELPERS_H
|
|
|
|
#define __PCBNEW_SCRIPTING_HELPERS_H
|
|
|
|
|
2018-01-30 07:13:33 +00:00
|
|
|
#include <pcb_edit_frame.h>
|
2012-04-14 21:18:27 +00:00
|
|
|
#include <io_mgr.h>
|
2017-05-24 16:08:15 +00:00
|
|
|
|
2012-03-17 15:17:13 +00:00
|
|
|
/* we could be including all these methods as static in a class, but
|
2017-05-24 16:08:15 +00:00
|
|
|
* we want plain pcbnew.<method_name> access from python
|
|
|
|
*/
|
2012-03-17 15:17:13 +00:00
|
|
|
|
|
|
|
#ifndef SWIG
|
2013-03-15 16:35:24 +00:00
|
|
|
void ScriptingSetPcbEditFrame( PCB_EDIT_FRAME* aPCBEdaFrame );
|
2012-03-17 15:17:13 +00:00
|
|
|
|
2013-03-15 16:35:24 +00:00
|
|
|
#endif
|
|
|
|
|
2017-05-24 19:34:56 +00:00
|
|
|
// For Python scripts: return the current board.
|
2013-03-15 16:35:24 +00:00
|
|
|
BOARD* GetBoard();
|
2012-04-14 21:18:27 +00:00
|
|
|
|
2013-03-15 16:35:24 +00:00
|
|
|
BOARD* LoadBoard( wxString& aFileName, IO_MGR::PCB_FILE_T aFormat );
|
2017-05-24 19:34:56 +00:00
|
|
|
|
|
|
|
// Default LoadBoard() to load .kicad_pcb files:.
|
2013-03-15 16:35:24 +00:00
|
|
|
BOARD* LoadBoard( wxString& aFileName );
|
2012-04-14 21:18:27 +00:00
|
|
|
|
2020-05-31 21:42:04 +00:00
|
|
|
/**
|
|
|
|
* Constructs a default BOARD with a tempoary (no filename) project
|
|
|
|
* @return the created board
|
|
|
|
*/
|
|
|
|
BOARD* CreateEmptyBoard();
|
|
|
|
|
2017-05-24 19:34:56 +00:00
|
|
|
// Boards can be saved only as .kicad_pcb file format,
|
|
|
|
// so no option to choose the file format.
|
2013-03-15 16:35:24 +00:00
|
|
|
bool SaveBoard( wxString& aFileName, BOARD* aBoard );
|
2012-03-17 15:17:13 +00:00
|
|
|
|
2020-06-05 22:21:41 +00:00
|
|
|
/**
|
|
|
|
* will get the nicknames of all of the footprint libraries configured in
|
|
|
|
* pcbnew in both the project and global library tables
|
|
|
|
* @return the list of footprint library nicknames, empty on error
|
|
|
|
*/
|
|
|
|
wxArrayString GetFootprintLibraries();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* will get the names of all of the footprints available in a footprint library
|
|
|
|
* @param aNickName is the nickname specifying which footprint library to fetch
|
|
|
|
* from
|
|
|
|
* @return the list of footprint names, empty on error
|
|
|
|
*/
|
|
|
|
wxArrayString GetFootprints( const wxString& aNickName );
|
|
|
|
|
2019-04-15 22:54:47 +00:00
|
|
|
/**
|
|
|
|
* will export the current BOARD to a specctra dsn file.
|
|
|
|
* See http://www.autotraxeda.com/docs/SPECCTRA/SPECCTRA.pdf for the
|
|
|
|
* specification.
|
|
|
|
* @return true if OK
|
|
|
|
*/
|
|
|
|
bool ExportSpecctraDSN( wxString& aFullFilename );
|
|
|
|
|
2020-08-28 11:17:50 +00:00
|
|
|
/**
|
|
|
|
* will export the current BOARD to a VRML (wrl) file.
|
|
|
|
* See ExportVRML_File in pcb_edit_frame.h for detailed documentation.
|
|
|
|
* @return true if OK
|
|
|
|
*/
|
|
|
|
bool ExportVRML( const wxString& aFullFileName, double aMMtoWRMLunit,
|
|
|
|
bool aExport3DFiles, bool aUseRelativePaths,
|
|
|
|
bool aUsePlainPCB, const wxString& a3D_Subdir,
|
|
|
|
double aXRef, double aYRef );
|
|
|
|
|
2019-04-15 22:54:47 +00:00
|
|
|
/**
|
|
|
|
* will import a specctra *.ses file and use it to relocate MODULEs and
|
|
|
|
* to replace all vias and tracks in an existing and loaded BOARD.
|
|
|
|
* See http://www.autotraxeda.com/docs/SPECCTRA/SPECCTRA.pdf for the
|
|
|
|
* specification.
|
|
|
|
* @return true if OK
|
|
|
|
*/
|
|
|
|
bool ImportSpecctraSES( wxString& aFullFilename );
|
|
|
|
|
|
|
|
/**
|
2020-10-21 10:31:06 +00:00
|
|
|
* Function HarvestFootprintsToLibrary
|
2020-10-21 03:48:06 +00:00
|
|
|
* Save footprints in a library:
|
2019-04-15 22:54:47 +00:00
|
|
|
* @param aStoreInNewLib:
|
2020-10-21 03:48:06 +00:00
|
|
|
* true : save footprints in a existing lib. Existing footprints will be kept
|
2019-04-15 22:54:47 +00:00
|
|
|
* or updated.
|
|
|
|
* This lib should be in fp lib table, and is type is .pretty
|
2020-10-21 03:48:06 +00:00
|
|
|
* false: save footprints in a new lib. It it is an existing lib,
|
2019-04-15 22:54:47 +00:00
|
|
|
* previous footprints will be removed
|
|
|
|
*
|
|
|
|
* @param aLibName:
|
|
|
|
* optional library name to create, stops dialog call.
|
|
|
|
* must be called with aStoreInNewLib as true
|
|
|
|
*/
|
2020-10-21 10:31:06 +00:00
|
|
|
bool HarvestFootprintsToLibrary( bool aStoreInNewLib, const wxString& aLibName = wxEmptyString,
|
|
|
|
wxString* aLibPath = NULL );
|
|
|
|
|
2017-08-27 06:04:12 +00:00
|
|
|
/**
|
2018-06-07 08:03:26 +00:00
|
|
|
* Update the board display after modifying it by a python script
|
2017-08-27 06:04:12 +00:00
|
|
|
* (note: it is automatically called by action plugins, after running the plugin,
|
|
|
|
* so call this function is usually not needed inside action plugins
|
|
|
|
*
|
|
|
|
* Could be deprecated because modifying a board (especially deleting items) outside
|
|
|
|
* a action plugin can crash Pcbnew.
|
|
|
|
*/
|
2017-03-17 14:41:00 +00:00
|
|
|
void Refresh();
|
2017-08-27 06:04:12 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the layer manager and other widgets from the board setup
|
|
|
|
* (layer and items visibility, colors ...)
|
|
|
|
* (note: it is automatically called by action plugins, after running the plugin,
|
|
|
|
* so call this function is usually not needed inside action plugins
|
|
|
|
*/
|
|
|
|
void UpdateUserInterface();
|
|
|
|
|
2019-02-19 13:46:08 +00:00
|
|
|
/**
|
|
|
|
* Returns the currently selected user unit value for the interface
|
|
|
|
* @return 0 = Inches, 1=mm, -1 if the frame isn't set
|
|
|
|
*/
|
|
|
|
int GetUserUnits();
|
|
|
|
|
2018-03-06 08:28:57 +00:00
|
|
|
/**
|
|
|
|
* Are we currently in an action plugin?
|
|
|
|
*/
|
|
|
|
bool IsActionRunning();
|
|
|
|
|
2020-09-23 00:23:14 +00:00
|
|
|
/**
|
|
|
|
* Runs the DRC check on the given board and writes the results to a report file.
|
|
|
|
* Requires that the project for the board be loaded, and note that unlike the DRC dialog
|
|
|
|
* this does not attempt to fill zones, so zones must be valid before calling.
|
|
|
|
*
|
|
|
|
* @param aBoard is a valid loaded board
|
|
|
|
* @param aFileName is the full path and name of the report file to write
|
|
|
|
* @param aUnits is the units to use in the report
|
|
|
|
* @param aTestTracksAgainstZones controls whether full track/zone checking is done (slow)
|
|
|
|
* @param aReportAllTrackErrors controls whether all errors or just the first error is reported
|
|
|
|
* for each track
|
|
|
|
* @return true if successful, false if not
|
|
|
|
*/
|
|
|
|
bool WriteDRCReport( BOARD* aBoard, const wxString& aFileName, EDA_UNITS aUnits,
|
|
|
|
bool aTestTracksAgainstZones, bool aReportAllTrackErrors );
|
|
|
|
|
2017-08-27 06:04:12 +00:00
|
|
|
#endif // __PCBNEW_SCRIPTING_HELPERS_H
|