22#include <fmt/format.h>
63 wxString::Format(
"Cannot use relative file paths in sexpr plugin to "
86 if( !warnings.empty() )
90 wxString errorMsg = wxString::Format(
91 _(
"Library '%s' loaded with errors:\n\n" ),
m_libFileName.GetFullPath() );
93 for(
const wxString& warning : warnings )
94 errorMsg += warning + wxT(
"\n\n" );
96 errorMsg +=
_(
"The library cannot be saved until these errors are fixed manually." );
103 wxString libFileName;
111 if( dir.GetFirst( &libFileName, fileSpec ) )
117 tmp.SetFullName( libFileName );
132 if( !errorCache.IsEmpty() )
133 errorCache += wxT(
"\n\n" );
135 errorCache += warning;
143 if( !errorCache.IsEmpty() )
144 errorCache += wxT(
"\n\n" );
146 errorCache += wxString::Format(
_(
"Unable to read file '%s'" ) +
'\n', tmp.GetFullPath() );
147 errorCache += ioe.
What();
149 }
while( dir.GetNext( &libFileName ) );
151 if( !errorCache.IsEmpty() )
153 errorCache +=
_(
"\n\nThe library cannot be saved until these errors are fixed manually." );
179 _(
"Cannot save library '%s' because it had a parse error during loading.\n\n"
180 "Saving would permanently lose symbols that could not be loaded.\n"
181 "Please fix the library file manually before saving." ),
190 auto formatter = std::make_unique<PRETTIFIED_FILE_OUTPUTFORMATTER>( fn.GetFullPath() );
194 std::vector<LIB_SYMBOL*> orderedSymbols;
199 orderedSymbols.push_back( symbol );
203 std::sort( orderedSymbols.begin(), orderedSymbols.end(),
206 unsigned int lhDepth = aLhs->GetInheritanceDepth();
207 unsigned int rhDepth = aRhs->GetInheritanceDepth();
209 if( lhDepth == rhDepth )
210 return aLhs->GetName() < aRhs->GetName();
212 return lhDepth < rhDepth;
218 formatter->Print(
")" );
223 if( !fn.DirExists() )
225 if( !fn.Mkdir( wxS_DIR_DEFAULT, wxPATH_MKDIR_FULL ) )
226 THROW_IO_ERROR( wxString::Format(
_(
"Cannot create symbol library path '%s'." ), fn.GetPath() ) );
231 wxFileName saveFn( fn );
235 auto formatter = std::make_unique<PRETTIFIED_FILE_OUTPUTFORMATTER>( saveFn.GetFullPath() );
241 formatter->Print(
")" );
252 const wxString& aLibName,
bool aIncludeData )
254 wxCHECK_RET( aSymbol,
"Invalid LIB_SYMBOL pointer." );
264 std::vector<SCH_FIELD*> orderedFields;
268 if( !aLibName.IsEmpty() )
274 wxCHECK2( unitId.
Parse( aLibName ) < 0, );
281 aFormatter.
Print(
"(symbol %s",
name.c_str() );
284 aFormatter.
Print(
"(power global)" );
286 aFormatter.
Print(
"(power local)" );
294 aFormatter.
Print(
"(body_styles " );
298 aFormatter.
Print(
"demorgan" );
303 aFormatter.
Print(
"%s ", aFormatter.
Quotew( bodyStyle ).c_str() );
306 aFormatter.
Print(
")" );
310 aFormatter.
Print(
"(pin_numbers (hide yes))" );
315 aFormatter.
Print(
"(pin_names" );
319 aFormatter.
Print(
"(offset %s)",
327 aFormatter.
Print(
")" );
338 const std::vector<std::set<wxString>>& jumperGroups = aSymbol->
JumperPinGroups();
340 if( !jumperGroups.empty() )
342 aFormatter.
Print(
"(jumper_pin_groups" );
344 for(
const std::set<wxString>&
group : jumperGroups )
346 aFormatter.
Print(
"(" );
348 for(
const wxString& padName :
group )
349 aFormatter.
Print(
"%s ", aFormatter.
Quotew( padName ).c_str() );
351 aFormatter.
Print(
")" );
354 aFormatter.
Print(
")" );
379 std::sort( units.begin(), units.end(),
382 if( a.m_unit == b.m_unit )
383 return a.m_bodyStyle < b.m_bodyStyle;
385 return a.m_unit < b.m_unit;
394 aFormatter.
Print(
"(symbol %s_%d_%d\"",
403 aFormatter.
Print(
"(unit_name %s)", aFormatter.
Quotes(
name ).c_str() );
413 std::multiset<
SCH_ITEM*,
decltype( cmp )> save_map( cmp );
415 for(
SCH_ITEM* item : unit.m_items )
416 save_map.insert( item );
421 aFormatter.
Print(
")" );
431 std::shared_ptr<LIB_SYMBOL> parent = aSymbol->
GetParent().lock();
435 aFormatter.
Print(
"(symbol %s (extends %s)",
437 aFormatter.
Quotew( parent->GetName() ).c_str() );
452 aFormatter.
Print(
")" );
459 wxCHECK_RET( aSymbol,
"Invalid LIB_SYMBOL pointer." );
471 if( !fpFilters.IsEmpty() )
475 for(
const wxString&
filter : fpFilters )
483 tmp +=
" " + curr_filter;
496 wxCHECK_RET( aItem,
"Invalid SCH_ITEM pointer." );
498 switch( aItem->
Type() )
511 formatArc( &aFormatter, shape, isPrivate, stroke, fillMode, fillColor,
true );
515 formatCircle( &aFormatter, shape, isPrivate, stroke, fillMode, fillColor,
true );
519 formatRect( &aFormatter, shape, isPrivate, stroke, fillMode, fillColor,
true );
523 formatBezier(&aFormatter, shape, isPrivate, stroke, fillMode, fillColor,
true );
527 formatPoly( &aFormatter, shape, isPrivate, stroke, fillMode, fillColor,
true );
557 wxCHECK_RET( aField && aField->
Type() ==
SCH_FIELD_T,
"Invalid SCH_FIELD object." );
559 wxString fieldName = aField->
GetName();
564 aFormatter.
Print(
"(property %s %s %s (at %s %s %s)",
566 aFormatter.
Quotew( fieldName ).c_str(),
581 aField->
Format( &aFormatter, 0 );
582 aFormatter.
Print(
")" );
588 wxCHECK_RET( aPin && aPin->
Type() ==
SCH_PIN_T,
"Invalid SCH_PIN object." );
592 aFormatter.
Print(
"(pin %s %s (at %s %s %s) (length %s)",
607 aFormatter.
Print(
"(name %s (effects (font (size %s %s))))",
614 aFormatter.
Print(
"(number %s (effects (font (size %s %s))))",
622 for(
const std::pair<const wxString, SCH_PIN::ALT>& alt : aPin->
GetAlternates() )
627 if( alt.second.m_Name.IsEmpty() )
630 aFormatter.
Print(
"(alternate %s %s %s)",
631 aFormatter.
Quotew( alt.second.m_Name ).c_str(),
636 aFormatter.
Print(
")" );
642 wxCHECK_RET( aText && aText->
Type() ==
SCH_TEXT_T,
"Invalid SCH_TEXT object." );
644 aFormatter.
Print(
"(text %s %s (at %s %s %d)",
653 aText->EDA_TEXT::Format( &aFormatter, 0 );
654 aFormatter.
Print(
")" );
660 wxCHECK_RET( aTextBox && aTextBox->
Type() ==
SCH_TEXTBOX_T,
"Invalid SCH_TEXTBOX object." );
662 aFormatter.
Print(
"(text_box %s %s",
669 aFormatter.
Print(
"(at %s %s %s) (size %s %s) (margins %s %s %s %s)",
682 aTextBox->EDA_TEXT::Format( &aFormatter, 0 );
683 aFormatter.
Print(
")" );
689 LIB_SYMBOL_MAP::iterator it =
m_symbols.find( aSymbolName );
692 THROW_IO_ERROR( wxString::Format(
_(
"library %s does not contain a symbol named %s" ),
704 LIB_SYMBOL_MAP::iterator it1 =
m_symbols.begin();
708 if( it1->second->IsDerived()
709 && it1->second->GetParent().lock() == rootSymbol->
SharedPtr() )
738 if( symbol->GetParentName().IsEmpty() )
741 auto it =
m_symbols.find( symbol->GetParentName() );
747 error.Printf(
_(
"No parent for extended symbol %s found in library '%s'" ),
752 symbol->SetParent( it->second );
759 aFormatter.
Print(
"(kicad_symbol_lib (version %d) (generator \"kicad_symbol_editor\") "
760 "(generator_version \"%s\")",
constexpr EDA_IU_SCALE schIUScale
wxString GetMajorMinorVersion()
Get only the major and minor version in a string major.minor.
int AsTenthsOfADegree() const
KICAD_T Type() const
Returns the type of object.
void ClearFlags(EDA_ITEM_FLAGS aMask=EDA_ITEM_ALL_FLAGS)
FILL_T GetFillMode() const
const VECTOR2I & GetEnd() const
Return the ending point of the graphic.
const VECTOR2I & GetStart() const
Return the starting point of the graphic.
COLOR4D GetFillColor() const
wxString SHAPE_T_asString() const
const EDA_ANGLE & GetTextAngle() const
virtual const wxString & GetText() const
Return the string associated with the text object.
virtual bool IsVisible() const
virtual void Format(OUTPUTFORMATTER *aFormatter, int aControlBits) const
Output the object to aFormatter in s-expression form.
virtual void SetVisible(bool aVisible)
void WriteEmbeddedFiles(OUTPUTFORMATTER &aOut, bool aWriteData) const
Output formatter for the embedded files.
void ClearEmbeddedFonts()
Remove all embedded fonts from the collection.
const std::map< wxString, EMBEDDED_FILE * > & EmbeddedFileMap() const
bool GetAreFontsEmbedded() const
A LINE_READER that reads from an open file.
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
virtual const wxString What() const
A composite of Problem() and Where()
A color representation with 4 components: red, green, blue, alpha.
A logical library item identifier and consists of various portions much like a URI.
int Parse(const UTF8 &aId, bool aFix=false)
Parse LIB_ID with the information from aId.
const UTF8 & GetLibItemName() const
Define a library symbol object.
const LIB_ID & GetLibId() const override
wxString GetKeyWords() const override
std::weak_ptr< LIB_SYMBOL > & GetParent()
void GetFields(std::vector< SCH_FIELD * > &aList, bool aVisibleOnly=false) const override
Populate a std::vector with SCH_FIELDs, sorted in ordinal order.
bool UnitsLocked() const
Check whether symbol units are interchangeable.
bool IsRoot() const override
For symbols derived from other symbols, IsRoot() indicates no derivation.
std::vector< struct LIB_SYMBOL_UNIT > GetUnitDrawItems()
Return a list of SCH_ITEM objects separated by unit and convert number.
std::map< int, wxString > & GetUnitDisplayNames()
bool IsMultiBodyStyle() const override
bool IsLocalPower() const override
wxArrayString GetFPFilters() const
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.
const std::vector< wxString > & GetBodyStyleNames() const
bool HasDeMorganBodyStyles() const override
EMBEDDED_FILES * GetEmbeddedFiles() override
bool IsGlobalPower() const override
bool GetDuplicatePinNumbersAreJumpers() const
std::vector< std::set< wxString > > & JumperPinGroups()
Each jumper pin group is a set of pin numbers that should be treated as internally connected.
void EmbedFonts() override
VECTOR2I GetPosition() const override
virtual const wxString & GetText() const override
Return the string associated with the text object.
wxString GetName(bool aUseDefaultName=true) const
Return the field name (not translated).
bool CanAutoplace() const
void SetText(const wxString &aText) override
int m_fileFormatVersionAtLoad
static void saveSymbolDrawItem(SCH_ITEM *aItem, OUTPUTFORMATTER &aFormatter)
SCH_IO_KICAD_SEXPR_LIB_CACHE(const wxString &aLibraryPath)
static void saveDcmInfoAsFields(LIB_SYMBOL *aSymbol, OUTPUTFORMATTER &aFormatter)
virtual ~SCH_IO_KICAD_SEXPR_LIB_CACHE()
static void SaveSymbol(LIB_SYMBOL *aSymbol, OUTPUTFORMATTER &aFormatter, const wxString &aLibName=wxEmptyString, bool aIncludeData=true)
static void saveTextBox(SCH_TEXTBOX *aTextBox, OUTPUTFORMATTER &aFormatter)
bool isLibraryPathValid() const
static void saveField(SCH_FIELD *aField, OUTPUTFORMATTER &aFormatter)
void formatLibraryHeader(OUTPUTFORMATTER &aFormatter)
void DeleteSymbol(const wxString &aName) override
static void savePin(SCH_PIN *aPin, OUTPUTFORMATTER &aFormatter)
static void saveText(SCH_TEXT *aText, OUTPUTFORMATTER &aFormatter)
void SetFileFormatVersionAtLoad(int aVersion)
void Save(const std::optional< bool > &aOpt=std::nullopt) override
Save the entire library to file m_libFileName;.
void updateParentSymbolLinks()
Update the parent symbol links for derived symbols.
Object to parser s-expression symbol library and schematic file formats.
const std::vector< wxString > & GetParseWarnings() const
Return any non-fatal parse warnings that occurred during parsing.
int GetParsedRequiredVersion() const
void ParseLib(LIB_SYMBOL_MAP &aSymbolLibMap)
void SetParseError(bool aHasError=true)
Set the parse error state.
bool HasParseError() const
wxFileName GetRealFile() const
long long GetLibModificationTime()
SCH_IO_LIB_CACHE(const wxString &aLibraryPath)
void IncrementModifyHash()
Base class for any item which can be embedded within the SCHEMATIC container class,...
wxString GetClass() const override
Return the class name.
int GetNumberTextSize() const
const std::map< wxString, ALT > & GetAlternates() const
const wxString & GetName() const
PIN_ORIENTATION GetOrientation() const
VECTOR2I GetPosition() const override
int GetNameTextSize() const
const wxString & GetNumber() const
GRAPHIC_PINSHAPE GetShape() const
ELECTRICAL_PINTYPE GetType() const
STROKE_PARAMS GetStroke() const override
int GetMarginBottom() const
int GetMarginLeft() const
int GetMarginRight() const
VECTOR2I GetPosition() const override
Simple container to manage line stroke parameters.
void Format(OUTPUTFORMATTER *out, const EDA_IU_SCALE &aIuScale) const
bool GetExcludedFromPosFiles(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
int GetPinNameOffset() const
virtual bool GetExcludedFromBOM(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
virtual bool GetShowPinNames() const
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
virtual bool GetShowPinNumbers() const
#define DEFAULT_PIN_NAME_OFFSET
The intersheets references prefix string.
#define IS_CHANGED
Item was edited, and modified.
@ RECTANGLE
Use RECTANGLE instead of RECT to avoid collision in a Windows header.
static const std::string KiCadSymbolLibFileExtension
const wxChar *const traceSchLegacyPlugin
Flag to enable legacy schematic plugin debug output.
#define THROW_IO_ERROR(msg)
macro which captures the "call site" values of FILE_, __FUNCTION & LINE
This file contains miscellaneous commonly used macros and functions.
#define UNIMPLEMENTED_FOR(type)
KICOMMON_API std::string FormatAngle(const EDA_ANGLE &aAngle)
Convert aAngle from board units to a string appropriate for writing to file.
KICOMMON_API std::string FormatInternalUnits(const EDA_IU_SCALE &aIuScale, int aValue, EDA_DATA_TYPE aDataType=EDA_DATA_TYPE::DISTANCE)
Converts aValue from internal units to a string appropriate for writing to file.
#define SEXPR_SYMBOL_LIB_FILE_VERSION
This file contains the file format version information for the s-expression schematic and symbol libr...
EDA_ANGLE getPinAngle(PIN_ORIENTATION aOrientation)
void formatArc(OUTPUTFORMATTER *aFormatter, EDA_SHAPE *aArc, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
void formatCircle(OUTPUTFORMATTER *aFormatter, EDA_SHAPE *aCircle, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
const char * getPinElectricalTypeToken(ELECTRICAL_PINTYPE aType)
void formatBezier(OUTPUTFORMATTER *aFormatter, EDA_SHAPE *aBezier, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
void formatRect(OUTPUTFORMATTER *aFormatter, EDA_SHAPE *aRect, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
void formatPoly(OUTPUTFORMATTER *aFormatter, EDA_SHAPE *aPolyLine, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
void formatFill(OUTPUTFORMATTER *aFormatter, FILL_T aFillMode, const COLOR4D &aFillColor)
Fill token formatting helper.
const char * getPinShapeToken(GRAPHIC_PINSHAPE aShape)
wxString EscapeString(const wxString &aSource, ESCAPE_CONTEXT aContext)
The Escape/Unescape routines use HTML-entity-reference-style encoding to handle characters which are:...
@ USER
The field ID hasn't been set yet; field is invalid.
wxString GetCanonicalFieldName(FIELD_T aFieldType)
wxLogTrace helper definitions.
VECTOR2< int32_t > VECTOR2I