21#include <magic_enum.hpp>
63 wxCHECK( aRow->
plugin && ret,
nullptr );
71 std::lock_guard lock ( aLib->
mutex );
78 wxArrayString dummyList;
112 if( type == SCH_IO_MGR::SCH_FILE_UNKNOWN )
115 wxString msg = wxString::Format(
_(
"Unknown library type %s " ), row->
Type() );
122 plugin->SetLibraryManagerAdapter(
this );
124 wxLogTrace(
traceLibraries,
"Sym: Library %s (%s) plugin created",
134 std::vector<LIB_SYMBOL*> symbols;
136 std::optional<const LIB_DATA*> maybeLib =
fetchIfLoaded( aNickname );
153 wxLogTrace(
traceLibraries,
"Sym: Exception enumerating library %s: %s",
159 LIB_ID id = symbol->GetLibId();
161 symbol->SetLibId(
id );
171 wxArrayString namesAS;
172 std::vector<wxString> names;
174 if( std::optional<const LIB_DATA*> maybeLib =
fetchIfLoaded( aNickname ) )
185 for(
const wxString&
name : namesAS )
186 names.emplace_back(
name );
194 if( std::optional<const LIB_DATA*> lib =
fetchIfLoaded( aNickname ) )
198 LIB_ID id = symbol->GetLibId();
200 symbol->SetLibId(
id );
206 wxLogTrace(
traceLibraries,
"LoadSymbol: requested library %s not loaded", aNickname );
220 if( !libResult.has_value() )
222 wxLogTrace(
traceLibraries,
"SaveSymbol: unable to load library %s: %s",
223 aNickname, libResult.error().message );
231 wxLogTrace(
traceLibraries,
"SaveSymbol: library %s not found", aNickname );
244 std::unique_ptr<LIB_SYMBOL> existing(
plugin->LoadSymbol(
getUri( lib->
row ),
254 "SaveSymbol: error checking for existing symbol %s:%s: %s",
277 wxCHECK_MSG(
false, ,
"Unimplemented!" );
297 [](
const std::future<void>& aFuture ) {
return aFuture.valid(); } );
301 wxLogTrace(
traceLibraries,
"Sym: Cannot AsyncLoad, futures from a previous call remain!" );
312 wxLogTrace(
traceLibraries,
"Sym: AsyncLoad: no libraries left to load; exiting" );
319 [](
const wxString& aLib, std::map<wxString, LIB_DATA>& aMap, std::mutex& aMutex )
321 std::lock_guard lock( aMutex );
323 if( aMap.contains( aLib ) )
336 wxString nickname = row->Nickname();
353 [
this, nickname, scope]()
358 LIBRARY_RESULT<LIB_DATA*> result = loadIfNeeded( nickname );
360 if( result.has_value() )
362 LIB_DATA* lib = *result;
363 wxArrayString dummyList;
364 std::lock_guard lock ( lib->mutex );
365 lib->status.load_status = LOAD_STATUS::LOADING;
367 std::map<std::string, UTF8> options = lib->row->GetOptionsMap();
371 schplugin( lib )->EnumerateSymbolLib( dummyList, getUri( lib->row ), &options );
372 wxLogTrace( traceLibraries,
"Sym: %s: library enumerated %zu items", nickname, dummyList.size() );
373 lib->status.load_status = LOAD_STATUS::LOADED;
377 lib->status.load_status = LOAD_STATUS::LOAD_ERROR;
378 lib->status.error = LIBRARY_ERROR( { e.What() } );
379 wxLogTrace( traceLibraries,
"Sym: %s: plugin threw exception: %s", nickname, e.What() );
386 case LIBRARY_TABLE_SCOPE::GLOBAL:
388 std::lock_guard lock( GlobalLibraryMutex );
390 GlobalLibraries[nickname].status = LIB_STATUS( {
391 .load_status = LOAD_STATUS::LOAD_ERROR,
392 .error = result.error()
398 case LIBRARY_TABLE_SCOPE::PROJECT:
400 wxLogTrace( traceLibraries,
"Sym: project library error: %s: %s", nickname, result.error().message );
401 std::lock_guard lock( m_libraries_mutex );
403 m_libraries[nickname].status = LIB_STATUS( {
404 .load_status = LOAD_STATUS::LOAD_ERROR,
405 .error = result.error()
412 wxFAIL_MSG(
"Unexpected library table scope" );
417 }, BS::pr::lowest ) );
421 wxLogTrace(
traceLibraries,
"Sym: Started async load of %zu libraries", m_loadTotal );
438 const wxString& aNickname )
440 std::vector<wxString> fields;
473 const wxString& aNickname )
const
475 std::vector<SUB_LIBRARY> ret;
480 std::vector<wxString> names;
483 for(
const wxString&
name : names )
499 return ( *result )->plugin->SupportsConfigurationDialog();
506 wxWindow* aParent )
const
508 std::optional<const LIB_DATA*> optRow =
fetchIfLoaded( aNickname );
510 if( !optRow || !( *optRow )->plugin->SupportsConfigurationDialog() )
513 DIALOG_SHIM* dialog = ( *optRow )->plugin->CreateConfigurationDialog( aParent );
527 wxCHECK2( rowData->
row,
continue );
Dialog helper object to sit in the inheritance tree between wxDialog and any class written by wxFormB...
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()
LIBRARY_MANAGER_ADAPTER(LIBRARY_MANAGER &aManager)
Constructs a type-specific adapter into the library manager.
LIBRARY_RESULT< LIB_DATA * > loadIfNeeded(const wxString &aNickname)
Fetches a loaded library, triggering a load of that library if it isn't loaded yet.
std::map< wxString, LIB_DATA > m_libraries
std::vector< std::future< void > > m_futures
static wxString getUri(const LIBRARY_TABLE_ROW *aRow)
std::mutex m_libraries_mutex
std::atomic< size_t > m_loadCount
LIBRARY_MANAGER & m_manager
std::optional< const LIB_DATA * > fetchIfLoaded(const wxString &aNickname) const
LIBRARY_TABLE_SCOPE Scope() const
std::map< std::string, UTF8 > GetOptionsMap() const
const wxString & Type() const
const wxString & Nickname() const
A logical library item identifier and consists of various portions much like a URI.
int SetLibNickname(const UTF8 &aLibNickname)
Override the logical library name portion of the LIB_ID to aLibNickname.
Define a library symbol object.
wxString GetName() const override
static SCH_FILE_T EnumFromStr(const wxString &aFileType)
Return the #SCH_FILE_T from the corresponding plugin type name: "kicad", "legacy",...
Base class that schematic file and library loading and saving plugins should derive from.
virtual void EnumerateSymbolLib(wxArrayString &aSymbolNameList, const wxString &aLibraryPath, const std::map< std::string, UTF8 > *aProperties=nullptr)
Populate a list of LIB_SYMBOL alias names contained within the library aLibraryPath.
virtual bool SupportsSubLibraries() const
virtual int GetModifyHash() const =0
Return the modification hash from the library cache.
virtual void GetAvailableSymbolFields(std::vector< wxString > &aNames)
Retrieves a list of (custom) field names that are present on symbols in this library.
virtual LIB_SYMBOL * LoadSymbol(const wxString &aLibraryPath, const wxString &aPartName, const std::map< std::string, UTF8 > *aProperties=nullptr)
Load a LIB_SYMBOL object having aPartName from the aLibraryPath containing a library format that this...
virtual wxString GetSubLibraryDescription(const wxString &aName)
Gets a description of a sublibrary.
virtual void GetSubLibraryNames(std::vector< wxString > &aNames)
Retrieves a list of sub-libraries in this library.
bool SupportsConfigurationDialog(const wxString &aNickname) const override
std::optional< LIB_STATUS > LoadOne(LIB_DATA *aLib) override
Loads or reloads the given library, if it exists.
static SCH_IO * schplugin(const LIB_DATA *aRow)
Helper to cast the ABC plugin in the LIB_DATA* to a concrete plugin.
LIB_SYMBOL * LoadSymbol(const wxString &aNickname, const wxString &aName)
Load a LIB_SYMBOL having aName from the library given by aNickname.
void DeleteSymbol(const wxString &aNickname, const wxString &aSymbolName)
Deletes the aSymbolName from the library given by aNickname.
std::vector< wxString > GetSymbolNames(const wxString &aNickname, SYMBOL_TYPE aType=SYMBOL_TYPE::ALL_SYMBOLS)
bool SupportsSubLibraries(const wxString &aNickname) const
SAVE_T SaveSymbol(const wxString &aNickname, const LIB_SYMBOL *aSymbol, bool aOverwrite=true)
Write aSymbol to an existing library given by aNickname.
LIBRARY_RESULT< IO_BASE * > createPlugin(const LIBRARY_TABLE_ROW *row) override
Creates a concrete plugin for the given row.
std::vector< SUB_LIBRARY > GetSubLibraries(const wxString &aNickname) const
SYMBOL_LIBRARY_ADAPTER(LIBRARY_MANAGER &aManager)
static wxString GlobalPathEnvVariableName()
int GetModifyHash() const
static const char * PropPowerSymsOnly
LIBRARY_TABLE_TYPE Type() const override
The type of library table this adapter works with.
static std::map< wxString, LIB_DATA > GlobalLibraries
IO_BASE * plugin(const LIB_DATA *aRow) override
std::vector< LIB_SYMBOL * > GetSymbols(const wxString &aNickname, SYMBOL_TYPE aType=SYMBOL_TYPE::ALL_SYMBOLS)
void AsyncLoad() override
Loads all available libraries for this adapter type in the background.
std::vector< wxString > GetAvailableExtraFields(const wxString &aNickname)
Returns a list of additional (non-mandatory) symbol fields present in the given library.
void ShowConfigurationDialog(const wxString &aNickname, wxWindow *aParent) const override
SAVE_T
The set of return values from SaveSymbol() below.
static const char * PropNonPowerSymsOnly
std::optional< LIB_STATUS > GetLibraryStatus(const wxString &aNickname) const override
Returns the status of a loaded library, or nullopt if the library hasn't been loaded (yet)
bool IsSymbolLibWritable(const wxString &aNickname)
Return true if the library given by aNickname is writable.
static std::mutex GlobalLibraryMutex
Functions related to environment variables, including help functions.
const wxChar *const traceLibraries
Flag to enable library table and library manager tracing.
tl::expected< ResultType, LIBRARY_ERROR > LIBRARY_RESULT
KICOMMON_API wxString GetVersionedEnvVarName(const wxString &aBaseName)
Construct a versioned environment variable based on this KiCad major version.
Storage for an actual loaded library (including library content owned by the plugin)
std::vector< wxString > available_fields_cache
std::unique_ptr< IO_BASE > plugin
const LIBRARY_TABLE_ROW * row
The overall status of a loaded or loading library.
std::optional< LIBRARY_ERROR > error
A descriptor for a sub-library (supported by database and http libraries)
wxString result
Test unit parsing edge cases and error handling.
thread_pool & GetKiCadThreadPool()
Get a reference to the current thread pool.
BS::priority_thread_pool thread_pool
wxLogTrace helper definitions.