30#include <wx/mstream.h>
31#include <boost/algorithm/string/join.hpp>
43#include <schematic_lexer.h>
70using namespace TSCHEMATIC_T;
73#define SCH_PARSE_ERROR( text, reader, pos ) \
74 THROW_PARSE_ERROR( text, reader.GetSource(), reader.Line(), \
75 reader.LineNumber(), pos - reader.Line() )
104 const std::map<std::string, UTF8>* aProperties )
106 wxASSERT( !aFileName || aSchematic !=
nullptr );
111 wxFileName fn = aFileName;
119 wxASSERT( fn.IsAbsolute() );
129 if( !normedFn.IsAbsolute() )
131 if( aFileName.Right( normedFn.GetFullPath().Length() ) == normedFn.GetFullPath() )
132 m_path = aFileName.Left( aFileName.Length() - normedFn.GetFullPath().Length() );
146 init( aSchematic, aProperties );
148 if( aAppendToMe ==
nullptr )
151 std::unique_ptr<SCH_SHEET> newSheet = std::make_unique<SCH_SHEET>( aSchematic );
153 wxFileName relPath( aFileName );
159 newSheet->SetFileName( relPath.GetFullPath() );
164 sheet = newSheet.release();
169 wxCHECK_MSG( aSchematic->
IsValid(),
nullptr,
"Can't append to a schematic with no root!" );
198 if( !fileName.IsAbsolute() )
207 wxLogTrace(
traceSchPlugin,
"Loading '%s'", fileName.GetFullPath() );
211 while( !ancestorSheetPath.
empty() )
218 m_error += wxString::Format(
_(
"Could not load sheet '%s' because it already "
219 "appears as a direct ancestor in the schematic "
221 fileName.GetFullPath() );
223 fileName = wxEmptyString;
231 if( ancestorSheetPath.
empty() )
252 loadFile( fileName.GetFullPath(), aSheet );
267 if( fileName.FileExists() )
305 size_t lineCount = 0;
340 const std::map<std::string, UTF8>* aProperties )
342 wxCHECK_RET( aSheet !=
nullptr,
"NULL SCH_SHEET object." );
343 wxCHECK_RET( !aFileName.IsEmpty(),
"No schematic file name defined." );
347 init( aSchematic, aProperties );
349 wxFileName fn = aFileName;
353 wxASSERT( fn.IsAbsolute() );
368 wxCHECK_RET( aSheet !=
nullptr,
"NULL SCH_SHEET* object." );
369 wxCHECK_RET(
m_schematic !=
nullptr,
"NULL SCHEMATIC* object." );
384 m_out->
Print( 0,
"(kicad_sch (version %d) (generator \"eeschema\") (generator_version \"%s\")\n\n",
396 for(
const auto& [ libItemName, libSymbol ] : screen->
GetLibSymbols() )
401 for(
const std::shared_ptr<BUS_ALIAS>& alias : screen->
GetBusAliases() )
408 if( a->
Type() != b->Type() )
409 return a->
Type() < b->Type();
411 return a->
m_Uuid < b->m_Uuid;
414 std::multiset<
SCH_ITEM*,
decltype( cmp )> save_map( cmp );
420 save_map.insert( item );
428 if( itemType != item->Type() )
430 itemType = item->Type();
440 switch( item->Type() )
470 if( layer != item->GetLayer() )
474 layer = item->GetLayer();
478 layer = item->GetLayer();
511 wxASSERT(
"Unexpected schematic object type in SCH_IO_KICAD_SEXPR::Format()" );
517 std::vector< SCH_SHEET_INSTANCE> instances;
538 wxCHECK( aSelection && aSelectionPath && aFormatter, );
548 std::map<wxString, LIB_SYMBOL*> libSymbols;
550 std::set<SCH_TABLE*> promotedTables;
552 for( i = 0; i < aSelection->
GetSize(); ++i )
556 wxCHECK2( item,
continue );
563 wxCHECK2( symbol,
continue );
573 libSymbols[ libSymbolLookup ] = it->second;
576 if( !libSymbols.empty() )
580 for(
const std::pair<const wxString, LIB_SYMBOL*>& libSymbol : libSymbols )
583 libSymbol.first,
false );
589 for( i = 0; i < aSelection->
GetSize(); ++i )
593 switch( item->
Type() )
649 if( promotedTables.count( table ) )
655 promotedTables.insert( table );
665 wxASSERT(
"Unexpected schematic object type in SCH_IO_KICAD_SEXPR::Format()" );
673 int aNestLevel,
bool aForClipboard,
676 wxCHECK_RET( aSymbol !=
nullptr &&
m_out !=
nullptr,
"" );
682 if( symbol_name.size() )
688 libName =
"_NONAME_";
711 m_out->
Print( 0,
" (lib_id %s) (at %s %s %s)",
722 if( mirrorX || mirrorY )
740 if( aForClipboard && aRelativePath )
745 unit = unitInstance.
m_Unit;
755 m_out->
Print( aNestLevel + 1,
"(exclude_from_sim %s)",
762 m_out->
Print( 0,
" (fields_autoplaced yes)" );
772 int id = field.GetId();
773 wxString value = field.GetText();
781 field.SetText( aSymbol->
GetInstances()[0].m_Reference );
792 else if( aForClipboard && aSymbol->
GetInstances().size() && aRelativePath
809 field.SetText( value );
815 field.SetText( value );
818 for(
const std::unique_ptr<SCH_PIN>&
pin : aSymbol->
GetRawPins() )
820 if(
pin->GetAlt().IsEmpty() )
830 m_out->
Print( aNestLevel + 1,
" (alternate %s))\n",
837 std::map<KIID, std::vector<SCH_SYMBOL_INSTANCE>> projectInstances;
839 m_out->
Print( aNestLevel + 1,
"(instances\n" );
841 wxString projectName;
842 KIID lastProjectUuid;
848 wxCHECK2( inst.m_Path.size(),
continue );
853 bool isOrphaned = ( inst.m_Path[0] == rootSheetUuid )
857 if( !aForClipboard && isOrphaned )
860 auto it = projectInstances.find( inst.m_Path[0] );
862 if( it == projectInstances.end() )
864 projectInstances[ inst.m_Path[0] ] = { inst };
868 it->second.emplace_back( inst );
872 for(
auto& [uuid, instances] : projectInstances )
874 wxCHECK2( instances.size(),
continue );
877 std::sort( instances.begin(), instances.end(),
880 return aLhs.m_Path < aRhs.m_Path;
883 projectName = instances[0].m_ProjectName;
885 m_out->
Print( aNestLevel + 2,
"(project %s\n",
893 if( aForClipboard && aRelativePath )
900 m_out->
Print( aNestLevel + 4,
"(reference %s) (unit %d)\n",
918 wxCHECK_RET( aField !=
nullptr &&
m_out !=
nullptr,
"" );
924 if( aField->
GetId() == -1 )
928 if( !aField->
GetName().IsEmpty() )
939 m_out->
Print( aNestLevel,
"(property %s %s (at %s %s %s)",
970 wxCHECK_RET(
m_out !=
nullptr,
"" );
977 wxCHECK_RET(
image !=
nullptr,
"wxImage* is NULL" );
979 m_out->
Print( aNestLevel,
"(image (at %s %s)",
1007#define MIME_BASE64_LENGTH 76
1011 while( first < out.Length() )
1027 wxCHECK_RET( aSheet !=
nullptr &&
m_out !=
nullptr,
"" );
1029 m_out->
Print( aNestLevel,
"(sheet (at %s %s) (size %s %s)",
1045 m_out->
Print( 0,
" (fields_autoplaced yes)" );
1056 m_out->
Print( aNestLevel + 1,
"(fill (color %d %d %d %0.4f))\n",
1073 m_out->
Print( aNestLevel + 1,
"(pin %s %s (at %s %s %s)\n",
1077 pin->GetPosition().x ).c_str(),
1079 pin->GetPosition().y ).c_str(),
1082 pin->Format(
m_out, aNestLevel + 1, 0 );
1090 std::vector< SCH_SHEET_INSTANCE > sheetInstances = aSheet->
GetInstances();
1092 auto it = sheetInstances.begin();
1094 while( it != sheetInstances.end() )
1096 if( it->m_Path.size() == 0 )
1097 it = sheetInstances.erase( it );
1102 if( !sheetInstances.empty() )
1104 m_out->
Print( aNestLevel + 1,
"(instances\n" );
1106 KIID lastProjectUuid;
1108 bool project_open =
false;
1110 for(
size_t i = 0; i < sheetInstances.size(); i++ )
1117 if( ( sheetInstances[i].m_Path[0] == rootSheetUuid )
1120 if( project_open && ( ( i + 1 == sheetInstances.size() )
1121 || lastProjectUuid != sheetInstances[i+1].m_Path[0] ) )
1124 project_open =
false;
1130 if( lastProjectUuid != sheetInstances[i].m_Path[0] )
1132 wxString projectName;
1134 if( sheetInstances[i].m_Path[0] == rootSheetUuid )
1137 projectName = sheetInstances[i].m_ProjectName;
1139 lastProjectUuid = sheetInstances[i].m_Path[0];
1140 m_out->
Print( aNestLevel + 2,
"(project %s\n",
1142 project_open =
true;
1145 wxString
path = sheetInstances[i].m_Path.AsString();
1147 m_out->
Print( aNestLevel + 3,
"(path %s (page %s))\n",
1149 m_out->
Quotew( sheetInstances[i].m_PageNumber ).c_str() );
1151 if( project_open && ( ( i + 1 == sheetInstances.size() )
1152 || lastProjectUuid != sheetInstances[i+1].m_Path[0] ) )
1155 project_open =
false;
1168 wxCHECK_RET( aJunction !=
nullptr &&
m_out !=
nullptr,
"" );
1170 m_out->
Print( aNestLevel,
"(junction (at %s %s) (diameter %s) (color %d %d %d %s)\n",
1190 wxCHECK_RET( aNoConnect !=
nullptr &&
m_out !=
nullptr,
"" );
1192 m_out->
Print( aNestLevel,
"(no_connect (at %s %s)",
1204 wxCHECK_RET( aBusEntry !=
nullptr &&
m_out !=
nullptr,
"" );
1207 if( aBusEntry->
GetClass() ==
"SCH_BUS_BUS_ENTRY" )
1212 saveLine( &busEntryLine, aNestLevel );
1216 m_out->
Print( aNestLevel,
"(bus_entry (at %s %s) (size %s %s)\n",
1224 aBusEntry->
GetSize().
y ).c_str() );
1239 wxCHECK_RET( aShape !=
nullptr &&
m_out !=
nullptr,
"" );
1248 case SHAPE_T::CIRCLE:
1253 case SHAPE_T::RECTANGLE:
1258 case SHAPE_T::BEZIER:
1276 wxCHECK_RET( aRuleArea !=
nullptr &&
m_out !=
nullptr,
"" );
1286 wxCHECK_RET( aLine !=
nullptr &&
m_out !=
nullptr,
"" );
1294 case LAYER_BUS: lineType =
"bus";
break;
1301 m_out->
Print( aNestLevel,
"(%s (pts (xy %s %s) (xy %s %s))\n",
1323 wxCHECK_RET( aText !=
nullptr &&
m_out !=
nullptr,
"" );
1342 flag->GetPinLength() ).c_str() );
1368 if( aText->
GetText().Length() < 50 )
1380 m_out->
Print( aNestLevel + 1,
"(at %s %s %s)",
1389 m_out->
Print( 0,
" (fields_autoplaced yes)" );
1392 aText->EDA_TEXT::Format(
m_out, aNestLevel, 0 );
1408 wxCHECK_RET( aTextBox !=
nullptr &&
m_out !=
nullptr,
"" );
1417 m_out->
Print( aNestLevel + 1,
"(exclude_from_sim %s) (at %s %s %s) (size %s %s) (margins %s %s %s %s)",
1430 m_out->
Print( 0,
" (span %d %d)", cell->GetColSpan(), cell->GetRowSpan() );
1443 aTextBox->EDA_TEXT::Format(
m_out, aNestLevel, 0 );
1463 for(
int row = 0; row < aTable->
GetRowCount(); ++row )
1465 for(
int col = 0; col < aTable->
GetColCount(); ++col )
1471 minRow = std::min( minRow, row );
1472 maxRow = std::max( maxRow, row );
1473 minCol = std::min( minCol, col );
1474 maxCol = std::max( maxCol, col );
1483 wxCHECK_MSG( maxCol >= minCol && maxRow >= minRow, , wxT(
"No selected cells!" ) );
1487 for(
int row = minRow; row <= maxRow; row++ )
1492 for(
int col = minCol; col <= maxCol; col++ )
1499 wxCHECK_RET( aTable !=
nullptr &&
m_out !=
nullptr,
"" );
1501 m_out->
Print( aNestLevel,
"(table (column_count %d)\n",
1504 m_out->
Print( aNestLevel + 1,
"(border (external %s) (header %s)",
1516 m_out->
Print( aNestLevel + 1,
"(separators (rows %s) (cols %s)",
1528 m_out->
Print( aNestLevel + 1,
"(column_widths" );
1530 for(
int col = 0; col < aTable->
GetColCount(); ++col )
1539 m_out->
Print( aNestLevel + 1,
"(row_heights" );
1541 for(
int row = 0; row < aTable->
GetRowCount(); ++row )
1565 wxCHECK_RET( aAlias !=
nullptr,
"BUS_ALIAS* is NULL" );
1569 for(
const wxString& member : aAlias->Members() )
1571 if( !members.IsEmpty() )
1572 members += wxS(
" " );
1577 m_out->
Print( aNestLevel,
"(bus_alias %s (members %s))\n",
1586 if( aInstances.size() )
1589 m_out->
Print( aNestLevel,
"(sheet_instances\n" );
1593 wxString
path = instance.m_Path.AsString();
1595 if(
path.IsEmpty() )
1598 m_out->
Print( aNestLevel + 1,
"(path %s (page %s))\n",
1609 const std::map<std::string, UTF8>* aProperties )
1643 const wxString& aLibraryPath,
1644 const std::map<std::string, UTF8>* aProperties )
1648 bool powerSymbolsOnly = ( aProperties &&
1651 cacheLib( aLibraryPath, aProperties );
1655 for( LIB_SYMBOL_MAP::const_iterator it = symbols.begin(); it != symbols.end(); ++it )
1657 if( !powerSymbolsOnly || it->second->IsPower() )
1658 aSymbolNameList.Add( it->first );
1664 const wxString& aLibraryPath,
1665 const std::map<std::string, UTF8>* aProperties )
1669 bool powerSymbolsOnly = ( aProperties &&
1672 cacheLib( aLibraryPath, aProperties );
1676 for( LIB_SYMBOL_MAP::const_iterator it = symbols.begin(); it != symbols.end(); ++it )
1678 if( !powerSymbolsOnly || it->second->IsPower() )
1679 aSymbolList.push_back( it->second );
1685 const wxString& aSymbolName,
1686 const std::map<std::string, UTF8>* aProperties )
1690 cacheLib( aLibraryPath, aProperties );
1692 LIB_SYMBOL_MAP::const_iterator it =
m_cache->
m_symbols.find( aSymbolName );
1698 if( it ==
m_cache->
m_symbols.end() && aSymbolName.Contains( wxT(
"{slash}" ) ) )
1700 wxString unescaped = aSymbolName;
1701 unescaped.Replace( wxT(
"{slash}" ), wxT(
"/" ) );
1713 const std::map<std::string, UTF8>* aProperties )
1717 cacheLib( aLibraryPath, aProperties );
1727 const std::map<std::string, UTF8>* aProperties )
1731 cacheLib( aLibraryPath, aProperties );
1741 const std::map<std::string, UTF8>* aProperties )
1743 if( wxFileExists( aLibraryPath ) )
1745 THROW_IO_ERROR( wxString::Format(
_(
"Symbol library '%s' already exists." ),
1746 aLibraryPath.GetData() ) );
1760 const std::map<std::string, UTF8>* aProperties )
1762 wxFileName fn = aLibraryPath;
1764 if( !fn.FileExists() )
1769 if( wxRemove( aLibraryPath ) )
1771 THROW_IO_ERROR( wxString::Format(
_(
"Symbol library '%s' cannot be deleted." ),
1772 aLibraryPath.GetData() ) );
1786 const std::map<std::string, UTF8>* aProperties )
1807 wxFileName fn( aLibraryPath );
1809 if( fn.FileExists() )
1810 return fn.IsFileWritable();
1812 return fn.IsDirWritable();
1823 std::set<wxString> fieldNames;
1825 for( LIB_SYMBOL_MAP::const_iterator it = symbols.begin(); it != symbols.end(); ++it )
1827 std::vector<SCH_FIELD*> fields;
1828 it->second->GetFields( fields );
1832 if( field->IsMandatory() )
1837 fieldNames.insert( field->GetName() );
1841 std::copy( fieldNames.begin(), fieldNames.end(), std::back_inserter( aNames ) );
1852 std::string aSource,
1859 std::vector<LIB_SYMBOL*> newSymbols;
1860 std::unique_ptr<STRING_LINE_READER> reader = std::make_unique<STRING_LINE_READER>( aSymbolText,
1867 newSymbol = parser.
ParseSymbol( map, aFileVersion );
1870 newSymbols.emplace_back( newSymbol );
constexpr EDA_IU_SCALE schIUScale
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
wxString GetMajorMinorVersion()
Get only the major and minor version in a string major.minor.
This class handle bitmap images in KiCad.
const wxMemoryBuffer & GetImageDataBuffer() const
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 void SetParent(EDA_ITEM *aParent)
EDA_ITEM * GetParent() const
EDA_ITEM_FLAGS GetFlags() const
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
int GetTextHeight() const
bool IsDefaultFormatting() const
const EDA_ANGLE & GetTextAngle() const
virtual const wxString & GetText() const
Return the string associated with the text object.
virtual void Format(OUTPUTFORMATTER *aFormatter, int aNestLevel, int aControlBits) const
Output the object to aFormatter in s-expression form.
EE_TYPE OfType(KICAD_T aType) const
void WriteEmbeddedFiles(OUTPUTFORMATTER &aOut, int aNestLevel, bool aWriteData) const
Output formatter for the embedded files.
void ClearEmbeddedFonts()
Removes all embedded fonts from the collection.
bool GetAreFontsEmbedded() const
A LINE_READER that reads from an open file.
void Rewind()
Rewind the file and resets the line number back to zero.
char * ReadLine() override
Read a line of text into the buffer and increments the line number counter.
PROGRESS_REPORTER * m_progressReporter
Progress reporter to track the progress of the operation, may be nullptr.
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()
bool MakeRelativeTo(const KIID_PATH &aPath)
wxString AsString() const
Define a library symbol object.
An abstract class from which implementation specific LINE_READERs may be derived to read single lines...
Instantiate the current locale within a scope in which you are expecting exceptions to be thrown.
void Format(OUTPUTFORMATTER *aFormatter, int aNestLevel, int aControlBits) const
Output the page class to aFormatter in s-expression form.
virtual bool KeepRefreshing(bool aWait=false)=0
Update the UI (if any).
virtual void Report(const wxString &aMessage)=0
Display aMessage in the progress bar dialog.
virtual const wxString GetProjectPath() const
Return the full path of the project.
virtual const wxString GetProjectName() const
Return the short name of the project.
A REFERENCE_IMAGE is a wrapper around a BITMAP_IMAGE that is displayed in an editor as a reference fo...
VECTOR2I GetPosition() const
const BITMAP_BASE & GetImage() const
Get the underlying image.
double GetImageScale() const
Holds all the data relating to one schematic.
void EmbedFonts() override
Embed fonts in the schematic.
SCH_SHEET_LIST Hierarchy() const override
Return the full schematic flattened hierarchical sheet list.
EMBEDDED_FILES * GetEmbeddedFiles() override
bool IsValid() const
A simple test if the schematic is loaded, not a complete one.
PROJECT & Prj() const override
Return a reference to the project this schematic is part of.
Object to handle a bitmap image that can be inserted in a schematic.
REFERENCE_IMAGE & GetReferenceImage()
Base class for a bus or wire entry.
VECTOR2I GetPosition() const override
virtual STROKE_PARAMS GetStroke() const override
Instances are attached to a symbol or sheet and provide a place for the symbol's value,...
VECTOR2I GetPosition() const override
wxString GetCanonicalName() const
Get a non-language-specific name for a field which can be used for storage, variable look-up,...
wxString GetName(bool aUseDefaultName=true) const
Return the field name (not translated).
bool CanAutoplace() const
A cache assistant for the KiCad s-expression symbol libraries.
static void SaveSymbol(LIB_SYMBOL *aSymbol, OUTPUTFORMATTER &aFormatter, int aNestLevel=0, const wxString &aLibName=wxEmptyString, bool aIncludeData=true)
void DeleteSymbol(const wxString &aName) override
void Save(const std::optional< bool > &aOpt=std::nullopt) override
Save the entire library to file m_libFileName;.
Object to parser s-expression symbol library and schematic file formats.
void ParseSchematic(SCH_SHEET *aSheet, bool aIsCopyablyOnly=false, int aFileVersion=SEXPR_SCHEMATIC_FILE_VERSION)
Parse the internal LINE_READER object into aSheet.
LIB_SYMBOL * ParseSymbol(LIB_SYMBOL_MAP &aSymbolLibMap, int aFileVersion=SEXPR_SYMBOL_LIB_FILE_VERSION)
Parse internal LINE_READER object into symbols and return all found.
wxString m_path
Root project path for loading child sheets.
void GetDefaultSymbolFields(std::vector< wxString > &aNames) override
Retrieves a list of (custom) field names that should be shown by default for this library in the symb...
void saveBusEntry(SCH_BUS_ENTRY_BASE *aBusEntry, int aNestLevel)
void SaveSchematicFile(const wxString &aFileName, SCH_SHEET *aSheet, SCHEMATIC *aSchematic, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Write aSchematic to a storage file in a format that this SCH_IO implementation knows about,...
void SaveLibrary(const wxString &aLibraryPath, const std::map< std::string, UTF8 > *aProperties=nullptr) override
SCH_SHEET_PATH m_currentSheetPath
void saveRuleArea(SCH_RULE_AREA *aRuleArea, int aNestLevel)
void LoadContent(LINE_READER &aReader, SCH_SHEET *aSheet, int aVersion=SEXPR_SCHEMATIC_FILE_VERSION)
void EnumerateSymbolLib(wxArrayString &aSymbolNameList, const wxString &aLibraryPath, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Populate a list of LIB_SYMBOL alias names contained within the library aLibraryPath.
void saveText(SCH_TEXT *aText, int aNestLevel)
bool m_appending
Schematic load append status.
int m_version
Version of file being loaded.
void loadFile(const wxString &aFileName, SCH_SHEET *aSheet)
static void FormatLibSymbol(LIB_SYMBOL *aPart, OUTPUTFORMATTER &aFormatter)
void DeleteSymbol(const wxString &aLibraryPath, const wxString &aSymbolName, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Delete the entire LIB_SYMBOL associated with aAliasName from the library aLibraryPath.
void loadHierarchy(const SCH_SHEET_PATH &aParentSheetPath, SCH_SHEET *aSheet)
void SaveSymbol(const wxString &aLibraryPath, const LIB_SYMBOL *aSymbol, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Write aSymbol to an existing library located at aLibraryPath.
static std::vector< LIB_SYMBOL * > ParseLibSymbols(std::string &aSymbolText, std::string aSource, int aFileVersion=SEXPR_SCHEMATIC_FILE_VERSION)
void saveField(SCH_FIELD *aField, int aNestLevel)
OUTPUTFORMATTER * m_out
The formatter for saving SCH_SCREEN objects.
SCH_SHEET * LoadSchematicFile(const wxString &aFileName, SCHEMATIC *aSchematic, SCH_SHEET *aAppendToMe=nullptr, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Load information from some input file format that this SCH_IO implementation knows about,...
void saveBusAlias(std::shared_ptr< BUS_ALIAS > aAlias, int aNestLevel)
LIB_SYMBOL * LoadSymbol(const wxString &aLibraryPath, const wxString &aAliasName, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Load a LIB_SYMBOL object having aPartName from the aLibraryPath containing a library format that this...
wxString m_error
For throwing exceptions or errors on partial loads.
bool isBuffering(const std::map< std::string, UTF8 > *aProperties)
static const char * PropBuffering
The property used internally by the plugin to enable cache buffering which prevents the library file ...
void saveBitmap(const SCH_BITMAP &aBitmap, int aNestLevel)
SCH_SHEET * m_rootSheet
The root sheet of the schematic being loaded.
void cacheLib(const wxString &aLibraryFileName, const std::map< std::string, UTF8 > *aProperties)
SCH_IO_KICAD_SEXPR_LIB_CACHE * m_cache
void Format(SCH_SHEET *aSheet)
bool IsLibraryWritable(const wxString &aLibraryPath) override
Return true if the library at aLibraryPath is writable.
void saveSymbol(SCH_SYMBOL *aSymbol, const SCHEMATIC &aSchematic, const SCH_SHEET_LIST &aSheetList, int aNestLevel, bool aForClipboard, const SCH_SHEET_PATH *aRelativePath=nullptr)
void init(SCHEMATIC *aSchematic, const std::map< std::string, UTF8 > *aProperties=nullptr)
initialize PLUGIN like a constructor would.
bool DeleteLibrary(const wxString &aLibraryPath, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Delete an existing library and returns true, or if library does not exist returns false,...
void saveNoConnect(SCH_NO_CONNECT *aNoConnect, int aNestLevel)
void saveShape(SCH_SHAPE *aShape, int aNestLevel)
int GetModifyHash() const override
Return the modification hash from the library cache.
void saveJunction(SCH_JUNCTION *aJunction, int aNestLevel)
void saveTextBox(SCH_TEXTBOX *aText, int aNestLevel)
void saveInstances(const std::vector< SCH_SHEET_INSTANCE > &aSheets, int aNestLevel)
void saveSheet(SCH_SHEET *aSheet, const SCH_SHEET_LIST &aSheetList, int aNestLevel)
virtual ~SCH_IO_KICAD_SEXPR()
void saveLine(SCH_LINE *aLine, int aNestLevel)
std::stack< wxString > m_currentPath
Stack to maintain nested sheet paths.
void CreateLibrary(const wxString &aLibraryPath, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Create a new empty library at aLibraryPath empty.
void saveTable(SCH_TABLE *aTable, int aNestLevel)
void GetAvailableSymbolFields(std::vector< wxString > &aNames) override
Retrieves a list of (custom) field names that are present on symbols in this library.
bool IsFile(const wxString &aFullPathAndFileName) const
void SetFileName(const wxString &aFileName)
virtual void AddSymbol(const LIB_SYMBOL *aSymbol)
bool IsFileChanged() const
wxString GetFileName() const
void SetModified(bool aModified=true)
Base class that schematic file and library loading and saving plugins should derive from.
Base class for any item which can be embedded within the SCHEMATIC container class,...
SCH_LAYER_ID GetLayer() const
Return the layer this item is on.
FIELDS_AUTOPLACED GetFieldsAutoplaced() const
Return whether the fields have been automatically placed.
wxString GetClass() const override
Return the class name.
VECTOR2I GetPosition() const override
SPIN_STYLE GetSpinStyle() const
LABEL_FLAG_SHAPE GetShape() const
std::vector< SCH_FIELD > & GetFields()
Segment description base class to describe items which have 2 end points (track, wire,...
virtual STROKE_PARAMS GetStroke() const override
VECTOR2I GetEndPoint() const
VECTOR2I GetStartPoint() const
void SetEndPoint(const VECTOR2I &aPosition)
VECTOR2I GetPosition() const override
const PAGE_INFO & GetPageSettings() const
auto & GetBusAliases() const
Return a set of bus aliases defined in this screen.
const std::map< wxString, LIB_SYMBOL * > & GetLibSymbols() const
Fetch a list of unique LIB_SYMBOL object pointers required to properly render each SCH_SYMBOL in this...
EE_RTREE & Items()
Gets the full RTree, usually for iterating.
const wxString & GetFileName() const
void SetFileName(const wxString &aFileName)
Set the file name for this screen to aFileName.
const TITLE_BLOCK & GetTitleBlock() const
KIID m_uuid
A unique identifier for each schematic file.
void SetFileReadOnly(bool aIsReadOnly)
void SetFileExists(bool aFileExists)
STROKE_PARAMS GetStroke() const override
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
std::optional< SCH_SHEET_PATH > GetSheetPathByKIIDPath(const KIID_PATH &aPath, bool aIncludeLastSheet=true) const
Finds a SCH_SHEET_PATH that matches the provided KIID_PATH.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
bool empty() const
Forwarded method from std::vector.
KIID_PATH Path() const
Get the sheet path as an KIID_PATH.
SCH_SCREEN * LastScreen()
SCH_SHEET * at(size_t aIndex) const
Forwarded method from std::vector.
void push_back(SCH_SHEET *aSheet)
Forwarded method from std::vector.
void pop_back()
Forwarded method from std::vector.
Define a sheet pin (label) used in sheets to create hierarchical schematics.
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
bool GetExcludedFromBOM() const
wxString GetFileName() const
Return the filename corresponding to this sheet.
bool HasRootInstance() const
Check to see if this sheet has a root sheet instance.
std::vector< SCH_FIELD > & GetFields()
bool GetExcludedFromBoard() const
bool SearchHierarchy(const wxString &aFilename, SCH_SCREEN **aScreen)
Search the existing hierarchy for an instance of screen loaded from aFileName.
SCH_SCREEN * GetScreen() const
VECTOR2I GetPosition() const override
void SetScreen(SCH_SCREEN *aScreen)
Set the SCH_SCREEN associated with this sheet to aScreen.
const SCH_SHEET_INSTANCE & GetRootInstance() const
Return the root sheet instance data.
KIGFX::COLOR4D GetBorderColor() const
bool GetExcludedFromSim() const override
int GetBorderWidth() const
std::vector< SCH_SHEET_PIN * > & GetPins()
const std::vector< SCH_SHEET_INSTANCE > & GetInstances() const
bool GetDNP() const
Set or clear the 'Do Not Populate' flaga.
KIGFX::COLOR4D GetBackgroundColor() const
std::vector< std::unique_ptr< SCH_PIN > > & GetRawPins()
const std::vector< SCH_SYMBOL_INSTANCE > & GetInstances() const
bool UseLibIdLookup() const
wxString GetSchSymbolLibraryName() const
SCH_FIELD * GetField(MANDATORY_FIELD_T aFieldType)
Return a mandatory field in this symbol.
VECTOR2I GetPosition() const override
const LIB_ID & GetLibId() const override
bool GetInstance(SCH_SYMBOL_INSTANCE &aInstance, const KIID_PATH &aSheetPath, bool aTestFromEnd=false) const
int GetOrientation() const
Get the display symbol orientation.
void GetFields(std::vector< SCH_FIELD * > &aVector, bool aVisibleOnly)
Populate a std::vector with SCH_FIELDs.
void SetRowHeight(int aRow, int aHeight)
const STROKE_PARAMS & GetSeparatorsStroke() const
void SetColCount(int aCount)
bool StrokeExternal() const
int GetRowHeight(int aRow) const
void SetColWidth(int aCol, int aWidth)
std::vector< SCH_TABLECELL * > GetCells() const
int GetColWidth(int aCol) const
const STROKE_PARAMS & GetBorderStroke() const
SCH_TABLECELL * GetCell(int aRow, int aCol) const
bool StrokeColumns() const
EDA_ITEM * Clone() const override
Create a duplicate of this item with linked list members set to NULL.
bool StrokeHeader() const
int GetMarginBottom() const
int GetMarginLeft() const
bool GetExcludedFromSim() const override
int GetMarginRight() const
VECTOR2I GetPosition() const override
bool GetExcludedFromSim() const override
virtual KIGFX::VIEW_ITEM * GetItem(unsigned int aIdx) const override
virtual unsigned int GetSize() const override
Return the number of stored items.
Is a LINE_READER that reads from a multiline 8 bit wide std::string.
Simple container to manage line stroke parameters.
void SetWidth(int aWidth)
void Format(OUTPUTFORMATTER *out, const EDA_IU_SCALE &aIuScale, int nestLevel) const
static const char * PropPowerSymsOnly
bool GetExcludedFromBoard() const
bool GetExcludedFromBOM() const
bool GetDNP() const
Set or clear the 'Do Not Populate' flaga.
bool GetExcludedFromSim() const override
virtual void Format(OUTPUTFORMATTER *aFormatter, int aNestLevel, int aControlBits) const
Output the object to aFormatter in s-expression form.
static REPORTER & GetInstance()
static void SetReporter(REPORTER *aReporter)
Set the reporter to use for reporting font substitution warnings.
#define MIME_BASE64_LENGTH
static constexpr EDA_ANGLE ANGLE_0
static constexpr EDA_ANGLE ANGLE_90
static constexpr EDA_ANGLE ANGLE_270
static constexpr EDA_ANGLE ANGLE_180
#define STRUCT_DELETED
flag indication structures to be erased
#define SKIP_STRUCT
flag indicating that the structure should be ignored
#define DEFAULT_SIZE_TEXT
This is the "default-of-the-default" hardcoded text size; individual application define their own def...
const wxChar *const traceSchPlugin
Flag to enable legacy schematic plugin debug output.
#define THROW_IO_ERROR(msg)
wxString LayerName(int aLayer)
Returns the default display name for a given layer.
SCH_LAYER_ID
Eeschema drawing layers.
#define UNIMPLEMENTED_FOR(type)
KICOMMON_API std::string FormatInternalUnits(const EDA_IU_SCALE &aIuScale, int aValue)
Converts aValue from internal units to a string appropriate for writing to file.
KICOMMON_API std::string FormatAngle(const EDA_ANGLE &aAngle)
Converts aAngle from board units to a string appropriate for writing to file.
#define SEXPR_SCHEMATIC_FILE_VERSION
Schematic file version.
const char * getSheetPinShapeToken(LABEL_FLAG_SHAPE aShape)
void formatArc(OUTPUTFORMATTER *aFormatter, int aNestLevel, EDA_SHAPE *aArc, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
void formatFill(OUTPUTFORMATTER *aFormatter, int aNestLevel, FILL_T aFillMode, const COLOR4D &aFillColor)
Fill token formatting helper.
const char * getTextTypeToken(KICAD_T aType)
void formatCircle(OUTPUTFORMATTER *aFormatter, int aNestLevel, EDA_SHAPE *aCircle, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
void formatBezier(OUTPUTFORMATTER *aFormatter, int aNestLevel, EDA_SHAPE *aBezier, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
void formatRect(OUTPUTFORMATTER *aFormatter, int aNestLevel, EDA_SHAPE *aRect, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
void formatPoly(OUTPUTFORMATTER *aFormatter, int aNestLevel, EDA_SHAPE *aPolyLine, bool aIsPrivate, const STROKE_PARAMS &aStroke, FILL_T aFillMode, const COLOR4D &aFillColor, bool aInvertY, const KIID &aUuid)
EDA_ANGLE getSheetPinAngle(SHEET_SIDE aSide)
@ SHEET_MANDATORY_FIELDS
The first 2 are mandatory, and must be instantiated in SCH_SHEET.
std::string toUTFTildaText(const wxString &txt)
Convert a wxString to UTF8 and replace any control characters with a ~, where a control character is ...
std::string FormatDouble2Str(double aValue)
Print a float number without using scientific notation and no trailing 0 This function is intended in...
std::string EscapedUTF8(const wxString &aString)
Return an 8 bit UTF8 string given aString in Unicode form.
wxString EscapeString(const wxString &aSource, ESCAPE_CONTEXT aContext)
The Escape/Unescape routines use HTML-entity-reference-style encoding to handle characters which are:...
#define TO_UTF8(wxstring)
Convert a wxString to a UTF8 encoded C string for all wxWidgets build modes.
constexpr int MilsToIU(int mils) const
A simple container for sheet instance information.
A simple container for schematic symbol instance information.
std::map< wxString, LIB_SYMBOL *, LibSymbolMapSort > LIB_SYMBOL_MAP
@ FOOTPRINT_FIELD
Field Name Module PCB, i.e. "16DIP300".
@ VALUE_FIELD
Field Value of part, i.e. "3.3K".
@ MANDATORY_FIELDS
The first 5 are mandatory, and must be instantiated in SCH_COMPONENT and LIB_PART constructors.
@ REFERENCE_FIELD
Field Reference of part, i.e. "IC21".
wxLogTrace helper definitions.
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.