21#include <magic_enum.hpp>
63 wxCHECK( aRow->
plugin && ret,
nullptr );
71 std::lock_guard lock ( aLib->
mutex );
78 wxArrayString dummyList;
110 if( type == SCH_IO_MGR::SCH_FILE_UNKNOWN )
113 wxString msg = wxString::Format(
_(
"Unknown library type %s " ), row->
Type() );
120 plugin->SetLibraryManagerAdapter(
this );
123 magic_enum::enum_name( row->
Scope() ) );
131 std::vector<LIB_SYMBOL*> symbols;
133 std::optional<const LIB_DATA*> maybeLib =
fetchIfLoaded( aNickname );
155 LIB_ID id = symbol->GetLibId();
157 symbol->SetLibId(
id );
167 wxArrayString namesAS;
168 std::vector<wxString> names;
170 if( std::optional<const LIB_DATA*> maybeLib =
fetchIfLoaded( aNickname ) )
181 for(
const wxString&
name : namesAS )
182 names.emplace_back(
name );
190 if( std::optional<const LIB_DATA*> lib =
fetchIfLoaded( aNickname ) )
194 LIB_ID id = symbol->GetLibId();
196 symbol->SetLibId(
id );
202 wxLogTrace(
traceLibraries,
"LoadSymbol: requested library %s not loaded", aNickname );
216 if( !libResult.has_value() )
218 wxLogTrace(
traceLibraries,
"SaveSymbol: unable to load library %s: %s", aNickname,
219 libResult.error().message );
227 wxLogTrace(
traceLibraries,
"SaveSymbol: library %s not found", aNickname );
248 wxLogTrace(
traceLibraries,
"SaveSymbol: error checking for existing symbol %s:%s: %s", aNickname,
270 wxCHECK_MSG(
false, ,
"Unimplemented!" );
290 [](
const std::future<void>& aFuture )
292 return aFuture.valid();
297 wxLogTrace(
traceLibraries,
"Sym: Cannot AsyncLoad, futures from a previous call remain!" );
308 wxLogTrace(
traceLibraries,
"Sym: AsyncLoad: no libraries left to load; exiting" );
315 [](
const wxString& aLib, std::map<wxString, LIB_DATA>& aMap, std::mutex& aMutex )
317 std::lock_guard lock( aMutex );
319 if( aMap.contains( aLib ) )
332 wxString nickname = row->Nickname();
349 [
this, nickname, scope]()
354 LIBRARY_RESULT<LIB_DATA*> result = loadIfNeeded( nickname );
356 if( result.has_value() )
358 LIB_DATA* lib = *result;
359 wxArrayString dummyList;
360 std::lock_guard lock ( lib->mutex );
361 lib->status.load_status = LOAD_STATUS::LOADING;
363 std::map<std::string, UTF8> options = lib->row->GetOptionsMap();
367 schplugin( lib )->EnumerateSymbolLib( dummyList, getUri( lib->row ), &options );
368 wxLogTrace( traceLibraries,
"Sym: %s: library enumerated %zu items", nickname,
370 lib->status.load_status = LOAD_STATUS::LOADED;
374 lib->status.load_status = LOAD_STATUS::LOAD_ERROR;
375 lib->status.error = LIBRARY_ERROR( { e.What() } );
376 wxLogTrace( traceLibraries,
"Sym: %s: plugin threw exception: %s", nickname, e.What() );
383 case LIBRARY_TABLE_SCOPE::GLOBAL:
385 std::lock_guard lock( GlobalLibraryMutex );
387 GlobalLibraries[nickname].status = LIB_STATUS( { .load_status = LOAD_STATUS::LOAD_ERROR,
388 .error = result.error() } );
393 case LIBRARY_TABLE_SCOPE::PROJECT:
395 wxLogTrace( traceLibraries,
"Sym: project library error: %s: %s", nickname,
396 result.error().message );
397 std::lock_guard lock( m_libraries_mutex );
399 m_libraries[nickname].status = LIB_STATUS( { .load_status = LOAD_STATUS::LOAD_ERROR,
400 .error = result.error() } );
406 wxFAIL_MSG(
"Unexpected library table scope" );
411 }, BS::pr::lowest ) );
415 wxLogTrace(
traceLibraries,
"Sym: Started async load of %zu libraries", m_loadTotal );
433 std::vector<wxString> fields;
467 std::vector<SUB_LIBRARY> ret;
472 std::vector<wxString> names;
475 for(
const wxString&
name : names )
489 return ( *result )->plugin->SupportsConfigurationDialog();
497 std::optional<const LIB_DATA*> optRow =
fetchIfLoaded( aNickname );
499 if( !optRow || !( *optRow )->plugin->SupportsConfigurationDialog() )
502 DIALOG_SHIM* dialog = ( *optRow )->plugin->CreateConfigurationDialog( aParent );
516 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.