39#include <unordered_set>
74 if( aSel.GetSize() == 1 )
88 return aSel.GetSize() == 1 && aSel.Front()->Type() ==
SCH_SYMBOL_T;
94 if( aSel.GetSize() == 1 )
108 if( aSel.GetSize() == 1 )
122 if( aSel.GetSize() == 1 )
126 if(
pin &&
pin->GetLibPin() )
127 return !
pin->GetLibPin()->GetAlternates().empty();
145 return aSel.GetSize() > 1 && aSel.OnlyContains( {
SCH_SYMBOL_T } );
151 return aSel.GetSize() >= 1 && aSel.OnlyContains( {
SCH_PIN_T } );
163 for(
EDA_ITEM* item : aSel.Items() )
167 if( schItem->IsLocked() )
178 for(
EDA_ITEM* item : aSel.Items() )
182 if( !schItem->IsLocked() )
193 for(
int i = 0; aAllowedActions[i]; ++i )
195 if( aEvent->
IsAction( aAllowedActions[i] ) )
204#define HITTEST_THRESHOLD_PIXELS 5
291 if( symbolEditorFrame )
306 auto expandableSelection =
314 auto schEditSheetPageNumberCondition =
324 auto schEditCondition =
330 auto belowRootSheetCondition =
354 auto groupEnterCondition =
357 auto inGroupCondition =
363 auto multipleUnitsSelection = [](
const SELECTION& aSel )
372 m_frame->eeconfig()->m_Input.allow_unconstrained_pin_swaps;
376 auto& menu =
m_menu->GetMenu();
391 menu.AddSeparator( 100 );
395 menu.AddSeparator( 100 );
402 menu.AddSeparator( 200 );
420 menu.AddSeparator( 400 );
424 menu.AddSeparator( 1000 );
460 if( symbolEditFrame )
487 auto pinOrientation =
497 return pin->GetOrientation();
502 return dummy.GetOrientation();
526 bool selCancelled =
false;
527 bool displayWireCursor =
false;
528 bool displayBusCursor =
false;
529 bool displayLineCursor =
false;
530 KIID rolloverItemId = lastRolloverItemId;
534 evt->Modifier(
MD_ALT ) );
540 if( !
m_frame->ToolStackIsEmpty() )
574 schframe->ClearFocus();
581 size_t preFilterCount = collector.
GetCount();
583 narrowSelection( collector, evt->Position(),
false,
false, &rejected );
590 bool allCellsFromSameTable =
true;
602 allCellsFromSameTable =
false;
622 VECTOR2D bottomRight( std::max( start.
x,
end.x ), std::max( start.
y,
end.y ) );
645 else if( collector[0]->HasHoveredHypertext() )
647 collector[ 0 ]->DoHypertextAction(
m_frame, evt->Position() );
650 else if( collector[0]->IsBrightened() )
656 schframe->SelectNetNavigatorItem( &itemData );
663 if( collector.
GetCount() == 0 && preFilterCount > 0 )
666 frame->HighlightSelectionFilter( rejected );
681 SelectPoint( evt->Position(), { SCH_LOCATE_ANY_T },
nullptr, &selCancelled );
690 .Contains( evt->Position() ) )
694 if(
CollectHits( collector, evt->Position(), { SCH_LOCATE_ANY_T } ) )
698 SelectPoint( evt->Position(), { SCH_LOCATE_ANY_T },
nullptr, &selCancelled );
706 else if( evt->IsDblClick(
BUT_LEFT ) )
712 schframe->ClearFocus();
750 schframe->ClearFocus();
760 else if(
CollectHits( collector, evt->DragOrigin(), { SCH_TABLECELL_T } )
761 && ( collector[0]->GetParent()->GetParentGroup() ==
nullptr
762 || collector[0]->GetParent()->GetParentGroup() ==
m_enteredGroup ) )
825 else if( evt->IsMouseDown(
BUT_AUX1 ) )
829 else if( evt->IsMouseDown(
BUT_AUX2 ) )
845 const int delta = evt->Parameter<
int>();
888 wxString alt = *evt->Parameter<wxString*>();
912 newItems.push_back( nc );
915 if( !commit.
Empty() )
917 commit.
Push( wxS(
"No Connect Pins" ) );
936 switch( pinOrientation( item ) )
957 newItems.push_back( wire );
960 if( !commit.
Empty() )
978 commit.
Push( wxS(
"Wire Pins" ) );
998 labelText =
pin->GetShownName();
1000 if( labelText.IsEmpty() )
1002 labelText.Printf(
"%s_%s",
1003 pin->GetParentSymbol()->GetRef( &sheetPath ),
1009 labelText = sheetPin->
GetShownText( &sheetPath,
false );
1016 switch( *evt->GetCommandId() )
1019 label =
new SCH_LABEL( item->GetPosition(), labelText );
1022 label =
new SCH_HIERLABEL( item->GetPosition(), labelText );
1031 switch( pinOrientation( item ) )
1052 pinType =
pin->GetType();
1088 newItems.push_back( label );
1091 if( !commit.
Empty() )
1093 commit.
Push( wxS(
"Label Pins" ) );
1105 wxString* net =
new wxString( *evt->Parameter<wxString*>() );
1109 else if( evt->IsCancelInteractive() )
1119 schframe->ClearFocus();
1125 else if( evt->FirstResponder() ==
this && evt->GetCommandId() == (
int) WXK_ESCAPE )
1135 if(
editor &&
m_frame->eeconfig()->m_Input.esc_clears_net_highlight )
1136 editor->ClearHighlight( *evt );
1143 schframe->ClearFocus();
1145 else if( evt->IsMotion() && !
m_isSymbolEditor && evt->FirstResponder() ==
this )
1164 displayBusCursor =
true;
1166 displayWireCursor =
true;
1168 displayLineCursor =
true;
1170 else if( collector[0]->HasHypertext() && !collector[0]->IsSelected() )
1172 rolloverItemId = collector[0]->m_Uuid;
1179 evt->SetPassEvent();
1182 if( lastRolloverItemId !=
niluuid && lastRolloverItemId != rolloverItemId )
1191 m_frame->GetCanvas()->GetView()->Update( item );
1196 if( rolloverItemId !=
niluuid )
1198 rolloverItem =
static_cast<SCH_ITEM*
>(
m_frame->ResolveItem( rolloverItemId ) );
1205 m_frame->GetCanvas()->GetView()->Update( rolloverItem );
1208 lastRolloverItemId = rolloverItemId;
1210 if(
m_frame->ToolStackIsEmpty() )
1212 if( displayWireCursor )
1216 else if( displayBusCursor )
1220 else if( displayLineCursor )
1230 && evt->HasPosition()
1255 wxT(
"EnterGroup called when selection is not a single group" ) );
1309 if(
m_frame->eeconfig()->m_Drawing.auto_start_wires
1342 if( possibleConnection.
IsBus() )
1350 if( !
pin || !
pin->IsPointClickableAnchor( pos ) )
1353 if( !
pin->IsVisible()
1354 && !(
m_frame->eeconfig()->m_Appearance.show_hidden_pins
1355 ||
m_frame->GetRenderSettings()->m_ShowHiddenPins ) )
1361 newEvt->SetMousePosition( pos );
1362 newEvt->SetHasPosition(
true );
1363 newEvt->SetForceImmediate(
true );
1376 wxMouseState keyboardState = wxGetMouseState();
1379 keyboardState.AltDown() );
1394 wxMouseState keyboardState = wxGetMouseState();
1397 keyboardState.AltDown() );
1418 const std::vector<KICAD_T>& aScanTypes )
1421 int gridThreshold =
KiROUND(
getView()->GetGAL()->GetGridSize().EuclideanNorm() / 2.0 );
1422 aCollector.
m_Threshold = std::max( pixelThreshold, gridThreshold );
1442 int originalCount = aCollector.
GetCount();
1444 for(
int ii = 0; ii < originalCount; ++ii )
1446 if( aCollector[ii]->Type() ==
SCH_PIN_T )
1450 if( !aCollector.
HasItem(
pin->GetParentSymbol() ) )
1451 aCollector.
Append(
pin->GetParentSymbol() );
1462 bool aCheckLocked,
bool aSelectedOnly,
1467 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
1469 if( symbolEditorFrame )
1476 if( !
static_cast<SCH_FIELD*
>( item )->IsVisible()
1485 if( !
static_cast<SCH_PIN*
>( item )->IsVisible()
1500 if( aCheckLocked && collector[i]->IsLocked() )
1514 if( aSelectedOnly && !collector[i]->IsSelected() )
1530 EDA_ITEM** aItem,
bool* aSelectionCancelledFlag,
bool aAdd,
1531 bool aSubtract,
bool aExclusiveOr )
1549 if( aSelectionCancelledFlag )
1550 *aSelectionCancelledFlag =
true;
1556 if( !aAdd && !aSubtract && !aExclusiveOr )
1564 bool foundEnteredGroup =
false;
1569 foundEnteredGroup =
true;
1574 if( !foundEnteredGroup )
1581 bool anySubtracted =
false;
1585 for(
int i = 0; i < aCollector.
GetCount(); ++i )
1588 bool isLine = aCollector[i]->Type() ==
SCH_LINE_T;
1604 || ( aExclusiveOr && aCollector[i]->IsSelected()
1605 && ( !isLine || ( isLine && aCollector[i]->HasFlag( flags ) ) ) ) )
1607 aCollector[i]->ClearFlags( flags );
1617 anySubtracted =
true;
1622 aCollector[i]->SetFlags( flags );
1629 if( addedCount == 1 )
1633 if( aItem && aCollector.
GetCount() == 1 )
1634 *aItem = aCollector[0];
1638 else if( addedCount > 1 )
1643 else if( anySubtracted )
1649 m_frame->GetCanvas()->ForceRefresh();
1655 const std::vector<KICAD_T>& aScanTypes,
1656 EDA_ITEM** aItem,
bool* aSelectionCancelledFlag,
1657 bool aCheckLocked,
bool aAdd,
bool aSubtract,
1662 if( !
CollectHits( collector, aWhere, aScanTypes ) )
1665 size_t preFilterCount = collector.
GetCount();
1667 rejected.
SetAll(
false );
1668 narrowSelection( collector, aWhere, aCheckLocked, aSubtract, &rejected );
1670 if( collector.
GetCount() == 0 && preFilterCount > 0 )
1673 frame->HighlightSelectionFilter( rejected );
1678 return selectPoint( collector, aWhere, aItem, aSelectionCancelledFlag, aAdd, aSubtract,
1689 std::vector<EDA_ITEM*> sheetPins;
1695 view->
Query( selectionBox,
1703 collection.
Append( item );
1717 sheetPins.emplace_back(
pin );
1738 m_frame->GetCanvas()->ForceRefresh();
1748 std::vector<KIGFX::VIEW::LAYER_ITEM_PAIR> selectedItems;
1754 view->
Query( selectionBox, selectedItems );
1781 m_frame->GetCanvas()->ForceRefresh();
1789 std::set<EDA_ITEM*> exactHits;
1791 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
1804 if( item->
HitTest( aPos, pixelThreshold ) )
1805 exactHits.insert( item );
1814 if(
m_frame->GetRenderSettings()->m_ShowPinsElectricalType )
1817 if( item->
HitTest( aPos, 0 ) )
1818 exactHits.insert( item );
1824 if( exactHits.size() > 0 && exactHits.size() < (
unsigned) collector.
GetCount() )
1826 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
1830 if( !exactHits.contains( item ) )
1836 SEG poss( aPos, aPos );
1838 int closestDist = INT_MAX / 4;
1842 BOX2I bbox = item->GetBoundingBox();
1843 int dist = INT_MAX / 4;
1848 bool dominating =
false;
1850 if( exactHits.contains( item ) )
1888 text->GetEffectiveTextShape(
false )->Collide( poss, INT_MAX / 4, &dist );
1894 shapes->Collide( poss, INT_MAX / 4, &dist );
1908 rect.
Collide( poss, closestDist, &dist );
1926 if( dist == closestDist )
1928 if( item->GetParent() == closest )
1931 else if( dist < closestDist )
1947 for(
int i = collector.
GetCount() - 1; i >= 0; --i )
1951 if( item == closest )
1954 if( !item->
HitTest( tightBox,
true ) )
1962 bool aPromoteCellSelections,
1963 bool aPromoteGroups )
1965 bool anyUnselected =
false;
1966 bool anySelected =
false;
1979 bool isMoving =
false;
1981 for(
int i = (
int)
m_selection.GetSize() - 1; i >= 0; --i )
1984 isMoving |=
static_cast<SCH_ITEM*
>( item )->IsMoving();
1986 if( !item->
IsType( aScanTypes ) )
1989 anyUnselected =
true;
1997 if( aPromoteGroups )
1999 for(
int i = (
int)
m_selection.GetSize() - 1; i >= 0; --i )
2003 std::set<EDA_ITEM*> selectedChildren;
2009 if( aChild->
IsType( aScanTypes ) )
2010 selectedChildren.insert( aChild );
2014 anyUnselected =
true;
2017 for(
EDA_ITEM* child : selectedChildren )
2019 if( !child->IsSelected() )
2031 if( aPromoteCellSelections )
2033 std::set<EDA_ITEM*> parents;
2035 for(
int i = (
int)
m_selection.GetSize() - 1; i >= 0; --i )
2043 anyUnselected =
true;
2049 if( !parent->IsSelected() )
2072 std::set<EDA_ITEM*> rejected;
2077 rejected.insert( item );
2081 aCollector.
Remove( item );
2092 if( schItem->IsLocked() && !
m_filter.lockedItems )
2101 switch( aItem->
Type() )
2119 aRejected->
pins =
true;
2129 aRejected->
wires =
true;
2137 switch(
static_cast<SCH_LINE*
>( aItem )->GetLayer() )
2144 aRejected->
wires =
true;
2180 aRejected->
text =
true;
2192 aRejected->
labels =
true;
2202 aRejected->
images =
true;
2282 bool cancelled =
false;
2298 isGreedy = !isGreedy;
2303 if( evt->IsCancelInteractive() || evt->IsActivate() )
2316 area.
SetEnd( evt->Position() );
2333 evt->SetPassEvent(
false );
2355 bool cancelled =
false;
2371 bool isClockwise = shapeArea > 0 ? true :
false;
2373 if(
getView()->IsMirroredX() && shapeArea != 0 )
2374 isClockwise = !isClockwise;
2387 if( evt->IsCancelInteractive() || evt->IsActivate() )
2396 points.
Append( evt->Position() );
2398 else if( evt->IsDblClick(
BUT_LEFT )
2437 area.
SetMode( selectionMode );
2464 std::vector<KIGFX::VIEW::LAYER_ITEM_PAIR> candidates;
2466 view->
Query( selectionRect, candidates );
2468 std::set<SCH_ITEM*> uniqueCandidates;
2470 for(
const auto& [viewItem, layer] : candidates )
2472 if( viewItem->IsSCH_ITEM() )
2473 uniqueCandidates.insert(
static_cast<SCH_ITEM*
>( viewItem ) );
2482 if( boxMode ? selectionRect.
Intersects(
pin->GetBoundingBox() )
2484 uniqueCandidates.insert(
pin );
2491 if( boxMode ? selectionRect.
Intersects(
pin->GetBoundingBox() )
2493 uniqueCandidates.insert(
pin );
2498 if( field.IsVisible()
2499 && ( boxMode ? selectionRect.
Intersects( field.GetBoundingBox() )
2502 uniqueCandidates.insert( &field );
2510 std::set<EDA_ITEM*> group_items;
2519 std::unordered_set<EDA_ITEM*>& newset =
group->GetItems();
2522 [&](
const BOX2I& aBox )
2524 return boxMode ? selectionRect.
Contains( aBox )
2528 if( containedMode && boxContained(
group->GetBoundingBox() ) && newset.size() )
2530 for(
EDA_ITEM* group_item : newset )
2532 if( !group_item->IsSCH_ITEM() )
2536 collector.
Append( group_item );
2540 for(
EDA_ITEM* group_item : newset )
2541 group_items.emplace( group_item );
2547 return boxMode ? aItem->HitTest( selectionRect, containedMode )
2548 : aItem->HitTest( aArea.
GetPoly(), containedMode );
2551 for(
SCH_ITEM* item : uniqueCandidates )
2554 && ( !containedMode || !group_items.count( item ) ) )
2557 pinsCollector.
Append( item );
2559 collector.
Append( item );
2568 collector = pinsCollector;
2573 std::sort( collector.
begin(), collector.
end(),
2576 VECTOR2I aPos = a->GetPosition();
2577 VECTOR2I bPos = b->GetPosition();
2579 if( aPos.y == bPos.y )
2580 return aPos.x < bPos.x;
2582 return aPos.y < bPos.y;
2585 bool anyAdded =
false;
2586 bool anySubtracted =
false;
2591 if( aSubtractive || ( aExclusiveOr && aItem->
IsSelected() ) )
2601 anySubtracted =
true;
2604 if( flags && !anySubtracted )
2615 std::vector<EDA_ITEM*> flaggedItems;
2617 auto shapeContains =
2620 return boxMode ? selectionRect.
Contains( aPoint )
2629 flaggedItems.push_back( item );
2631 if(
m_frame->GetRenderSettings()->m_ShowPinsElectricalType )
2640 hits = line->
HitTest( selectionRect,
false );
2644 if( ( !containedMode && hits )
2649 else if( containedMode )
2659 selectItem( item, flags );
2662 selectItem( item, flags );
2667 for(
EDA_ITEM* item : pinsCollector )
2669 if(
m_frame->GetRenderSettings()->m_ShowPinsElectricalType )
2686 selectItem( item, 0 );
2692 for(
EDA_ITEM* item : flaggedItems )
2699 else if( anySubtracted )
2705 bool aMultiselect )
const
2707 std::unordered_set<EDA_ITEM*> toAdd;
2711 for(
int j = 0; j < aCollector.
GetCount(); j++ )
2713 if( aCollector[j]->GetParent() )
2716 if( aCollector[j]->GetParentSymbol() )
2722 for(
int j = 0; j < aCollector.
GetCount(); j++ )
2726 for(
int j = 0; j < aCollector.
GetCount(); )
2738 aCollector.
Remove( item );
2746 if(
top->AsEdaItem() != item )
2748 toAdd.insert(
top->AsEdaItem() );
2751 aCollector.
Remove( item );
2760 aCollector.
Remove( item );
2769 if( !aCollector.
HasItem( item ) )
2770 aCollector.
Append( item );
2780 std::vector<EDA_ITEM*> toRemove;
2786 bool lockedDescendant =
false;
2788 schItem->RunOnChildren(
2792 lockedDescendant =
true;
2796 if( schItem->IsLocked() || lockedDescendant )
2797 toRemove.push_back( item );
2819 if( cell->IsSelected() )
2831 auto wasSelected = [](
EDA_ITEM* aItem )
2838 bool doSelect =
false;
2840 if( cell->HitTest( selectionRect,
false ) )
2845 doSelect = !wasSelected( cell );
2849 else if( wasSelected( cell ) )
2854 if( doSelect && !cell->IsSelected() )
2856 else if( !doSelect && cell->IsSelected() )
2863 bool cancelled =
false;
2870 if( evt->IsCancelInteractive() || evt->IsActivate() )
2878 SelectCellsBetween( evt->DragOrigin(), evt->Position() - evt->DragOrigin(), aTable );
2880 else if( evt->IsMouseUp(
BUT_LEFT ) )
2884 bool anyAdded =
false;
2885 bool anySubtracted =
false;
2892 anySubtracted =
true;
2908 evt->SetPassEvent();
2932 int gridThreshold =
KiROUND(
getView()->GetGAL()->GetGridSize().EuclideanNorm() );
2933 int thresholdMax = std::max( pixelThreshold, gridThreshold );
2935 for(
int threshold : { 0, thresholdMax/4, thresholdMax/2, thresholdMax } )
2944 return collector.
GetCount() ? collector[ 0 ] :
nullptr;
2970 std::vector<SCH_ITEM*> startItems;
2971 std::set<SCH_ITEM*> added;
2974 for(
auto item : aItems )
2976 if( !item->IsSCH_ITEM() )
2987 startItems.push_back(
pin );
2992 startItems.push_back( schItem );
2996 if( startItems.empty() )
2999 std::deque<SCH_ITEM*> queue;
3000 std::unordered_set<SCH_ITEM*> visited;
3002 auto enqueue = [&](
SCH_ITEM* aItem )
3007 if( visited.insert( aItem ).second )
3008 queue.push_back( aItem );
3014 while( !queue.empty() )
3024 added.insert( symbol );
3029 for(
SCH_ITEM* neighbor : neighbors )
3039 added.insert( symbol );
3044 enqueue( neighbor );
3050 added.insert( item );
3059 std::set<SCH_ITEM*> added;
3061 for(
auto item : aItems )
3063 if( !item->IsSCH_ITEM() )
3068 std::set<SCH_ITEM*> conns =
m_frame->GetScreen()->MarkConnections( schItem, schItem->
IsConnectable() );
3076 added.insert( connItem );
3099 if( !selItem->IsSCH_ITEM() )
3105 graphicalSelection.
Add( item );
3107 graphicalSelection.
Add( item );
3109 connectableSelection.
Add( item );
3114 std::set<SCH_ITEM*> graphAdded;
3115 std::set<SCH_ITEM*> graphicalAdded;
3117 if( !connectableSelection.
Empty() )
3120 if( !graphicalSelection.
Empty() )
3125 if( graphAdded.empty() && !connectableSelection.
Empty() )
3130 combinedSelection.
Add( selItem );
3132 graphicalSelection = combinedSelection;
3137 auto smartAddToSel = [&](
EDA_ITEM* aItem )
3146 for(
auto item : graphAdded )
3147 smartAddToSel( item );
3149 for(
auto item : graphicalAdded )
3150 smartAddToSel( item );
3152 for(
auto item : originalSelection )
3153 smartAddToSel( item );
3172 std::set<std::pair<SCH_TABLE*, int>> columns;
3180 columns.insert( std::make_pair(
table, cell->GetColumn() ) );
3184 for(
auto& [
table, col ] : columns )
3186 for(
int row = 0; row <
table->GetRowCount(); ++row )
3207 std::set<std::pair<SCH_TABLE*, int>> rows;
3215 rows.insert( std::make_pair(
table, cell->GetRow() ) );
3219 for(
auto& [
table, row ] : rows )
3221 for(
int col = 0; col <
table->GetColCount(); ++col )
3242 std::set<SCH_TABLE*> tables;
3248 tables.insert(
static_cast<SCH_TABLE*
>( cell->GetParent() ) );
3255 if( !
table->IsSelected() )
3298 double compRatio = bbSize.
y / currTextHeight;
3299 double compRatioBent = 1.0;
3305 std::vector<std::pair<double, double>> lut{ { 1.25, 16 },
3314 std::vector<std::pair<double, double>>::iterator it;
3317 compRatioBent = lut.back().second;
3321 if( compRatio >= lut.front().first )
3323 for( it = lut.begin(); it < lut.end() - 1; ++it )
3325 if( it->first <= compRatio &&
next( it )->first >= compRatio )
3327 double diffx = compRatio - it->first;
3328 double diffn =
next( it )->first - it->first;
3330 compRatioBent = it->second + (
next( it )->second - it->second ) * diffx / diffn;
3337 compRatioBent = lut.front().second;
3346 screenSize.
x = std::max( 10.0, screenSize.
x );
3347 screenSize.
y = std::max( 10.0, screenSize.
y );
3348 double ratio = std::max( -1.0, fabs( bbSize.
y / screenSize.
y ) );
3351 double kicadRatio = std::max( fabs( bbSize.
x / screenSize.
x ),
3352 fabs( bbSize.
y / screenSize.
y ) );
3357 if( bbSize.
x > screenSize.
x * ratio * compRatioBent )
3361 compRatioBent = 1.0;
3362 wxLogTrace(
"CROSS_PROBE_SCALE",
3363 "Part TOO WIDE for screen. Using normal KiCad zoom ratio: %1.5f", ratio );
3368 ratio *= compRatioBent;
3370 bool alwaysZoom =
false;
3373 if( ( ratio < 0.5 || ratio > 1.0 ) || alwaysZoom )
3379 SCH_ITEM* focusItem,
const std::vector<SCH_ITEM*>& items )
3386 double targetZoom = 0.0;
3388 bool targetZoomValid =
false;
3389 bool changedSheet =
false;
3391 if( targetSheetPath )
3397 targetZoom = screen->m_LastZoomLevel;
3398 targetCenter = screen->m_ScrollCenter;
3399 targetZoomValid = screen->IsZoomInitialized();
3405 changedSheet =
true;
3409 if( changedSheet && targetZoomValid && !
m_frame->eeconfig()->m_CrossProbing.zoom_to_fit )
3423 if(
m_frame->GetScreen()->CheckIfOnDrawList( item )
3424 || ( parent &&
m_frame->GetScreen()->CheckIfOnDrawList( parent ) ) )
3434 if(
m_frame->eeconfig()->m_CrossProbing.center_on_items )
3436 if(
m_frame->eeconfig()->m_CrossProbing.zoom_to_fit )
3455 bool enteredGroupFound =
false;
3463 if( item.IsSelected() )
3471 enteredGroupFound =
true;
3485 if( item->IsSelected() )
3491 item->RunOnChildren(
3505 enteredGroupFound =
true;
3517 if( !enteredGroupFound )
3529 bool checkVisibilityOnly )
const
3540 switch( aItem->
Type() )
3548 if(
pin->GetUnit() &&
pin->GetUnit() != symEditFrame->
GetUnit() )
3555 if( !
pin->IsVisible() && !
m_frame->GetShowAllPins() )
3566 if(
pin->IsPointClickableAnchor(
grid.BestSnapAnchor( *aPos, pinGrid ) ) )
3577 if( !
m_frame->eeconfig()->m_Appearance.show_directive_labels )
3682 aGroup->
Add( aItem );
3692 sch_item->RunOnChildren(
3743 sch_item->RunOnChildren(
3757 aGroup->
Remove( aChild );
3771 const unsigned GRIP_MARGIN = 20;
3777 BOX2I itemBox = item->ViewBBox();
constexpr EDA_IU_SCALE schIUScale
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
static TOOL_ACTION unselectAll
static TOOL_ACTION selectItem
Select an item (specified as the event parameter).
static TOOL_ACTION cursorLeft
static TOOL_ACTION zoomOutCenter
static TOOL_ACTION unselectItem
static TOOL_ACTION zoomIn
static TOOL_ACTION cursorLeftFast
static TOOL_ACTION selectSetLasso
static TOOL_ACTION selectSetRect
Set lasso selection mode.
static TOOL_ACTION groupEnter
static TOOL_ACTION selectColumns
static TOOL_ACTION cursorDown
static TOOL_ACTION zoomOut
static TOOL_ACTION cursorRightFast
static TOOL_ACTION zoomCenter
static TOOL_ACTION panDown
static TOOL_ACTION cursorDblClick
static TOOL_ACTION selectionActivate
Activation of the selection tool.
static TOOL_ACTION cursorDownFast
static TOOL_ACTION selectionMenu
Run a selection menu to select from a list of items.
static TOOL_ACTION selectRows
static TOOL_ACTION cursorUpFast
static TOOL_ACTION panLeft
static TOOL_ACTION updateMenu
static TOOL_ACTION doDelete
static TOOL_ACTION selectionTool
static TOOL_ACTION cursorClick
static TOOL_ACTION zoomFitScreen
static TOOL_ACTION increment
static TOOL_ACTION selectionClear
Clear the current selection.
static TOOL_ACTION zoomFitObjects
static TOOL_ACTION zoomInCenter
static TOOL_ACTION panRight
static TOOL_ACTION selectTable
static TOOL_ACTION cursorUp
Cursor control with keyboard.
static TOOL_ACTION groupLeave
static TOOL_ACTION finishInteractive
static TOOL_ACTION cursorRight
static TOOL_ACTION selectAll
static TOOL_ACTION unselectItems
static TOOL_ACTION selectItems
Select a list of items (specified as the event parameter)
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
constexpr const Vec & GetPosition() const
constexpr void SetMaximum()
constexpr BOX2< Vec > & Inflate(coord_type dx, coord_type dy)
Inflates the rectangle horizontally by dx and vertically by dy.
constexpr BOX2< Vec > & Normalize()
Ensure that the height and width are positive.
constexpr size_type GetWidth() const
constexpr Vec Centre() const
constexpr const Vec GetCenter() const
constexpr size_type GetHeight() const
constexpr bool Contains(const Vec &aPoint) const
constexpr const SizeVec & GetSize() const
constexpr bool Intersects(const BOX2< Vec > &aRect) const
An abstract class that will find and hold all the objects according to an inspection done by the Insp...
void Transfer(int aIndex)
Move the item at aIndex (first position is 0) to the backup list.
int GetCount() const
Return the number of objects in the list.
bool HasItem(const EDA_ITEM *aItem) const
Tests if aItem has already been collected.
void Remove(int aIndex)
Remove the item at aIndex (first position is 0).
void Append(EDA_ITEM *item)
Add an item to the end of the list.
COMMIT & Added(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
Notify observers that aItem has been added.
COMMIT & Add(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
Add a new item to the model.
Calculate the connectivity of a schematic and generates netlists.
bool IsHorizontal() const
void FocusOnLocation(const VECTOR2I &aPos, bool aAllowScroll=true)
Useful to focus on a particular location, in find functions.
A set of EDA_ITEMs (i.e., without duplicates).
A base class for most all the KiCad significant classes used in schematics and boards.
virtual VECTOR2I GetPosition() const
void SetIsRollover(bool aIsRollover, const VECTOR2I &aMousePos)
virtual const BOX2I GetBoundingBox() const
Return the orthogonal bounding box of this object for display purposes.
void SetFlags(EDA_ITEM_FLAGS aMask)
KICAD_T Type() const
Returns the type of object.
void ClearFlags(EDA_ITEM_FLAGS aMask=EDA_ITEM_ALL_FLAGS)
virtual bool IsType(const std::vector< KICAD_T > &aScanTypes) const
Check whether the item is one of the listed types.
virtual bool HitTest(const VECTOR2I &aPosition, int aAccuracy=0) const
Test if aPosition is inside or on the boundary of this item.
EDA_ITEM * GetParent() const
bool HasFlag(EDA_ITEM_FLAGS aFlag) const
void XorFlags(EDA_ITEM_FLAGS aMask)
EDA_ITEM_FLAGS GetFlags() const
virtual bool IsFilledForHitTesting() const
virtual std::vector< SHAPE * > MakeEffectiveShapesForHitTesting() const
A mix-in class (via multiple inheritance) that handles texts such as labels, parts,...
const EDA_ANGLE & GetTextAngle() const
virtual bool IsVisible() const
std::shared_ptr< SHAPE_COMPOUND > GetEffectiveTextShape(bool aTriangulate=true, const BOX2I &aBBox=BOX2I(), const EDA_ANGLE &aAngle=ANGLE_0) const
build a list of segments (SHAPE_SEGMENT) to describe a text shape.
GRID_HELPER_GRIDS GetItemGrid(const EDA_ITEM *aItem) const override
Get the coarsest grid that applies to an item.
VECTOR2I BestSnapAnchor(const VECTOR2I &aOrigin, GRID_HELPER_GRIDS aGrid, SCH_ITEM *aSkip)
static const TOOL_EVENT DisambiguatePoint
Used for hotkey feedback.
static const TOOL_EVENT ClearedEvent
static const TOOL_EVENT SelectedEvent
static const TOOL_EVENT SelectedItemsModified
Selected items were moved, this can be very high frequency on the canvas, use with care.
static const TOOL_EVENT PointSelectedEvent
static const TOOL_EVENT SelectedItemsMoved
Used to inform tools that the selection should temporarily be non-editable.
static const TOOL_EVENT UnselectedEvent
virtual RENDER_SETTINGS * GetSettings()=0
Return a pointer to current settings that are going to be used when drawing items.
Represent a selection area (currently a rectangle) in a VIEW, drawn corner-to-corner between two poin...
VECTOR2I GetOrigin() const
void SetMode(SELECTION_MODE aMode)
void SetSubtractive(bool aSubtractive)
SELECTION_MODE GetMode() const
void SetAdditive(bool aAdditive)
void SetPoly(SHAPE_LINE_CHAIN &aPoly)
void SetOrigin(const VECTOR2I &aOrigin)
const BOX2I ViewBBox() const override
Set the origin of the rectangle (the fixed corner)
SHAPE_LINE_CHAIN & GetPoly()
void SetExclusiveOr(bool aExclusiveOr)
void SetEnd(const VECTOR2I &aEnd)
Set the current end of the rectangle (the corner that moves with the cursor.
void SetHighlight(bool aEnabled, int aNetcode=-1, bool aMulti=false)
Turns on/off highlighting.
An interface for classes handling user events controlling the view behavior such as zooming,...
virtual void CaptureCursor(bool aEnabled)
Force the cursor to stay within the drawing panel area.
virtual void ForceCursorPosition(bool aEnabled, const VECTOR2D &aPosition=VECTOR2D(0, 0))
Place the cursor immediately at a given point.
virtual void WarpMouseCursor(const VECTOR2D &aPosition, bool aWorldCoordinates=false, bool aWarpView=false)=0
If enabled (.
virtual void SetCrossHairCursorPosition(const VECTOR2D &aPosition, bool aWarpView=true)=0
Move the graphic crosshair cursor to the requested position expressed in world coordinates.
VECTOR2D GetCursorPosition() const
Return the current cursor position in world coordinates.
virtual void SetCursorPosition(const VECTOR2D &aPosition, bool aWarpView=true, bool aTriggeredByArrows=false, long aArrowCommand=0)=0
Move cursor to the requested position expressed in world coordinates.
virtual void SetAutoPan(bool aEnabled)
Turn on/off auto panning (this feature is used when there is a tool active (eg.
An abstract base class for deriving all objects that can be added to a VIEW.
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
BOX2D GetViewport() const
Return the current viewport visible area rectangle.
virtual void SetScale(double aScale, VECTOR2D aAnchor={ 0, 0 })
Set the scaling factor, zooming around a given anchor point.
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1)
Add a VIEW_ITEM to the view.
virtual void Remove(VIEW_ITEM *aItem)
Remove a VIEW_ITEM from the view.
int Query(const BOX2I &aRect, std::vector< LAYER_ITEM_PAIR > &aResult) const
Find all visible items that touch or are within the rectangle aRect.
virtual void Update(const VIEW_ITEM *aItem, int aUpdateFlags) const
For dynamic VIEWs, inform the associated VIEW that the graphical representation of this item has chan...
bool IsMirroredX() const
Return true if view is flipped across the X axis.
std::pair< VIEW_ITEM *, int > LAYER_ITEM_PAIR
void Hide(VIEW_ITEM *aItem, bool aHide=true, bool aHideOverlay=false)
Temporarily hide the item in the view (e.g.
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
void SetCenter(const VECTOR2D &aCenter)
Set the center point of the VIEW (i.e.
void SetVisible(VIEW_ITEM *aItem, bool aIsVisible=true)
Set the item visibility.
Define a library symbol object.
bool IsPower() const override
bool IsMultiBodyStyle() const override
LIB_ITEMS_CONTAINER & GetDrawItems()
Return a reference to the draw item list.
int GetUnitCount() const override
Tree view item data for the net navigator.
CONNECTION_GRAPH * ConnectionGraph() const
SCH_SHEET_PATH & CurrentSheet() const
static TOOL_ACTION placeClassLabel
static TOOL_ACTION placeSheetPin
static TOOL_ACTION placeNextSymbolUnit
static TOOL_ACTION swapPins
static TOOL_ACTION saveToLinkedDesignBlock
static TOOL_ACTION clearHighlight
static TOOL_ACTION placeGlobalLabel
static TOOL_ACTION pinTable
static TOOL_ACTION navigateBack
static TOOL_ACTION properties
static TOOL_ACTION leaveSheet
static TOOL_ACTION breakWire
static TOOL_ACTION findNetInInspector
static TOOL_ACTION autoplaceAllSheetPins
static TOOL_ACTION drawLines
static TOOL_ACTION placeHierLabel
static TOOL_ACTION selectConnection
If current selection is a wire or bus, expand to entire connection.
static TOOL_ACTION placeLabel
static TOOL_ACTION nextNetItem
static TOOL_ACTION drawWire
static TOOL_ACTION placeJunction
static TOOL_ACTION previousNetItem
static TOOL_ACTION swapUnitLabels
static TOOL_ACTION navigateForward
static TOOL_ACTION placeLinkedDesignBlock
static TOOL_ACTION selectNode
Select the junction, wire or bus segment under the cursor.
static TOOL_ACTION unfoldBus
static TOOL_ACTION drawBus
static TOOL_ACTION symbolProperties
static TOOL_ACTION changeSheet
static TOOL_ACTION assignNetclass
static TOOL_ACTION swapPinLabels
static TOOL_ACTION enterSheet
static TOOL_ACTION editPageNumber
static TOOL_ACTION selectOnPCB
static TOOL_ACTION syncSheetPins
A shim class between EDA_DRAW_FRAME and several derived classes: SYMBOL_EDIT_FRAME,...
Class for a wire to bus entry.
SCH_ITEM * m_connected_bus_item
Pointer to the bus item (usually a bus wire) connected to this bus-wire entry, if it is connected to ...
void Collect(SCH_SCREEN *aScreen, const std::vector< KICAD_T > &aScanTypes, const VECTOR2I &aPos, int aUnit=0, int aBodyStyle=0)
Scan a EDA_ITEM using this class's Inspector method which does the collection.
bool m_ShowPinElectricalTypes
static const std::vector< KICAD_T > MovableItems
virtual void Push(const wxString &aMessage=wxT("A commit"), int aCommitFlags=0) override
Execute the changes.
virtual void Revert() override
Revert the commit by restoring the modified items state.
static SELECTION_CONDITION SingleMultiFunctionPin
static SELECTION_CONDITION SingleSymbol
static SELECTION_CONDITION MultipleSymbolsOrPower
static SELECTION_CONDITION HasLockedItems
static SELECTION_CONDITION AllPinsOrSheetPins
static SELECTION_CONDITION SingleSymbolOrPower
static SELECTION_CONDITION HasUnlockedItems
static SELECTION_CONDITION SingleNonExcludedMarker
static SELECTION_CONDITION SingleMultiUnitSymbol
static SELECTION_CONDITION SingleMultiBodyStyleSymbol
static SELECTION_CONDITION AllPins
Each graphical item can have a SCH_CONNECTION describing its logical connection (to a bus or net).
void ConfigureFromLabel(const wxString &aLabel)
Configures the connection given a label.
Handle actions specific to the schematic editor.
Schematic editor (Eeschema) main window.
void FocusOnItem(EDA_ITEM *aItem, bool aAllowScroll=true) override
Focus on a particular canvas item.
SCH_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
SCH_SHEET_PATH & GetCurrentSheet() const
SCHEMATIC & Schematic() const
const SCH_ITEM * SelectNextPrevNetNavigatorItem(bool aNext)
const wxString & GetHighlightedConnection() const
wxGenericTreeCtrl * GetNetNavigator()
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
A set of SCH_ITEMs (i.e., without duplicates).
static bool WithinScope(SCH_ITEM *aItem, SCH_GROUP *aScope, bool isSymbolEditor)
static EDA_GROUP * TopLevelGroup(SCH_ITEM *aItem, EDA_GROUP *aScope, bool isSymbolEditor)
Base class for any item which can be embedded within the SCHEMATIC container class,...
virtual bool IsConnectable() const
virtual bool HasHoveredHypertext() const
Indicates that a hypertext link is currently active.
const SCH_ITEM_VEC & ConnectedItems(const SCH_SHEET_PATH &aPath)
Retrieve the set of items connected to this item on the given sheet.
const SYMBOL * GetParentSymbol() const
SCHEMATIC * Schematic() const
Search the item hierarchy to find a SCHEMATIC.
virtual bool IsPointClickableAnchor(const VECTOR2I &aPos) const
bool IsLocked() const override
bool IsType(const std::vector< KICAD_T > &aScanTypes) const override
Check whether the item is one of the listed types.
wxString GetShownText(const SCH_SHEET_PATH *aPath, bool aAllowExtraText, int aDepth=0) const override
void SetShape(LABEL_FLAG_SHAPE aShape)
LABEL_SHAPE GetLabelShape() const
virtual void SetSpinStyle(SPIN_STYLE aSpinStyle)
Segment description base class to describe items which have 2 end points (track, wire,...
bool HitTest(const VECTOR2I &aPosition, int aAccuracy=0) const override
Test if aPosition is inside or on the boundary of this item.
bool IsStartDangling() const
VECTOR2I GetEndPoint() const
VECTOR2I GetStartPoint() const
SEG GetSeg() const
Get the geometric aspect of the wire as a SEG.
bool IsEndDangling() const
bool IsBus() const
Return true if the line is a bus.
bool IsGraphicLine() const
Return if the line is a graphic (non electrical line)
void SetEndPoint(const VECTOR2I &aPosition)
Tool that displays edit points allowing to modify items by dragging the points.
bool HasPoint()
Indicate the cursor is over an edit point.
VECTOR2I GetCenter() const
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
SCH_SHEET * Last() const
Return a pointer to the last SCH_SHEET of the list.
Define a sheet pin (label) used in sheets to create hierarchical schematics.
SHEET_SIDE GetSide() const
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
std::vector< SCH_SHEET_PIN * > & GetPins()
std::vector< const SCH_PIN * > GetPins(const SCH_SHEET_PATH *aSheet) const
Retrieve a list of the SCH_PINs for the given sheet path.
void GetFields(std::vector< SCH_FIELD * > &aVector, bool aVisibleOnly) const override
Populate a std::vector with SCH_FIELDs, sorted in ordinal order.
SCH_PIN * GetPin(const wxString &number) const
Find a symbol pin by number.
int GetOrientation() const override
Get the display symbol orientation.
std::unique_ptr< LIB_SYMBOL > & GetLibSymbolRef()
BOX2I GetBodyBoundingBox() const override
Return a bounding box for the symbol body but not the pins or fields.
std::vector< SCH_TABLECELL * > GetCells() const
int Distance(const SEG &aSeg) const
Compute minimum Euclidean distance to segment aSeg.
static SELECTION_CONDITION HasTypes(std::vector< KICAD_T > aTypes)
Create a functor that tests if among the selected items there is at least one of a given types.
static SELECTION_CONDITION HasType(KICAD_T aType)
Create a functor that tests if among the selected items there is at least one of a given type.
static bool Empty(const SELECTION &aSelection)
Test if there are no items selected.
static SELECTION_CONDITION MoreThan(int aNumber)
Create a functor that tests if the number of selected items is greater than the value given as parame...
static bool Idle(const SELECTION &aSelection)
Test if there no items selected or being edited.
static SELECTION_CONDITION LessThan(int aNumber)
Create a functor that tests if the number of selected items is smaller than the value given as parame...
static SELECTION_CONDITION Count(int aNumber)
Create a functor that tests if the number of selected items is equal to the value given as parameter.
static SELECTION_CONDITION OnlyTypes(std::vector< KICAD_T > aTypes)
Create a functor that tests if the selected items are only of given types.
virtual void Add(EDA_ITEM *aItem)
const std::deque< EDA_ITEM * > GetItems() const
VECTOR2I GetReferencePoint() const
virtual void Remove(EDA_ITEM *aItem)
bool Empty() const
Checks if there is anything selected.
bool HasReferencePoint() const
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
void GenerateBBoxCache() const
void SetClosed(bool aClosed)
Mark the line chain as closed (i.e.
int PointCount() const
Return the number of points (vertices) in this line chain.
double Area(bool aAbsolute=true) const
Return the area of this chain.
virtual size_t GetPointCount() const override
void Append(int aX, int aY, bool aAllowDuplication=false)
Append a new point at the end of the line chain.
const VECTOR2I & CLastPoint() const
Return the last point in the line chain.
void Remove(int aStartIndex, int aEndIndex)
Remove the range of points [start_index, end_index] from the line chain.
bool PointInside(const VECTOR2I &aPt, int aAccuracy=0, bool aUseBBoxCache=false) const override
Check if point aP lies inside a closed shape.
bool Collide(const SHAPE *aShape, int aClearance, VECTOR2I *aMTV) const override
Check if the boundary of shape (this) lies closer to the shape aShape than aClearance,...
The symbol library editor main window.
bool GetShowInvisibleFields()
bool IsSymbolAlias() const
Return true if aLibId is an alias for the editor screen symbol.
bool GetShowInvisiblePins()
Symbol library viewer main window.
A base class for LIB_SYMBOL and SCH_SYMBOL.
const TRANSFORM & GetTransform() const
double Distance(const VECTOR2< extended_type > &aVector) const
Compute the distance between two vectors.
#define DEFAULT_TEXT_SIZE
Ratio of the font height to the baseline of the text above the wire.
static constexpr EDA_ANGLE ANGLE_VERTICAL
static constexpr EDA_ANGLE ANGLE_HORIZONTAL
#define BRIGHTENED
item is drawn with a bright contour
#define IS_NEW
New item, just created.
#define SELECTED
Item was manually selected by the user.
#define SELECTION_CANDIDATE
indicates an item is a candidate for selection
#define ENTERED
indicates a group has been entered
#define ENDPOINT
ends. (Used to support dragging.)
std::uint32_t EDA_ITEM_FLAGS
#define IS_MOVING
Item being moved.
#define SHOW_ELEC_TYPE
Show pin electrical type.
#define STARTPOINT
When a line is selected, these flags indicate which.
@ ID_POPUP_SCH_PIN_TRICKS_START
@ ID_POPUP_SCH_PIN_TRICKS_HIER_LABEL
@ ID_POPUP_SCH_PIN_TRICKS_WIRE
@ ID_POPUP_SCH_PLACE_UNIT_END
@ ID_POPUP_SCH_ALT_PIN_FUNCTION
@ ID_POPUP_SCH_UNFOLD_BUS_END
@ ID_POPUP_SCH_SELECT_UNIT
@ ID_POPUP_SCH_SELECT_BODY_STYLE
@ ID_POPUP_SCH_PIN_TRICKS_NET_LABEL
@ ID_POPUP_SCH_SELECT_BODY_STYLE_END
@ ID_POPUP_SCH_PIN_TRICKS_NO_CONNECT
@ ID_POPUP_SCH_UNFOLD_BUS
@ ID_POPUP_SCH_SELECT_UNIT_END
@ ID_POPUP_SCH_ALT_PIN_FUNCTION_END
@ ID_POPUP_SCH_PLACE_UNIT
@ ID_POPUP_SCH_PIN_TRICKS_GLOBAL_LABEL
@ ID_POPUP_SCH_PIN_TRICKS_END
a few functions useful in geometry calculations.
bool BoxHitTest(const VECTOR2I &aHitPoint, const BOX2I &aHittee, int aAccuracy)
Perform a point-to-box hit test.
@ REPAINT
Item needs to be redrawn.
ELECTRICAL_PINTYPE
The symbol library pin object electrical types used in ERC tests.
@ PT_INPUT
usual pin input: must be connected
@ PT_TRISTATE
tri state bus pin
@ PT_BIDI
input or output (like port for a microprocessor)
@ PT_UNSPECIFIED
unknown electrical properties: creates always a warning when connected
@ PT_PASSIVE
pin for passive symbols: must be connected, and can be connected to any pin.
@ PIN_UP
The pin extends upwards from the connection point: Probably on the bottom side of the symbol.
@ PIN_RIGHT
The pin extends rightwards from the connection point.
@ PIN_LEFT
The pin extends leftwards from the connection point: Probably on the right side of the symbol.
@ PIN_DOWN
The pin extends downwards from the connection: Probably on the top side of the symbol.
#define HITTEST_THRESHOLD_PIXELS
Class to handle a set of SCH_ITEMs.
std::vector< SCH_ITEM * > SCH_ITEM_VEC
std::vector< EDA_ITEM * > EDA_ITEMS
std::function< bool(const SELECTION &)> SELECTION_CONDITION
Functor type that checks a specific condition for selected items.
std::vector< FAB_LAYER_COLOR > dummy
bool text
Text and fields.
bool symbols
Allow selecting symbols and sheet symbols.
bool labels
Net and bus labels.
bool pins
Symbol and sheet pins.
bool graphics
Graphic lines, shapes, polygons.
bool lockedItems
Allow selecting locked items.
bool images
Bitmap/vector images.
bool otherItems
Anything not fitting one of the above categories.
bool ruleAreas
Rule areas.
bool wires
Net and bus wires and junctions.
KIBIS top(path, &reporter)
std::vector< std::vector< std::string > > table
@ NOT_USED
the 3d code uses this value
@ SCH_ITEM_LOCATE_GRAPHIC_LINE_T
@ SCH_SYMBOL_LOCATE_POWER_T
VECTOR2< int32_t > VECTOR2I
VECTOR2< double > VECTOR2D