eeschema: Cleanup processing for multiple line editing

This commit is contained in:
Ian McInerney 2020-01-03 19:30:29 +00:00
parent 20e7fc8a0e
commit 81292d2bf1
1 changed files with 7 additions and 11 deletions

View File

@ -195,7 +195,7 @@ bool SCH_EDIT_TOOL::Init()
case SCH_LINE_T: case SCH_LINE_T:
{ {
const std::deque<EDA_ITEM*> items = aSel.GetItems(); const std::deque<EDA_ITEM*> items = aSel.GetItems();
if( !std::all_of( items.begin(), items.end(), if( !std::all_of( items.begin(), items.end(),
[&]( const EDA_ITEM* item ) [&]( const EDA_ITEM* item )
{ {
const SCH_LINE* line = dynamic_cast<const SCH_LINE*>( item ); const SCH_LINE* line = dynamic_cast<const SCH_LINE*>( item );
@ -1306,23 +1306,19 @@ int SCH_EDIT_TOOL::Properties( const TOOL_EVENT& aEvent )
case SCH_LINE_T: case SCH_LINE_T:
{ {
SCH_LINE* line = static_cast<SCH_LINE*>( item );
// We purposely disallow editing everything except graphic lines
if( !line->IsGraphicLine() )
break;
if( !selection.AreAllItemsIdentical() ) if( !selection.AreAllItemsIdentical() )
break; break;
std::deque<SCH_LINE*> lines; std::deque<SCH_LINE*> lines;
for( auto item : selection.Items() ) for( auto selItem : selection.Items() )
{ {
auto line = dynamic_cast<SCH_LINE*>( item ); SCH_LINE* line = dynamic_cast<SCH_LINE*>( selItem );
assert( line != nullptr );
lines.push_back( line ); if( line )
lines.push_back( line );
} }
// Verify we are only editing graphic lines
if( !std::all_of( lines.begin(), lines.end(), if( !std::all_of( lines.begin(), lines.end(),
[&]( const SCH_LINE* r ) { return r->IsGraphicLine(); } ) ) [&]( const SCH_LINE* r ) { return r->IsGraphicLine(); } ) )
break; break;