Handle Eagle user-defined attributes.

(We map these to text variables.)

Fixes https://gitlab.com/kicad/code/kicad/issues/13798
This commit is contained in:
Jeff Young 2023-05-06 21:09:44 +01:00
parent 5d116245c6
commit 8fe02ee83c
2 changed files with 27 additions and 22 deletions

View File

@ -115,6 +115,8 @@ wxString interpretText( const wxString& aText )
bool substituteVariable( wxString* aText ) bool substituteVariable( wxString* aText )
{
if( aText->StartsWith( '>' ) && aText->AfterFirst( ' ' ).IsEmpty() )
{ {
if ( *aText == wxT( ">NAME" ) ) *aText = wxT( "${REFERENCE}" ); if ( *aText == wxT( ">NAME" ) ) *aText = wxT( "${REFERENCE}" );
else if( *aText == wxT( ">VALUE" ) ) *aText = wxT( "${VALUE}" ); else if( *aText == wxT( ">VALUE" ) ) *aText = wxT( "${VALUE}" );
@ -132,11 +134,14 @@ bool substituteVariable( wxString* aText )
else if( *aText == wxT( ">DRAWING_NAME" ) ) *aText = wxT( "${PROJECTNAME}" ); else if( *aText == wxT( ">DRAWING_NAME" ) ) *aText = wxT( "${PROJECTNAME}" );
else if( *aText == wxT( ">LAST_DATE_TIME" ) ) *aText = wxT( "${CURRENT_DATE}" ); else if( *aText == wxT( ">LAST_DATE_TIME" ) ) *aText = wxT( "${CURRENT_DATE}" );
else if( *aText == wxT( ">PLOT_DATE_TIME" ) ) *aText = wxT( "${CURRENT_DATE}" ); else if( *aText == wxT( ">PLOT_DATE_TIME" ) ) *aText = wxT( "${CURRENT_DATE}" );
else return false; else *aText = wxString::Format( wxS( "${%s}" ), aText->Mid( 1 ).Trim() );
return true; return true;
} }
return false;
}
template<> template<> template<> template<>
OPTIONAL_XML_ATTRIBUTE<wxString>::OPTIONAL_XML_ATTRIBUTE( wxString aData ) OPTIONAL_XML_ATTRIBUTE<wxString>::OPTIONAL_XML_ATTRIBUTE( wxString aData )

View File

@ -1726,7 +1726,7 @@ void SCH_EAGLE_PLUGIN::loadInstance( wxXmlNode* aInstanceNode )
valueField->SetVisible( false ); valueField->SetVisible( false );
} }
for( const auto& a : epart->attribute ) for( const auto& [ attrName, attrValue ] : epart->attribute )
{ {
VECTOR2I newFieldPosition( 0, 0 ); VECTOR2I newFieldPosition( 0, 0 );
SCH_FIELD* lastField = symbol->GetFieldById( symbol->GetFieldCount() - 1 ); SCH_FIELD* lastField = symbol->GetFieldById( symbol->GetFieldCount() - 1 );
@ -1736,8 +1736,8 @@ void SCH_EAGLE_PLUGIN::loadInstance( wxXmlNode* aInstanceNode )
SCH_FIELD newField( newFieldPosition, symbol->GetFieldCount(), symbol.get() ); SCH_FIELD newField( newFieldPosition, symbol->GetFieldCount(), symbol.get() );
newField.SetName( a.first ); newField.SetName( attrName );
newField.SetText( a.second ); newField.SetText( attrValue );
newField.SetVisible( false ); newField.SetVisible( false );
symbol->AddField( newField ); symbol->AddField( newField );