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
|
|
|
|
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
|
|
|
|
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
|
|
|
|
2017-03-17 14:41:00 +00:00
|
|
|
void WindowZoom( int xl, int yl, int width, int height );
|
2012-07-31 21:00:33 +00:00
|
|
|
|
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();
|
|
|
|
|
2017-08-27 06:04:12 +00:00
|
|
|
#endif // __PCBNEW_SCRIPTING_HELPERS_H
|