PAD_TOOL: enable 'Apply' after copying a pad

This commit is contained in:
Maciej Suminski 2017-02-16 18:39:09 +01:00
parent 2fa17b4460
commit 6fdccc1829
2 changed files with 12 additions and 27 deletions

View File

@ -90,21 +90,18 @@ private:
ENABLEMENTS enablements; ENABLEMENTS enablements;
auto anyPadSel = S_C::HasType( PCB_PAD_T ); auto anyPadSel = S_C::HasType( PCB_PAD_T );
auto singlePadSel = S_C::Count( 1 ) && S_C::OnlyType( PCB_PAD_T );
auto singlePadSel = S_C::Count( 1 )
&& S_C::OnlyType( PCB_PAD_T );
// Apply pads enabled when any pads selected (it applies to each one // Apply pads enabled when any pads selected (it applies to each one
// individually), plus need a valid global pad setting // individually), plus need a valid global pad setting
enablements.canImport = m_haveGlobalPadSettings() enablements.canImport = m_haveGlobalPadSettings() && ( anyPadSel )( aSelection );
&& ( anyPadSel )( aSelection );
// Copy pads item enabled only when there is a single pad selected // Copy pads item enabled only when there is a single pad selected
// (otherwise how would we know which one to copy?) // (otherwise how would we know which one to copy?)
enablements.canExport = ( singlePadSel )( aSelection ); enablements.canExport = ( singlePadSel )( aSelection );
// Push pads available when there is a single pad to push from // Push pads available when there is a single pad to push from
enablements.canPush = ( singlePadSel ) ( aSelection ); enablements.canPush = ( singlePadSel )( aSelection );
return enablements; return enablements;
} }
@ -127,7 +124,7 @@ private:
PAD_TOOL::PAD_TOOL() : PAD_TOOL::PAD_TOOL() :
PCB_TOOL( "pcbnew.PadTool" ) PCB_TOOL( "pcbnew.PadTool" ), m_padCopied( false )
{ {
} }
@ -138,14 +135,7 @@ PAD_TOOL::~PAD_TOOL()
void PAD_TOOL::Reset( RESET_REASON aReason ) void PAD_TOOL::Reset( RESET_REASON aReason )
{ {
} m_padCopied = false;
bool PAD_TOOL::hasMasterPadSettings()
{
auto& frame = *getEditFrame<PCB_EDIT_FRAME>();
D_PAD& masterPad = frame.GetDesignSettings().m_Pad_Master;
return masterPad.GetParent() != nullptr;
} }
@ -158,13 +148,8 @@ bool PAD_TOOL::haveFootprints()
bool PAD_TOOL::Init() bool PAD_TOOL::Init()
{ {
// functor to report if the current frame has master pad settings auto contextMenu = std::make_shared<PAD_CONTEXT_MENU>( EditingModules(),
std::function<bool()> haveMasterPad = [this] () { [this]() { return m_padCopied; } );
return hasMasterPadSettings();
};
auto contextMenu = std::make_shared<PAD_CONTEXT_MENU>(
EditingModules(), haveMasterPad );
contextMenu->SetTool( this ); contextMenu->SetTool( this );
SELECTION_TOOL* selTool = m_toolMgr->GetTool<SELECTION_TOOL>(); SELECTION_TOOL* selTool = m_toolMgr->GetTool<SELECTION_TOOL>();
@ -243,6 +228,7 @@ int PAD_TOOL::copyPadSettings( const TOOL_EVENT& aEvent )
{ {
const auto& selPad = static_cast<const D_PAD&>( *item ); const auto& selPad = static_cast<const D_PAD&>( *item );
masterPad.ImportSettingsFromMaster( selPad ); masterPad.ImportSettingsFromMaster( selPad );
m_padCopied = true;
} }
} }
@ -304,7 +290,6 @@ static void globalChangePadSettings( BOARD& board,
} }
int PAD_TOOL::pushPadSettings( const TOOL_EVENT& aEvent ) int PAD_TOOL::pushPadSettings( const TOOL_EVENT& aEvent )
{ {
auto& selTool = *m_toolMgr->GetTool<SELECTION_TOOL>(); auto& selTool = *m_toolMgr->GetTool<SELECTION_TOOL>();
@ -377,6 +362,7 @@ int PAD_TOOL::pushPadSettings( const TOOL_EVENT& aEvent )
return 0; return 0;
} }
void PAD_TOOL::SetTransitions() void PAD_TOOL::SetTransitions()
{ {
Go( &PAD_TOOL::applyPadSettings, COMMON_ACTIONS::applyPadSettings.MakeEvent() ); Go( &PAD_TOOL::applyPadSettings, COMMON_ACTIONS::applyPadSettings.MakeEvent() );

View File

@ -50,9 +50,6 @@ public:
void SetTransitions() override; void SetTransitions() override;
private: private:
///> Determine if the frame has a valid master pad setting
bool hasMasterPadSettings();
///> Determine if there are any footprints on the board ///> Determine if there are any footprints on the board
bool haveFootprints(); bool haveFootprints();
@ -64,7 +61,9 @@ private:
///> Push pad settings from a pad to other pads on board or module ///> Push pad settings from a pad to other pads on board or module
int pushPadSettings( const TOOL_EVENT& aEvent ); int pushPadSettings( const TOOL_EVENT& aEvent );
///> Flag to indicate there are valid settings stored in the Master Pad object
bool m_padCopied;
}; };
#endif // __PAD_TOOL_H #endif // __PAD_TOOL_H