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 )
1628 wxASSERT( field !=
nullptr );
1636 wxASSERT( field !=
nullptr );
1644 wxASSERT( field !=
nullptr );
1652 wxASSERT( field !=
nullptr );
1660 wxASSERT( field !=
nullptr );
1669 refDesignator.Replace( wxS(
"~" ), wxS(
" " ) );
1671 wxString prefix = refDesignator;
1673 while( prefix.Length() )
1675 wxUniCharRef last = prefix.Last();
1677 if( ( last >=
'0' && last <=
'9' ) || last ==
'?' || last ==
'*' )
1678 prefix.RemoveLast();
1684 prefix.Trim(
true );
1685 prefix.Trim(
false );
1701 item.Move( aOffset );
1721 if( root.get() !=
this )
1722 return root->HasLegacyAlternateBodyStyle();
1735 if( root.get() !=
this )
1736 return root->GetMaxPinNumber();
1739 int maxPinNumber = 0;
1744 long currentPinNumber = 0;
1746 if(
pin->GetNumber().ToLong( ¤tPinNumber ) )
1747 maxPinNumber = std::max( maxPinNumber, (
int) currentPinNumber );
1750 return maxPinNumber;
1759 item.ClearTempFlags();
1768 item.ClearEditFlags();
1776 if( ( aUnit && item.m_unit && aUnit != item.m_unit )
1777 || ( aBodyStyle && item.m_bodyStyle && aBodyStyle != item.m_bodyStyle )
1783 if( item.HitTest( aPoint ) )
1816 if( item.IsType( aScanTypes ) )
1832 wxCHECK_RET( aCount >= 1,
1833 wxString::Format( wxT(
"Invalid unit count %d, ignoring." ), aCount ) );
1847 if( it->m_unit > aCount )
1854 else if( aDuplicateDrawItems )
1861 std::vector<SCH_ITEM*> tmp;
1865 if( item.m_unit != 1 )
1868 for(
int j = prevCount + 1; j <= aCount; j++ )
1872 tmp.push_back( newItem );
1891 if( root.get() !=
this )
1892 return root->GetUnitCount();
1907 if( aDuplicateDrawItems || aDuplicatePins )
1909 std::vector<SCH_ITEM*> tmp;
1913 if( item.Type() !=
SCH_PIN_T && !aDuplicateDrawItems )
1916 if( item.m_bodyStyle == 1 )
1920 tmp.push_back( newItem );
1936 if( i->m_bodyStyle > 1 )
1949 std::vector<SCH_ITEM*> unitItems;
1956 if( ( aBodyStyle == -1 && item.GetUnit() == aUnit ) || ( aUnit == -1 && item.GetBodyStyle() == aBodyStyle )
1957 || ( aUnit == item.GetUnit() && aBodyStyle == item.GetBodyStyle() ) )
1959 unitItems.push_back( &item );
1969 std::vector<LIB_SYMBOL_UNIT> units;
1976 int unit = item.GetUnit();
1977 int bodyStyle = item.GetBodyStyle();
1979 auto it = std::find_if( units.begin(), units.end(),
1982 return a.m_unit == unit && a.m_bodyStyle == bodyStyle;
1985 if( it == units.end() )
1988 newUnit.
m_unit = item.GetUnit();
1990 newUnit.
m_items.push_back( &item );
1991 units.emplace_back( newUnit );
1995 it->m_items.push_back( &item );
2003#define REPORT( msg ) \
2006 aReporter->Report( msg ); \
2008#define ITEM_DESC( item ) ( item )->GetItemDescription( &unitsProvider, false )
2037 REPORT(
_(
"Power flag differs." ) );
2046 REPORT(
_(
"Unit count differs." ) );
2054 std::set<const SCH_ITEM*, SCH_ITEM::cmp_items> aShapes;
2055 std::set<const SCH_FIELD*> aFields;
2056 std::set<const SCH_PIN*> aPins;
2061 aShapes.insert( &( *it ) );
2063 aFields.insert(
static_cast<const SCH_FIELD*
>( &( *it ) ) );
2065 aPins.insert(
static_cast<const SCH_PIN*
>( &( *it ) ) );
2068 std::set<const SCH_ITEM*, SCH_ITEM::cmp_items> bShapes;
2069 std::set<const SCH_FIELD*> bFields;
2070 std::set<const SCH_PIN*> bPins;
2075 bShapes.insert( &( *it ) );
2077 bFields.insert(
static_cast<const SCH_FIELD*
>( &( *it ) ) );
2079 bPins.insert(
static_cast<const SCH_PIN*
>( &( *it ) ) );
2082 if(
int tmp =
static_cast<int>( aShapes.size() - bShapes.size() ) )
2085 REPORT(
_(
"Graphic item count differs." ) );
2092 for(
auto aIt = aShapes.begin(), bIt = bShapes.begin(); aIt != aShapes.end(); aIt++, bIt++ )
2094 if(
int tmp2 = ( *aIt )->compare( *( *bIt ), aCompareFlags ) )
2097 REPORT( wxString::Format(
_(
"Graphic item differs: %s; %s." ),
ITEM_DESC( *aIt ),
2106 for(
const SCH_PIN* aPin : aPins )
2108 const SCH_PIN* bPin = aRhs.
GetPin( aPin->GetNumber(), aPin->GetUnit(), aPin->GetBodyStyle() );
2113 REPORT( wxString::Format(
_(
"Extra pin in schematic symbol: %s." ),
ITEM_DESC( aPin ) ) );
2118 else if(
int tmp = aPin->SCH_ITEM::compare( *bPin, aCompareFlags ) )
2121 REPORT( wxString::Format(
_(
"Pin %s differs: %s; %s" ), aPin->GetNumber(),
ITEM_DESC( aPin ),
2129 for(
const SCH_PIN* bPin : bPins )
2131 const SCH_PIN* aPin = aRhs.
GetPin( bPin->GetNumber(), bPin->GetUnit(), bPin->GetBodyStyle() );
2136 REPORT( wxString::Format(
_(
"Missing pin in schematic symbol: %s." ),
ITEM_DESC( bPin ) ) );
2143 for(
const SCH_FIELD* aField : aFields )
2147 if( aField->IsMandatory() )
2148 bField = aRhs.
GetField( aField->GetId() );
2150 bField = aRhs.
GetField( aField->GetName() );
2155 REPORT( wxString::Format(
_(
"Extra field in schematic symbol: %s." ),
ITEM_DESC( aField ) ) );
2169 tmp = aField->GetText().compare( bField->
GetText() );
2175 tmp = aField->SCH_ITEM::compare( *bField, aCompareFlags );
2181 REPORT( wxString::Format(
_(
"Field '%s' differs: %s; %s." ), aField->GetName(
false ),
2190 for(
const SCH_FIELD* bField : bFields )
2194 if( bField->IsMandatory() )
2195 aField = aRhs.
GetField( bField->GetId() );
2197 aField = aRhs.
GetField( bField->GetName() );
2202 REPORT( wxString::Format(
_(
"Missing field in schematic symbol: %s." ),
ITEM_DESC( bField ) ) );
2212 REPORT(
_(
"Footprint filter count differs." ) );
2219 for(
size_t i = 0; i <
m_fpFilters.GetCount(); i++ )
2224 REPORT(
_(
"Footprint filters differ." ) );
2235 REPORT(
_(
"Symbol keywords differ." ) );
2244 REPORT(
_(
"Symbol pin name offsets differ." ) );
2255 REPORT(
_(
"Show pin names settings differ." ) );
2264 REPORT(
_(
"Show pin numbers settings differ." ) );
2273 REPORT(
_(
"Exclude from simulation settings differ." ) );
2282 REPORT(
_(
"Exclude from bill of materials settings differ." ) );
2291 REPORT(
_(
"Exclude from board settings differ." ) );
2300 REPORT(
_(
"Exclude from position files settings differ." ) );
2336 return Compare( *tmp, aCompareFlags );
2345 double similarity = 0.0;
2354 double max_similarity = 0.0;
2358 double temp_similarity = item.Similarity( otherItem );
2359 max_similarity = std::max( max_similarity, temp_similarity );
2361 if( max_similarity == 1.0 )
2365 similarity += max_similarity;
2371 double max_similarity = 0.0;
2375 double temp_similarity =
pin->Similarity( *otherPin );
2376 max_similarity = std::max( max_similarity, temp_similarity );
2378 if( max_similarity == 1.0 )
2382 similarity += max_similarity;
2385 if( totalItems == 0 )
2388 similarity /= totalItems;
2440 std::set<const LIB_SYMBOL*> visited;
2441 visited.insert(
this );
2443 std::shared_ptr<LIB_SYMBOL> parent =
m_parent.lock();
2448 if( visited.count( parent.get() ) )
2451 wxT(
"AppendParentEmbeddedFiles: Circular inheritance detected in "
2452 "symbol '%s' (lib: %s)" ),
2457 visited.insert( parent.get() );
2458 aStack.push_back( parent->GetEmbeddedFiles() );
2459 parent = parent->GetParent().lock();
2468 std::set<KIFONT::OUTLINE_FONT*>
fonts;
2476 if(
auto* font =
text.GetFont(); font && !font->IsStroke() )
2481 if( permission == EMBEDDING_PERMISSION::EDITABLE || permission == EMBEDDING_PERMISSION::INSTALLABLE )
2483 fonts.insert( outline );
2509 if(
group.contains( aPinNumber ) )
2513 return std::nullopt;
2524 const wxString groupFields =
_HKI(
"Fields" );
2542 const wxString groupSymbolDef =
_HKI(
"Symbol Definition" );
2553 const wxString groupPinDisplay =
_HKI(
"Pin Display" );
2569 const wxString groupAttributes =
_HKI(
"Attributes" );
2588 const wxString groupUnits =
_HKI(
"Units and Body Styles" );
2598 auto multiBodyStyle = [=](
INSPECTABLE* aItem ) ->
bool
2601 return symbol->IsMultiBodyStyle();
2613 wxPGChoices choices;
2617 for(
int ii = 1; ii <= symbol->GetBodyStyleCount(); ii++ )
2618 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