kicad/pcbnew/router/router_tool.h

72 lines
2.2 KiB
C
Raw Normal View History

/*
* KiRouter - a push-and-(sometimes-)shove PCB router
*
* Copyright (C) 2013-2017 CERN
* Copyright (C) 2016 KiCad Developers, see AUTHORS.txt for contributors.
* Author: Tomasz Wlostowski <tomasz.wlostowski@cern.ch>
* Author: Maciej Suminski <maciej.suminski@cern.ch>
2013-09-26 21:53:54 +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 3 of the License, or (at your
* option) any later version.
2013-09-26 21:53:54 +00:00
*
* 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.
2013-09-26 21:53:54 +00:00
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __ROUTER_TOOL_H
#define __ROUTER_TOOL_H
#include "pns_tool_base.h"
class APIEXPORT ROUTER_TOOL : public PNS::TOOL_BASE
{
public:
ROUTER_TOOL();
~ROUTER_TOOL();
2016-09-24 18:53:15 +00:00
bool Init() override;
void Reset( RESET_REASON aReason ) override;
2017-01-17 16:24:09 +00:00
int RouteSingleTrace( const TOOL_EVENT& aEvent );
int RouteDiffPair( const TOOL_EVENT& aEvent );
int InlineDrag( const TOOL_EVENT& aEvent );
// TODO make this private?
int DpDimensionsDialog( const TOOL_EVENT& aEvent );
int SettingsDialog( const TOOL_EVENT& aEvent );
int CustomTrackWidthDialog( const TOOL_EVENT& aEvent );
void setTransitions() override;
private:
int mainLoop( PNS::ROUTER_MODE aMode );
2013-09-26 21:53:54 +00:00
int getDefaultWidth( int aNetCode );
2014-11-14 19:19:00 +00:00
void performRouting();
void performDragging( int aMode = PNS::DM_ANY );
void breakTrack();
2014-11-14 19:19:00 +00:00
2013-09-26 21:53:54 +00:00
void getNetclassDimensions( int aNetCode, int& aWidth, int& aViaDiameter, int& aViaDrill );
void handleCommonEvents( const TOOL_EVENT& evt );
int getStartLayer( const PNS::ITEM* aItem );
void switchLayerOnViaPlacement();
int onViaCommand( const TOOL_EVENT& aEvent );
int onTrackViaSizeChanged( const TOOL_EVENT& aEvent );
int onLayerChanged( const TOOL_EVENT& aEvent );
2015-08-04 21:08:13 +00:00
bool prepareInteractive();
bool finishInteractive();
};
#endif