45#include <unordered_set>
60 std::set<const LIB_SYMBOL*> visited;
61 visited.insert( aSymbol );
63 std::shared_ptr<LIB_SYMBOL> current = aSymbol->
SharedPtr();
64 std::shared_ptr<LIB_SYMBOL> parent = aSymbol->
GetParent().lock();
68 if( visited.count( parent.get() ) )
76 chain += wxT(
" -> " ) + sym->GetName();
79 chain += wxT(
" -> " ) + parent->GetName() + wxT(
" (CYCLE)" );
82 wxT(
"%s: Circular inheritance detected in symbol '%s' (lib: %s). Chain: %s" ),
92 visited.insert( parent.get() );
94 parent = parent->GetParent().lock();
114 if( root.get() !=
this )
115 shownText = root->GetDescriptionField().GetShownText(
false, 0 );
141 std::function<bool( wxString* )> libSymbolResolver = [&]( wxString* token ) ->
bool
170 wxStringTokenizer keywordTokenizer(
GetShownKeyWords(),
" \t\r\n", wxTOKEN_STRTOK );
172 while( keywordTokenizer.HasMoreTokens() )
181 if( !footprint.IsEmpty() )
206 const wxString localizedKeywords =
_(
"Keywords" );
239 auto addField = [&](
FIELD_T id,
bool visible )
301 wxFAIL_MSG(
"Failed to clone SCH_ITEM." );
316 if( &aSymbol ==
this )
397 std::set<const LIB_SYMBOL*> visited;
398 visited.insert(
this );
400 std::shared_ptr<LIB_SYMBOL> parent =
m_parent.lock();
405 if( visited.count( parent.get() ) )
408 wxT(
"GetInheritanceDepth: Circular inheritance detected in symbol '%s' "
414 visited.insert( parent.get() );
416 parent = parent->m_parent.lock();
425 std::set<const LIB_SYMBOL*> visited;
426 visited.insert(
this );
428 std::shared_ptr<LIB_SYMBOL> current =
m_me;
429 std::shared_ptr<LIB_SYMBOL> parent =
m_parent.lock();
434 if( visited.count( parent.get() ) )
437 wxT(
"GetRootSymbol: Circular inheritance detected in symbol '%s' "
443 visited.insert( parent.get() );
445 parent = parent->m_parent.lock();
468 return aLabel ?
_(
"Alternate" ) : wxString(
_HKI(
"Alternate" ) );
470 return aLabel ?
_(
"Standard" ) : wxString(
_HKI(
"Standard" ) );
485 m_libId.SetLibItemName( aName );
511 std::set<const LIB_SYMBOL*> visited;
512 visited.insert(
this );
514 std::shared_ptr<LIB_SYMBOL> ancestor = aParent->
SharedPtr();
518 if( visited.count( ancestor.get() ) )
521 wxT(
"SetParent: Rejecting parent '%s' for symbol '%s' - would create "
522 "circular inheritance (lib: %s)" ),
529 visited.insert( ancestor.get() );
530 ancestor = ancestor->m_parent.lock();
545 return wxEmptyString;
553 std::unique_ptr<LIB_SYMBOL> retv;
558 std::vector<const LIB_SYMBOL*> parentChain;
559 std::set<const LIB_SYMBOL*> visited;
560 visited.insert(
this );
562 std::shared_ptr<LIB_SYMBOL> parent =
m_parent.lock();
564 wxCHECK_MSG( parent, retv, wxString::Format(
"Parent of derived symbol '%s' undefined",
m_name ) );
569 if( visited.count( parent.get() ) )
572 wxT(
"Flatten: Circular inheritance detected in symbol '%s' (lib: %s)" ),
577 visited.insert( parent.get() );
578 parentChain.push_back( parent.get() );
579 parent = parent->m_parent.lock();
583 if( !parentChain.empty() )
585 retv = std::make_unique<LIB_SYMBOL>( *parentChain.back() );
588 for(
int i =
static_cast<int>( parentChain.size() ) - 2; i >= 0; --i )
596 *retv->GetField( fieldId ) = *derived->
GetField( fieldId );
614 retv->AddDrawItem( newField );
618 retv->RemoveDrawItem( parentField );
619 retv->AddDrawItem( newField );
633 retv = std::make_unique<LIB_SYMBOL>( *
this );
634 retv->m_parent.reset();
646 *retv->GetField( fieldId ) = *
GetField( fieldId );
665 retv->AddDrawItem( newField );
669 retv->RemoveDrawItem( parentField );
670 retv->AddDrawItem( newField );
684 retv->AddFile( newFile );
688 if( !parentChain.empty() )
690 retv->SetExcludedFromSim( parentChain.front()->GetExcludedFromSim() );
691 retv->SetExcludedFromBOM( parentChain.front()->GetExcludedFromBOM() );
692 retv->SetExcludedFromBoard( parentChain.front()->GetExcludedFromBoard() );
693 retv->SetExcludedFromPosFiles( parentChain.front()->GetExcludedFromPosFiles() );
696 retv->m_parent.reset();
700 retv = std::make_unique<LIB_SYMBOL>( *
this );
723 return m_libId.GetLibNickname();
733 if( root.get() !=
this )
734 return root->IsLocalPower();
747 if( root.get() !=
this )
749 root->SetLocalPower();
764 if( root.get() !=
this )
765 return root->IsGlobalPower();
784 if( root.get() !=
this )
786 root->SetGlobalPower();
801 if( root.get() !=
this )
802 return root->IsNormal();
815 if( root.get() !=
this )
836 u = ( aUnit - 1 ) % 26;
837 suffix = wxChar( aInitialLetter + u ) + suffix;
838 aUnit = ( aUnit - u ) / 26;
839 }
while( aUnit > 0 );
856 footprint = field.
GetShownText(
nullptr,
false, aDepth + 1 );
860 *token = field.
GetShownText(
nullptr,
false, aDepth + 1 );
867 if( token->IsSameAs( wxT(
"SIM.DEVICE" ) ) || token->IsSameAs( wxT(
"SIM.TYPE" ) )
868 || token->IsSameAs( wxT(
"SIM.PINS" ) ) || token->IsSameAs( wxT(
"SIM.PARAMS" ) )
869 || token->IsSameAs( wxT(
"SIM.LIBRARY" ) ) || token->IsSameAs( wxT(
"SIM.NAME" ) ) )
871 *token = wxEmptyString;
875 if( token->IsSameAs( wxT(
"FOOTPRINT_LIBRARY" ) ) )
877 wxArrayString parts = wxSplit( footprint,
':' );
879 if( parts.Count() > 0 )
882 *token = wxEmptyString;
886 else if( token->IsSameAs( wxT(
"FOOTPRINT_NAME" ) ) )
888 wxArrayString parts = wxSplit( footprint,
':' );
890 if( parts.Count() > 1 )
891 *token = parts[std::min( 1, (
int) parts.size() - 1 )];
893 *token = wxEmptyString;
897 else if( token->IsSameAs( wxT(
"SYMBOL_LIBRARY" ) ) )
899 *token =
m_libId.GetUniStringLibNickname();
902 else if( token->IsSameAs( wxT(
"SYMBOL_NAME" ) ) )
904 *token =
m_libId.GetUniStringLibItemName();
907 else if( token->IsSameAs( wxT(
"SYMBOL_DESCRIPTION" ) ) )
912 else if( token->IsSameAs( wxT(
"SYMBOL_KEYWORDS" ) ) )
917 else if( token->IsSameAs( wxT(
"EXCLUDE_FROM_BOM" ) ) )
922 else if( token->IsSameAs( wxT(
"EXCLUDE_FROM_BOARD" ) ) )
927 else if( token->IsSameAs( wxT(
"EXCLUDE_FROM_SIM" ) ) )
932 else if( token->IsSameAs( wxT(
"DNP" ) ) )
934 *token = this->
GetDNP() ?
_(
"DNP" ) : wxString(
"" );
943 const VECTOR2I& aOffset,
bool aDimmed )
945 wxASSERT( aPlotter !=
nullptr );
960 color = color.
Mix( bg, 0.5f );
968 if( item.IsPrivate() )
976 if( aUnit && item.m_unit && ( item.m_unit != aUnit ) )
979 if( aBodyStyle && item.m_bodyStyle && ( item.m_bodyStyle != aBodyStyle ) )
982 item.Plot( aPlotter, aBackground, aPlotOpts, aUnit, aBodyStyle, aOffset, aDimmed );
988 int aBodyStyle,
const VECTOR2I& aOffset,
bool aDimmed )
990 wxASSERT( aPlotter !=
nullptr );
1002 color = color.
Mix( bg, 0.5f );
1016 wxString tmp = field.
GetText();
1019 item.Plot( aPlotter, aBackground, aPlotOpts, aUnit, aBodyStyle, aOffset, aDimmed );
1028 std::vector<SCH_SHAPE*> potential_top_items;
1029 std::vector<SCH_ITEM*> bottom_items;
1038 potential_top_items.push_back( &shape );
1040 bottom_items.push_back( &item );
1044 bottom_items.push_back( &item );
1048 std::sort( potential_top_items.begin(), potential_top_items.end(),
1051 return a->GetBoundingBox().GetArea() > b->GetBoundingBox().GetArea();
1054 for(
SCH_SHAPE* item : potential_top_items )
1056 for(
SCH_ITEM* bottom_item : bottom_items )
1058 if( item->GetBoundingBox().Contains( bottom_item->GetBoundingBox() ) )
1070 wxASSERT( aItem !=
nullptr );
1076 if(
static_cast<SCH_FIELD*
>( aItem )->IsMandatory() )
1082 for( LIB_ITEMS::iterator i = items.begin(); i != items.end(); i++ )
1118 if( root.get() !=
this )
1119 return const_cast<const LIB_SYMBOL*
>( root.get() )->GetGraphicalPins( aUnit, aBodyStyle );
1122 std::vector<const SCH_PIN*> pins;
1134 if( aUnit && item.m_unit && ( item.m_unit != aUnit ) )
1138 if( aBodyStyle && item.m_bodyStyle && ( item.m_bodyStyle != aBodyStyle ) )
1141 pins.push_back(
static_cast<const SCH_PIN*
>( &item ) );
1154 if( root.get() !=
this )
1155 return root->GetGraphicalPins( aUnit, aBodyStyle );
1158 std::vector<SCH_PIN*> pins;
1170 if( aUnit && item.m_unit && ( item.m_unit != aUnit ) )
1174 if( aBodyStyle && item.m_bodyStyle && ( item.m_bodyStyle != aBodyStyle ) )
1177 pins.push_back(
static_cast<SCH_PIN*
>( &item ) );
1186 std::vector<UNIT_PIN_INFO> units;
1190 auto compareByPosition =
1194 VECTOR2I positionB = b->GetPosition();
1196 if( positionA.
x != positionB.
x )
1197 return positionA.
x < positionB.
x;
1199 return positionA.
y < positionB.
y;
1202 for(
int unitIdx = 1; unitIdx <= unitCount; ++unitIdx )
1209 std::sort( pinList.begin(), pinList.end(), compareByPosition );
1211 std::unordered_set<wxString> seenNumbers;
1213 for(
const SCH_PIN* basePin : pinList )
1215 bool stackedValid =
false;
1216 std::vector<wxString> expandedNumbers = basePin->GetStackedPinNumbers( &stackedValid );
1218 if( stackedValid && !expandedNumbers.empty() )
1220 for(
const wxString& number : expandedNumbers )
1222 if( seenNumbers.insert( number ).second )
1229 const wxString& number = basePin->GetNumber();
1231 if( !number.IsEmpty() && seenNumbers.insert( number ).second )
1235 units.push_back( std::move( unitInfo ) );
1244 std::vector<LOGICAL_PIN> out;
1249 std::vector<wxString> expanded =
pin->GetStackedPinNumbers( &valid );
1251 if( valid && !expanded.empty() )
1253 for(
const wxString& num : expanded )
1256 wxLogTrace(
traceStackedPins,
"GetLogicalPins: base='%s' -> '%s'",
pin->GetShownNumber(), num );
1262 wxLogTrace(
traceStackedPins,
"GetLogicalPins: base='%s' (no expansion)",
pin->GetShownNumber() );
1282 int pinCount =
pin->GetStackedPinCount();
1292 if( aNumber ==
pin->GetNumber() )
1302 std::vector<SCH_PIN*> pins;
1306 if( aNumber ==
pin->GetNumber() )
1307 pins.push_back(
pin );
1315 bool aTestOrientation,
bool aTestLength )
const
1320 bool foundMatch =
false;
1324 wxASSERT( otherPin );
1327 if(
pin->GetUnit() != otherPin->GetUnit() )
1331 if(
pin->GetBodyStyle() != otherPin->GetBodyStyle() )
1335 if(
pin->GetPosition() != otherPin->GetPosition() )
1339 if( aTestNums && (
pin->GetNumber() != otherPin->GetNumber() ) )
1343 if( aTestNames && (
pin->GetName() != otherPin->GetName() ) )
1347 if( aTestType && (
pin->GetType() != otherPin->GetType() ) )
1351 if( aTestOrientation && (
pin->GetOrientation() != otherPin->GetOrientation() ) )
1355 if( aTestLength && (
pin->GetLength() != otherPin->GetLength() ) )
1382 bool aIgnoreLabelsOnInvisiblePins )
const
1390 if( root.get() !=
this )
1391 bBox = root->GetUnitBoundingBox( aUnit, aBodyStyle, aIgnoreHiddenFields, aIgnoreLabelsOnInvisiblePins );
1396 if( item.m_unit > 0 &&
m_unitCount > 1 && aUnit > 0 && aUnit != item.m_unit )
1399 if( item.m_bodyStyle > 0 && aBodyStyle > 0 && aBodyStyle != item.m_bodyStyle )
1402 if( aIgnoreHiddenFields && item.Type() ==
SCH_FIELD_T )
1404 if( !
static_cast<const SCH_FIELD&
>( item ).IsVisible() )
1408 if( item.Type() ==
SCH_PIN_T && !aIgnoreLabelsOnInvisiblePins )
1411 bBox.
Merge(
pin.GetBoundingBox(
true,
true,
false ) );
1415 bBox.
Merge( item.GetBoundingBox() );
1424 bool aIncludePrivateItems )
const
1430 if( item.m_unit > 0 && aUnit > 0 && aUnit != item.m_unit )
1433 if( item.m_bodyStyle > 0 && aBodyStyle > 0 && aBodyStyle != item.m_bodyStyle )
1436 if( item.IsPrivate() && !aIncludePrivateItems )
1446 if(
pin.IsVisible() )
1452 bbox.
Merge(
pin.GetBoundingBox(
false,
false,
false ) );
1459 bbox.
Merge( item.GetBoundingBox() );
1494 for(
const SCH_FIELD& src : aFieldsList )
1522 aList.push_back(
const_cast<SCH_FIELD*
>( field ) );
1525 std::sort( aList.begin(), aList.end(),
1528 return lhs->GetOrdinal() < rhs->GetOrdinal();
1535 std::vector<SCH_FIELD*> orderedFields;
1540 aList.emplace_back( *field );
1549 ordinal = std::max( ordinal,
static_cast<const SCH_FIELD*
>( &item )->GetOrdinal() + 1 );
1561 if( field->
GetId() == aFieldType )
1575 if( field->
GetId() == aFieldType )
1589 if( field.
GetName() == aFieldName )
1603 if( field.
GetName() == aFieldName )
1642 wxASSERT( field !=
nullptr );
1650 wxASSERT( field !=
nullptr );
1658 wxASSERT( field !=
nullptr );
1666 wxASSERT( field !=
nullptr );
1674 wxASSERT( field !=
nullptr );
1683 refDesignator.Replace( wxS(
"~" ), wxS(
" " ) );
1685 wxString prefix = refDesignator;
1687 while( prefix.Length() )
1689 wxUniCharRef last = prefix.Last();
1691 if( ( last >=
'0' && last <=
'9' ) || last ==
'?' || last ==
'*' )
1692 prefix.RemoveLast();
1698 prefix.Trim(
true );
1699 prefix.Trim(
false );
1715 item.Move( aOffset );
1735 if( root.get() !=
this )
1736 return root->HasLegacyAlternateBodyStyle();
1749 if( root.get() !=
this )
1750 return root->GetMaxPinNumber();
1753 int maxPinNumber = 0;
1758 long currentPinNumber = 0;
1760 if(
pin->GetNumber().ToLong( ¤tPinNumber ) )
1761 maxPinNumber = std::max( maxPinNumber, (
int) currentPinNumber );
1764 return maxPinNumber;
1773 item.ClearTempFlags();
1782 item.ClearEditFlags();
1790 if( ( aUnit && item.m_unit && aUnit != item.m_unit )
1791 || ( aBodyStyle && item.m_bodyStyle && aBodyStyle != item.m_bodyStyle )
1797 if( item.HitTest( aPoint ) )
1830 if( item.IsType( aScanTypes ) )
1846 wxCHECK_RET( aCount >= 1,
1847 wxString::Format( wxT(
"Invalid unit count %d, ignoring." ), aCount ) );
1861 if( it->m_unit > aCount )
1868 else if( aDuplicateDrawItems )
1875 std::vector<SCH_ITEM*> tmp;
1879 if( item.m_unit != 1 )
1882 for(
int j = prevCount + 1; j <= aCount; j++ )
1886 tmp.push_back( newItem );
1905 if( root.get() !=
this )
1906 return root->GetUnitCount();
1921 if( aDuplicateDrawItems || aDuplicatePins )
1923 std::vector<SCH_ITEM*> tmp;
1927 if( item.Type() !=
SCH_PIN_T && !aDuplicateDrawItems )
1930 if( item.m_bodyStyle == 1 )
1934 tmp.push_back( newItem );
1950 if( i->m_bodyStyle > 1 )
1963 std::vector<SCH_ITEM*> unitItems;
1970 if( ( aBodyStyle == -1 && item.GetUnit() == aUnit ) || ( aUnit == -1 && item.GetBodyStyle() == aBodyStyle )
1971 || ( aUnit == item.GetUnit() && aBodyStyle == item.GetBodyStyle() ) )
1973 unitItems.push_back( &item );
1983 std::vector<LIB_SYMBOL_UNIT> units;
1990 int unit = item.GetUnit();
1991 int bodyStyle = item.GetBodyStyle();
1993 auto it = std::find_if( units.begin(), units.end(),
1996 return a.m_unit == unit && a.m_bodyStyle == bodyStyle;
1999 if( it == units.end() )
2002 newUnit.
m_unit = item.GetUnit();
2004 newUnit.
m_items.push_back( &item );
2005 units.emplace_back( newUnit );
2009 it->m_items.push_back( &item );
2017#define REPORT( msg ) \
2020 aReporter->Report( msg ); \
2022#define ITEM_DESC( item ) ( item )->GetItemDescription( &unitsProvider, false )
2051 REPORT(
_(
"Power flag differs." ) );
2060 REPORT(
_(
"Unit count differs." ) );
2068 std::set<const SCH_ITEM*, SCH_ITEM::cmp_items> aShapes;
2069 std::set<const SCH_FIELD*> aFields;
2070 std::set<const SCH_PIN*> aPins;
2075 aShapes.insert( &( *it ) );
2077 aFields.insert(
static_cast<const SCH_FIELD*
>( &( *it ) ) );
2079 aPins.insert(
static_cast<const SCH_PIN*
>( &( *it ) ) );
2082 std::set<const SCH_ITEM*, SCH_ITEM::cmp_items> bShapes;
2083 std::set<const SCH_FIELD*> bFields;
2084 std::set<const SCH_PIN*> bPins;
2089 bShapes.insert( &( *it ) );
2091 bFields.insert(
static_cast<const SCH_FIELD*
>( &( *it ) ) );
2093 bPins.insert(
static_cast<const SCH_PIN*
>( &( *it ) ) );
2096 if(
int tmp =
static_cast<int>( aShapes.size() - bShapes.size() ) )
2099 REPORT(
_(
"Graphic item count differs." ) );
2106 for(
auto aIt = aShapes.begin(), bIt = bShapes.begin(); aIt != aShapes.end(); aIt++, bIt++ )
2108 if(
int tmp2 = ( *aIt )->compare( *( *bIt ), aCompareFlags ) )
2111 REPORT( wxString::Format(
_(
"Graphic item differs: %s; %s." ),
ITEM_DESC( *aIt ),
2120 for(
const SCH_PIN* aPin : aPins )
2122 const SCH_PIN* bPin = aRhs.
GetPin( aPin->GetNumber(), aPin->GetUnit(), aPin->GetBodyStyle() );
2127 REPORT( wxString::Format(
_(
"Extra pin in schematic symbol: %s." ),
ITEM_DESC( aPin ) ) );
2132 else if(
int tmp = aPin->SCH_ITEM::compare( *bPin, aCompareFlags ) )
2135 REPORT( wxString::Format(
_(
"Pin %s differs: %s; %s" ), aPin->GetNumber(),
ITEM_DESC( aPin ),
2143 for(
const SCH_PIN* bPin : bPins )
2145 const SCH_PIN* aPin = aRhs.
GetPin( bPin->GetNumber(), bPin->GetUnit(), bPin->GetBodyStyle() );
2150 REPORT( wxString::Format(
_(
"Missing pin in schematic symbol: %s." ),
ITEM_DESC( bPin ) ) );
2157 for(
const SCH_FIELD* aField : aFields )
2161 if( aField->IsMandatory() )
2162 bField = aRhs.
GetField( aField->GetId() );
2164 bField = aRhs.
GetField( aField->GetName() );
2169 REPORT( wxString::Format(
_(
"Extra field in schematic symbol: %s." ),
ITEM_DESC( aField ) ) );
2183 tmp = aField->GetText().compare( bField->
GetText() );
2189 tmp = aField->SCH_ITEM::compare( *bField, aCompareFlags );
2195 REPORT( wxString::Format(
_(
"Field '%s' differs: %s; %s." ), aField->GetName(
false ),
2204 for(
const SCH_FIELD* bField : bFields )
2208 if( bField->IsMandatory() )
2209 aField = aRhs.
GetField( bField->GetId() );
2211 aField = aRhs.
GetField( bField->GetName() );
2216 REPORT( wxString::Format(
_(
"Missing field in schematic symbol: %s." ),
ITEM_DESC( bField ) ) );
2226 REPORT(
_(
"Footprint filter count differs." ) );
2233 for(
size_t i = 0; i <
m_fpFilters.GetCount(); i++ )
2238 REPORT(
_(
"Footprint filters differ." ) );
2249 REPORT(
_(
"Symbol keywords differ." ) );
2258 REPORT(
_(
"Symbol pin name offsets differ." ) );
2269 REPORT(
_(
"Show pin names settings differ." ) );
2278 REPORT(
_(
"Show pin numbers settings differ." ) );
2287 REPORT(
_(
"Exclude from simulation settings differ." ) );
2296 REPORT(
_(
"Exclude from bill of materials settings differ." ) );
2305 REPORT(
_(
"Exclude from board settings differ." ) );
2314 REPORT(
_(
"Exclude from position files settings differ." ) );
2350 return Compare( *tmp, aCompareFlags );
2359 double similarity = 0.0;
2368 double max_similarity = 0.0;
2372 double temp_similarity = item.Similarity( otherItem );
2373 max_similarity = std::max( max_similarity, temp_similarity );
2375 if( max_similarity == 1.0 )
2379 similarity += max_similarity;
2385 double max_similarity = 0.0;
2389 double temp_similarity =
pin->Similarity( *otherPin );
2390 max_similarity = std::max( max_similarity, temp_similarity );
2392 if( max_similarity == 1.0 )
2396 similarity += max_similarity;
2399 if( totalItems == 0 )
2402 similarity /= totalItems;
2454 std::set<const LIB_SYMBOL*> visited;
2455 visited.insert(
this );
2457 std::shared_ptr<LIB_SYMBOL> parent =
m_parent.lock();
2462 if( visited.count( parent.get() ) )
2465 wxT(
"AppendParentEmbeddedFiles: Circular inheritance detected in "
2466 "symbol '%s' (lib: %s)" ),
2471 visited.insert( parent.get() );
2472 aStack.push_back( parent->GetEmbeddedFiles() );
2473 parent = parent->GetParent().lock();
2482 std::set<KIFONT::OUTLINE_FONT*>
fonts;
2490 if(
auto* font =
text.GetFont(); font && !font->IsStroke() )
2495 if( permission == EMBEDDING_PERMISSION::EDITABLE || permission == EMBEDDING_PERMISSION::INSTALLABLE )
2497 fonts.insert( outline );
2523 if(
group.contains( aPinNumber ) )
2527 return std::nullopt;
2538 const wxString groupFields =
_HKI(
"Fields" );
2556 const wxString groupSymbolDef =
_HKI(
"Symbol Definition" );
2567 const wxString groupPinDisplay =
_HKI(
"Pin Display" );
2583 const wxString groupAttributes =
_HKI(
"Attributes" );
2602 const wxString groupUnits =
_HKI(
"Units and Body Styles" );
2612 auto multiBodyStyle = [=](
INSPECTABLE* aItem ) ->
bool
2615 return symbol->IsMultiBodyStyle();
2627 wxPGChoices choices;
2631 for(
int ii = 1; ii <= symbol->GetBodyStyleCount(); ii++ )
2632 choices.Add( symbol->GetBodyStyleDescription( ii,
false ) );
constexpr EDA_IU_SCALE schIUScale
constexpr BOX2< Vec > & Merge(const BOX2< Vec > &aRect)
Modify the position and size of the rectangle in order to contain aRect.
static const COLOR4D WHITE
static const COLOR4D UNSPECIFIED
For legacy support; used as a value to indicate color hasn't been set yet.
virtual void ClearEditFlags()
KICAD_T Type() const
Returns the type of object.
virtual EDA_ITEM * Clone() const
Create a duplicate of this item with linked list members set to NULL.
virtual void SetParent(EDA_ITEM *aParent)
EDA_ITEM_FLAGS GetFlags() const
virtual void ClearTempFlags()
FILL_T GetFillMode() const
virtual bool IsVisible() const
virtual void SetVisible(bool aVisible)
EMBEDDED_FILES & operator=(EMBEDDED_FILES &&other) noexcept
EMBEDDED_FILE * AddFile(const wxFileName &aName, bool aOverwrite)
Load a file from disk and adds it to the collection.
const std::map< wxString, EMBEDDED_FILE * > & EmbeddedFileMap() const
Class that other classes need to inherit from, in order to be inspectable.
Class OUTLINE_FONT implements outline font drawing.
EMBEDDING_PERMISSION GetEmbeddingPermission() const
A color representation with 4 components: red, green, blue, alpha.
std::shared_ptr< wxString > m_text
COLOR4D & Desaturate()
Removes color (in HSL model)
COLOR4D Mix(const COLOR4D &aColor, double aFactor) const
Return a color that is mixed with the input by a factor.
const COLOR4D & GetLayerColor(int aLayer) const
Return the color used to draw a layer.
Object used to load, save, search, and otherwise manipulate symbol library files.
A logical library item identifier and consists of various portions much like a URI.
const UTF8 & GetLibNickname() const
Return the logical library name portion of a LIB_ID.
Define a library symbol object.
LIB_ITEMS_CONTAINER m_drawings
bool ResolveTextVar(wxString *token, int aDepth=0) const
Resolve any references to system tokens supported by the symbol.
SCH_FIELD & GetDescriptionField()
Return reference to the description field.
const LIB_ID & GetLibId() const override
const BOX2I GetUnitBoundingBox(int aUnit, int aBodyStyle, bool aIgnoreHiddenFields=true, bool aIgnoreLabelsOnInvisiblePins=true) const
Get the bounding box for the symbol.
wxString GetKeyWords() const override
std::weak_ptr< LIB_SYMBOL > & GetParent()
wxString GetBodyStyleProp() const override
LIBRENTRYOPTIONS m_options
Special symbol features such as POWER or NORMAL.
wxString GetRefProp() const
bool PinsConflictWith(const LIB_SYMBOL &aOtherSymbol, bool aTestNums, bool aTestNames, bool aTestType, bool aTestOrientation, bool aTestLength) const
Return true if this symbol's pins do not match another symbol's pins.
bool GetUnitsInterchangeableProp() const
wxString m_shownDescriptionCache
std::vector< const SCH_PIN * > GetGraphicalPins(int aUnit=0, int aBodyStyle=0) const
Graphical pins: Return schematic pin objects as drawn (unexpanded), filtered by unit/body.
void GetFields(std::vector< SCH_FIELD * > &aList, bool aVisibleOnly=false) const override
Populate a std::vector with SCH_FIELDs, sorted in ordinal order.
bool IsPower() const override
wxString GetShownKeyWords(int aDepth=0) const override
SCH_FIELD & GetDatasheetField()
Return reference to the datasheet field.
void RefreshLibraryTreeCaches()
std::weak_ptr< LIB_SYMBOL > m_parent
Use for inherited symbols.
void SetExcludedFromBoardProp(bool aExclude)
std::vector< struct LIB_SYMBOL_UNIT > GetUnitDrawItems()
Return a list of SCH_ITEM objects separated by unit and convert number.
std::map< int, wxString > m_unitDisplayNames
std::vector< std::set< wxString > > m_jumperPinGroups
A list of jumper pin groups, each of which is a set of pin numbers that should be jumpered together (...
void ClearTempFlags() override
Clears the status flag all draw objects in this symbol.
void SetKeywordsProp(const wxString &aKeywords)
std::map< int, wxString > & GetUnitDisplayNames()
bool m_demorgan
True if there are two body styles: normal and De Morgan If false, the body style count is taken from ...
wxString GetFootprint() override
For items with footprint fields.
const wxString GetLibraryName() const
void SetFields(const std::vector< SCH_FIELD > &aFieldsList)
Overwrite all the existing fields in this symbol with fields supplied in aFieldsList.
void SetExcludedFromPosFilesProp(bool aExclude)
void SetLib(LEGACY_SYMBOL_LIB *aLibrary)
bool GetPowerSymbolProp() const
bool IsMultiBodyStyle() const override
int GetMaxPinNumber() const
std::vector< SEARCH_TERM > m_searchTermsCache
void Plot(PLOTTER *aPlotter, bool aBackground, const SCH_PLOT_OPTS &aPlotOpts, int aUnit, int aBodyStyle, const VECTOR2I &aOffset, bool aDimmed) override
Plot the item to aPlotter.
SCH_FIELD * GetField(const wxString &aFieldName)
Find a field within this symbol matching aFieldName; return nullptr if not found.
SCH_FIELD & GetFootprintField()
Return reference to the footprint field.
int Compare(const LIB_SYMBOL &aRhs, int aCompareFlags=0, REPORTER *aReporter=nullptr) const
Comparison test that can be used for operators.
void FixupDrawItems()
This function finds the filled draw items that are covering up smaller draw items and replaces their ...
bool IsNormal() const override
void SetUnitsInterchangeableProp(bool aInterchangeable)
std::set< KIFONT::OUTLINE_FONT * > GetFonts() const override
LEGACY_SYMBOL_LIB * m_library
bool GetExcludedFromPosFilesProp() const
SCH_FIELD * FindFieldCaseInsensitive(const wxString &aFieldName)
wxString m_keyWords
Search keywords.
SCH_ITEM * LocateDrawItem(int aUnit, int aBodyStyle, KICAD_T aType, const VECTOR2I &aPoint)
Locate a draw object.
static wxString LetterSubReference(int aUnit, wxChar aInitialLetter)
double Similarity(const SCH_ITEM &aSymbol) const override
Return a measure of similarity between this symbol and aSymbol.
static LIB_SYMBOL * GetDummy()
Returns a dummy LIB_SYMBOL, used when one is missing in the schematic.
void PlotFields(PLOTTER *aPlotter, bool aBackground, const SCH_PLOT_OPTS &aPlotOpts, int aUnit, int aBodyStyle, const VECTOR2I &aOffset, bool aDimmed)
Plot symbol fields.
wxString GetDatasheetProp() const
std::shared_ptr< LIB_SYMBOL > GetRootSymbol() const
Get the parent symbol that does not have another parent.
void SetRefProp(const wxString &aRef)
void SetParent(LIB_SYMBOL *aParent=nullptr)
std::vector< UNIT_PIN_INFO > GetUnitPinInfo() const
Return pin-number lists for each unit, ordered consistently for gate swapping.
wxString GetName() const override
void SetUnitCount(int aCount, bool aDuplicateDrawItems)
Set the units per symbol count.
void SetDescription(const wxString &aDescription)
Gets the Description field text value */.
void cacheChooserFields()
std::shared_ptr< LIB_SYMBOL > m_me
wxString GetValueProp() const
bool GetExcludedFromBOMProp() const
void SetKeyWords(const wxString &aKeyWords)
SCH_FIELD & GetValueField()
Return reference to the value field.
bool IsLocalPower() const override
LIB_SYMBOL(const wxString &aName, LIB_SYMBOL *aParent=nullptr, LEGACY_SYMBOL_LIB *aLibrary=nullptr)
void RemoveDrawItem(SCH_ITEM *aItem)
Remove draw aItem from list.
void GetChooserFields(std::map< wxString, wxString > &aColumnMap) override
Retrieves a key/value map of the fields on this item that should be exposed to the library browser/ch...
bool HasLegacyAlternateBodyStyle() const
Before V10 we didn't store the number of body styles in a symbol – we just looked through all its dra...
std::shared_ptr< LIB_SYMBOL > SharedPtr() const
http://www.boost.org/doc/libs/1_55_0/libs/smart_ptr/sp_techniques.html#weak_without_shared.
bool GetPinNamesInsideProp() const
const std::vector< wxString > & GetBodyStyleNames() const
void SetBodyStyleProp(const wxString &aBodyStyle) override
int compare(const SCH_ITEM &aOther, int aCompareFlags=SCH_ITEM::COMPARE_FLAGS::EQUALITY) const override
The library symbol specific sort order is as follows:
timestamp_t m_lastModDate
void SetExcludedFromSimProp(bool aExclude)
bool GetExcludedFromBoardProp() const
std::optional< const std::set< wxString > > GetJumperPinGroup(const wxString &aPinNumber) const
Retrieves the jumper group containing the specified pin number, if one exists.
std::vector< SCH_PIN * > GetPins() const override
void SetBodyStyleCount(int aCount, bool aDuplicateDrawItems, bool aDuplicatePins)
Set or clear the alternate body style (DeMorgan) for the symbol.
wxString GetLibNickname() const override
Sets the Description field text value.
void SetFootprintProp(const wxString &aFootprint)
std::vector< LOGICAL_PIN > GetLogicalPins(int aUnit, int aBodyStyle) const
Return all logical pins (expanded) filtered by unit/body.
bool HasDeMorganBodyStyles() const override
const LIB_SYMBOL & operator=(const LIB_SYMBOL &aSymbol)
bool m_unitsLocked
True if symbol has multiple units and changing one unit does not automatically change another unit.
wxArrayString m_fpFilters
List of suitable footprint names for the symbol (wild card names accepted).
void Move(const VECTOR2I &aOffset) override
Move the symbol aOffset.
void CopyFields(std::vector< SCH_FIELD > &aList)
Create a copy of the SCH_FIELDs, sorted in ordinal order.
void RunOnChildren(const std::function< void(SCH_ITEM *)> &aFunction, RECURSE_MODE aMode) override
bool GetExcludedFromSimProp() const
int GetBodyStyleCount() const override
void SetDatasheetProp(const wxString &aDatasheet)
INSPECT_RESULT Visit(INSPECTOR inspector, void *testData, const std::vector< KICAD_T > &aScanTypes) override
May be re-implemented for each derived class in order to handle all the types given by its member dat...
EMBEDDED_FILES * GetEmbeddedFiles() override
void SetPowerSymbolProp(bool aIsPower)
void SetExcludedFromBOMProp(bool aExclude)
int m_unitCount
Number of units (parts) per package.
wxString GetShownDescription(int aDepth=0) const override
bool IsGlobalPower() const override
wxString GetBodyStyleDescription(int aBodyStyle, bool aLabel) const override
unsigned GetInheritanceDepth() const
Get the number of parents for this symbol.
int GetUnitCount() const override
wxString GetKeywordsProp() const
std::vector< wxString > m_bodyStyleNames
void AppendParentEmbeddedFiles(std::vector< EMBEDDED_FILES * > &aStack) const
std::vector< SCH_PIN * > GetPinsByNumber(const wxString &aNumber, int aUnit=0, int aBodyStyle=0)
Return all pin objects with the requested pin aNumber.
std::unique_ptr< LIB_SYMBOL > Flatten() const
Return a flattened symbol inheritance to the caller.
BOX2I GetBodyBoundingBox() const override
Return a bounding box for the symbol body but not the pins or fields.
void SetValueProp(const wxString &aValue)
int GetPinCount() override
std::map< wxString, wxString > m_chooserFieldsCache
void SetLibId(const LIB_ID &aLibId)
void AddField(SCH_FIELD *aField)
Add a field.
void ClearEditFlags() override
bool GetLocalPowerSymbolProp() const
LIB_ID GetLIB_ID() const override
const SCH_PIN * GetPin(const wxString &aNumber, int aUnit=0, int aBodyStyle=0) const
Return pin object with the requested pin aNumber.
bool m_duplicatePinNumbersAreJumpers
Flag that this symbol should automatically treat sets of two or more pins with the same number as jum...
void SetUnitProp(int aUnits)
wxString GetFootprintProp() const
void SetPinNamesInsideProp(bool aInside)
void AddDrawItem(SCH_ITEM *aItem, bool aSort=true)
Add a new draw aItem to the draw object list and sort according to aSort.
wxString GetUnitDisplayName(int aUnit, bool aLabel) const override
Return the user-defined display name for aUnit for symbols with units.
void EmbedFonts() override
void SetLocalPowerSymbolProp(bool aIsLocalPower)
virtual void SetName(const wxString &aName)
SCH_FIELD & GetReferenceField()
Return reference to the reference designator field.
void cacheShownDescription()
int GetNextFieldOrdinal() const
Return the next ordinal for a user field for this symbol.
static constexpr int FIRST_TYPE
ITERATOR_BASE< SCH_ITEM, MULTIVECTOR< SCH_ITEM, FIRST_TYPE_VAL, LAST_TYPE_VAL >, typename ITEM_PTR_VECTOR::iterator > ITERATOR
ITERATOR end(int aType=UNDEFINED_TYPE)
static constexpr int LAST_TYPE
ITERATOR begin(int aType=UNDEFINED_TYPE)
Base plotter engine class.
bool GetColorMode() const
virtual void SetColor(const COLOR4D &color)=0
PROPERTY_BASE & SetChoicesFunc(std::function< wxPGChoices(INSPECTABLE *)> aFunc)
PROPERTY_BASE & SetAvailableFunc(std::function< bool(INSPECTABLE *)> aFunc)
Set a callback function to determine whether an object provides this property.
Provide class metadata.Helper macro to map type hashes to names.
void InheritsAfter(TYPE_ID aDerived, TYPE_ID aBase)
Declare an inheritance relationship between types.
static PROPERTY_MANAGER & Instance()
PROPERTY_BASE & AddProperty(PROPERTY_BASE *aProperty, const wxString &aGroup=wxEmptyString)
Register a property.
A pure virtual class used to derive REPORTER objects from.
wxString GetFullText(int unit=1) const
Return the text of a field.
virtual const wxString & GetText() const override
Return the string associated with the text object.
wxString GetCanonicalName() const
Get a non-language-specific name for a field which can be used for storage, variable look-up,...
wxString GetShownText(const SCH_SHEET_PATH *aPath, bool aAllowExtraText, int aDepth=0, const wxString &aVariantName=wxEmptyString) const
wxString GetName(bool aUseDefaultName=true) const
Return the field name (not translated).
bool ShowInChooser() const
void SetText(const wxString &aText) override
SCH_RENDER_SETTINGS * getRenderSettings(PLOTTER *aPlotter) const
SCHEMATIC * Schematic() const
Search the item hierarchy to find a SCHEMATIC.
SCH_ITEM(EDA_ITEM *aParent, KICAD_T aType, int aUnit=0, int aBodyStyle=0)
wxString ResolveText(const wxString &aText, const SCH_SHEET_PATH *aPath, int aDepth=0) const
VECTOR2I GetPosition() const override
const KIGFX::COLOR4D & GetBackgroundColor() const override
Return current background color settings.
A base class for LIB_SYMBOL and SCH_SYMBOL.
bool m_excludedFromPosFiles
virtual bool GetDNP(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
Set or clear the 'Do Not Populate' flag.
virtual void SetShowPinNumbers(bool aShow)
Set or clear the pin number visibility flag.
int GetPinNameOffset() const
virtual void SetShowPinNames(bool aShow)
Set or clear the pin name visibility flag.
virtual bool GetExcludedFromBOM(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
virtual bool GetShowPinNames() const
void SetPinNameOffset(int aOffset)
Set the offset in mils of the pin name text from the pin symbol.
bool GetExcludedFromBoard(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
virtual bool GetExcludedFromSim(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
SYMBOL & operator=(const SYMBOL &aItem)
virtual bool GetShowPinNumbers() const
int m_pinNameOffset
The offset in mils to draw the pin name.
wxString ResolveTextVars(const wxString &aSource, const std::function< bool(wxString *)> *aResolver, int &aDepth)
Multi-pass text variable expansion and math expression evaluation.
#define DEFAULT_PIN_NAME_OFFSET
The intersheets references prefix string.
const INSPECTOR_FUNC & INSPECTOR
std::function passed to nested users by ref, avoids copying std::function.
#define IGNORE_PARENT_GROUP
#define IS_NEW
New item, just created.
#define STRUCT_DELETED
flag indication structures to be erased
@ RECTANGLE
Use RECTANGLE instead of RECT to avoid collision in a Windows header.
@ FILLED_WITH_BG_BODYCOLOR
TRANSFORM DefaultTransform
const wxChar *const traceSymbolInheritance
Flag to enable tracing of circular symbol inheritance detection.
const wxChar *const traceStackedPins
Flag to enable debug output for stacked pins handling in symbol/pin code.
static std::shared_ptr< LIB_SYMBOL > GetSafeRootSymbol(const LIB_SYMBOL *aSymbol, const char *aCallerName)
Helper to safely get the root symbol, detecting and logging circular inheritance.
static struct LIB_SYMBOL_DESC _LIB_SYMBOL_DESC
bool operator<(const LIB_SYMBOL &aItem1, const LIB_SYMBOL &aItem2)
LIB_ITEMS_CONTAINER::ITEM_PTR_VECTOR LIB_ITEMS
@ PT_SIZE
Size expressed in distance units (mm/inch)
void Format(OUTPUTFORMATTER *out, int aNestLevel, int aCtl, const CPTREE &aTree)
Output a PTREE into s-expression format via an OUTPUTFORMATTER derivative.
Logical pins: Return expanded logical pins based on stacked-pin notation.
std::vector< wxString > m_pinNumbers
int m_bodyStyle
The alternate body style of the unit.
std::vector< SCH_ITEM * > m_items
The items unique to this unit and alternate body style.
int m_unit
The unit number.
A structure for storing weighted search terms.
http://www.boost.org/doc/libs/1_55_0/libs/smart_ptr/sp_techniques.html#weak_without_shared
void operator()(void const *) const
FIELD_T
The set of all field indices assuming an array like sequence that a SCH_COMPONENT or LIB_PART can hol...
@ DESCRIPTION
Field Description of part, i.e. "1/4W 1% Metal Film Resistor".
@ FOOTPRINT
Field Name Module PCB, i.e. "16DIP300".
@ DATASHEET
name of datasheet
@ REFERENCE
Field Reference of part, i.e. "IC21".
@ VALUE
Field Value of part, i.e. "3.3K".
const SHAPE_LINE_CHAIN chain
wxLogTrace helper definitions.
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.
VECTOR2< int32_t > VECTOR2I