Fix bone-headed mess up of two-click-place.

Original architecture was to pass KICAD_T in to specify what kind of
object you wanted.  That didn't work well with things like cursor
shape so it was moved to setting booleans based on the ACTION.  When
I cleared out the old KICAD_T stuff I missed one case where it was
still used.  That is now corrected as well.

Fixes https://gitlab.com/kicad/code/kicad/issues/7651
This commit is contained in:
Jeff Young 2021-02-22 11:52:33 +00:00
parent 41b8ef85e3
commit 09d3667bce
1 changed files with 27 additions and 31 deletions

View File

@ -880,12 +880,11 @@ int SCH_DRAWING_TOOLS::TwoClickPlace( const TOOL_EVENT& aEvent )
else else
m_inTwoClickPlace = true; m_inTwoClickPlace = true;
bool isImportMode = aEvent.IsAction( &EE_ACTIONS::importSheetPin );
bool isText = aEvent.IsAction( &EE_ACTIONS::placeSchematicText ); bool isText = aEvent.IsAction( &EE_ACTIONS::placeSchematicText );
bool isGlobalLabel = aEvent.IsAction( &EE_ACTIONS::placeGlobalLabel ); bool isGlobalLabel = aEvent.IsAction( &EE_ACTIONS::placeGlobalLabel );
bool isHierLabel = aEvent.IsAction( &EE_ACTIONS::placeHierLabel ); bool isHierLabel = aEvent.IsAction( &EE_ACTIONS::placeHierLabel );
bool isNetLabel = aEvent.IsAction( &EE_ACTIONS::placeLabel ); bool isNetLabel = aEvent.IsAction( &EE_ACTIONS::placeLabel );
KICAD_T type = aEvent.Parameter<KICAD_T>(); bool isSheetPin = aEvent.IsAction( &EE_ACTIONS::importSheetPin );
int snapLayer = isText ? LAYER_GRAPHICS : LAYER_CONNECTABLE; int snapLayer = isText ? LAYER_GRAPHICS : LAYER_CONNECTABLE;
m_toolMgr->RunAction( EE_ACTIONS::clearSelection, true ); m_toolMgr->RunAction( EE_ACTIONS::clearSelection, true );
@ -977,21 +976,23 @@ int SCH_DRAWING_TOOLS::TwoClickPlace( const TOOL_EVENT& aEvent )
{ {
m_toolMgr->RunAction( EE_ACTIONS::clearSelection, true ); m_toolMgr->RunAction( EE_ACTIONS::clearSelection, true );
switch( type ) if( isText )
{ {
case SCH_LABEL_T:
item = createNewText( cursorPos, LAYER_LOCLABEL ); item = createNewText( cursorPos, LAYER_LOCLABEL );
break; }
case SCH_HIER_LABEL_T: else if( isGlobalLabel )
item = createNewText( cursorPos, LAYER_HIERLABEL ); {
break;
case SCH_GLOBAL_LABEL_T:
item = createNewText( cursorPos, LAYER_GLOBLABEL ); item = createNewText( cursorPos, LAYER_GLOBLABEL );
break; }
case SCH_TEXT_T: else if( isHierLabel )
item = createNewText( cursorPos, LAYER_NOTES ); {
break; item = createNewText( cursorPos, LAYER_HIERLABEL );
case SCH_SHEET_PIN_T: }
else if( isNetLabel )
{
item = createNewText( cursorPos, LAYER_LOCLABEL );
}
else if( isSheetPin )
{ {
EDA_ITEM* i; EDA_ITEM* i;
SCH_HIERLABEL* label = nullptr; SCH_HIERLABEL* label = nullptr;
@ -1000,18 +1001,15 @@ int SCH_DRAWING_TOOLS::TwoClickPlace( const TOOL_EVENT& aEvent )
if( m_selectionTool->SelectPoint( cursorPos, EE_COLLECTOR::SheetsOnly, &i ) ) if( m_selectionTool->SelectPoint( cursorPos, EE_COLLECTOR::SheetsOnly, &i ) )
sheet = dynamic_cast<SCH_SHEET*>( i ); sheet = dynamic_cast<SCH_SHEET*>( i );
item = nullptr;
if( !sheet ) if( !sheet )
{ {
m_statusPopup.reset( new STATUS_TEXT_POPUP( m_frame ) ); m_statusPopup.reset( new STATUS_TEXT_POPUP( m_frame ) );
m_statusPopup->SetText( _( "Click over a sheet." ) ); m_statusPopup->SetText( _( "Click over a sheet." ) );
m_statusPopup->Move( wxGetMousePosition() + wxPoint( 20, 20 ) ); m_statusPopup->Move( wxGetMousePosition() + wxPoint( 20, 20 ) );
m_statusPopup->PopupFor( 2000 ); m_statusPopup->PopupFor( 2000 );
break; item = nullptr;
} }
else
if( isImportMode )
{ {
label = importHierLabel( sheet ); label = importHierLabel( sheet );
@ -1021,15 +1019,13 @@ int SCH_DRAWING_TOOLS::TwoClickPlace( const TOOL_EVENT& aEvent )
m_statusPopup->SetText( _( "No new hierarchical labels found." ) ); m_statusPopup->SetText( _( "No new hierarchical labels found." ) );
m_statusPopup->Move( wxGetMousePosition() + wxPoint( 20, 20 ) ); m_statusPopup->Move( wxGetMousePosition() + wxPoint( 20, 20 ) );
m_statusPopup->PopupFor( 2000 ); m_statusPopup->PopupFor( 2000 );
break; item = nullptr;
} }
} else
{
item = createSheetPin( sheet, label ); item = createSheetPin( sheet, label );
break;
} }
default: }
break;
} }
// Restore cursor after dialog // Restore cursor after dialog