Move to explicit symbol properties mapping
Fixes https://gitlab.com/kicad/code/kicad/-/issues/12845
This commit is contained in:
parent
39774463db
commit
c07477b94c
|
@ -29,7 +29,7 @@
|
||||||
#include <wildcards_and_files_ext.h>
|
#include <wildcards_and_files_ext.h>
|
||||||
|
|
||||||
|
|
||||||
const int dblibSchemaVersion = 0;
|
const int dblibSchemaVersion = 1;
|
||||||
|
|
||||||
|
|
||||||
DATABASE_LIB_SETTINGS::DATABASE_LIB_SETTINGS( const std::string& aFilename ) :
|
DATABASE_LIB_SETTINGS::DATABASE_LIB_SETTINGS( const std::string& aFilename ) :
|
||||||
|
@ -48,71 +48,131 @@ DATABASE_LIB_SETTINGS::DATABASE_LIB_SETTINGS( const std::string& aFilename ) :
|
||||||
m_params.emplace_back( new PARAM<int>( "source.timeout_seconds", &m_Source.timeout, 2 ) );
|
m_params.emplace_back( new PARAM<int>( "source.timeout_seconds", &m_Source.timeout, 2 ) );
|
||||||
|
|
||||||
m_params.emplace_back( new PARAM_LAMBDA<nlohmann::json>(
|
m_params.emplace_back( new PARAM_LAMBDA<nlohmann::json>(
|
||||||
"libraries",
|
"libraries",
|
||||||
[&]() -> nlohmann::json
|
[&]() -> nlohmann::json
|
||||||
{
|
{
|
||||||
// TODO: implement this; libraries are read-only from KiCad at the moment
|
// TODO: implement this; libraries are read-only from KiCad at the moment
|
||||||
return {};
|
return {};
|
||||||
},
|
},
|
||||||
[&]( const nlohmann::json aObj )
|
[&]( const nlohmann::json aObj )
|
||||||
{
|
{
|
||||||
m_Tables.clear();
|
m_Tables.clear();
|
||||||
|
|
||||||
if( !aObj.is_array() )
|
if( !aObj.is_array() )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
for( const nlohmann::json& entry : aObj )
|
for( const nlohmann::json& entry : aObj )
|
||||||
|
{
|
||||||
|
if( entry.empty() || !entry.is_object() )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
DATABASE_LIB_TABLE table;
|
||||||
|
|
||||||
|
table.name = entry["name"].get<std::string>();
|
||||||
|
table.table = entry["table"].get<std::string>();
|
||||||
|
table.key_col = entry["key"].get<std::string>();
|
||||||
|
table.symbols_col = entry["symbols"].get<std::string>();
|
||||||
|
table.footprints_col = entry["footprints"].get<std::string>();
|
||||||
|
|
||||||
|
if( entry.contains( "properties" ) && entry["properties"].is_object() )
|
||||||
{
|
{
|
||||||
if( entry.empty() || !entry.is_object() )
|
const nlohmann::json& pj = entry["properties"];
|
||||||
continue;
|
|
||||||
|
|
||||||
DATABASE_LIB_TABLE table;
|
if( pj.contains( "description" ) )
|
||||||
|
table.properties.description = pj["description"].get<std::string>();
|
||||||
|
|
||||||
table.name = entry["name"].get<std::string>();
|
if( pj.contains( "footprint_filters" ) )
|
||||||
table.table = entry["table"].get<std::string>();
|
|
||||||
table.key_col = entry["key"].get<std::string>();
|
|
||||||
table.symbols_col = entry["symbols"].get<std::string>();
|
|
||||||
table.footprints_col = entry["footprints"].get<std::string>();
|
|
||||||
|
|
||||||
if( entry.contains( "fields" ) && entry["fields"].is_array() )
|
|
||||||
{
|
{
|
||||||
for( const nlohmann::json& fieldJson : entry["fields"] )
|
table.properties.footprint_filters =
|
||||||
{
|
pj["footprint_filters"].get<std::string>();
|
||||||
if( fieldJson.empty() || !fieldJson.is_object() )
|
|
||||||
continue;
|
|
||||||
|
|
||||||
std::string column = fieldJson.contains( "column" )
|
|
||||||
? fieldJson["column"].get<std::string>() : "";
|
|
||||||
|
|
||||||
std::string name = fieldJson.contains( "name" )
|
|
||||||
? fieldJson["name"].get<std::string>() : "";
|
|
||||||
|
|
||||||
bool visible_on_add = !fieldJson.contains( "visible_on_add" )
|
|
||||||
|| fieldJson["visible_on_add"].get<bool>();
|
|
||||||
|
|
||||||
bool visible_in_chooser =
|
|
||||||
!fieldJson.contains( "visible_in_chooser" )
|
|
||||||
|| fieldJson["visible_in_chooser"].get<bool>();
|
|
||||||
|
|
||||||
bool show_name = fieldJson.contains( "show_name" )
|
|
||||||
&& fieldJson["show_name"].get<bool>();
|
|
||||||
|
|
||||||
table.fields.emplace_back(
|
|
||||||
DATABASE_FIELD_MAPPING(
|
|
||||||
{
|
|
||||||
column, name, visible_on_add, visible_in_chooser, show_name
|
|
||||||
} ) );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
m_Tables.emplace_back( std::move( table ) );
|
if( pj.contains( "exclude_from_bom" ) )
|
||||||
|
{
|
||||||
|
table.properties.exclude_from_bom =
|
||||||
|
pj["exclude_from_bom"].get<std::string>();
|
||||||
|
}
|
||||||
|
|
||||||
|
if( pj.contains( "exclude_from_board" ) )
|
||||||
|
{
|
||||||
|
table.properties.exclude_from_board =
|
||||||
|
pj["exclude_from_board"].get<std::string>();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
|
||||||
{} ) );
|
if( entry.contains( "fields" ) && entry["fields"].is_array() )
|
||||||
|
{
|
||||||
|
for( const nlohmann::json& fieldJson : entry["fields"] )
|
||||||
|
{
|
||||||
|
if( fieldJson.empty() || !fieldJson.is_object() )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
std::string column = fieldJson.contains( "column" )
|
||||||
|
? fieldJson["column"].get<std::string>() : "";
|
||||||
|
|
||||||
|
std::string name = fieldJson.contains( "name" )
|
||||||
|
? fieldJson["name"].get<std::string>() : "";
|
||||||
|
|
||||||
|
bool visible_on_add = !fieldJson.contains( "visible_on_add" )
|
||||||
|
|| fieldJson["visible_on_add"].get<bool>();
|
||||||
|
|
||||||
|
bool visible_in_chooser =
|
||||||
|
!fieldJson.contains( "visible_in_chooser" )
|
||||||
|
|| fieldJson["visible_in_chooser"].get<bool>();
|
||||||
|
|
||||||
|
bool show_name = fieldJson.contains( "show_name" )
|
||||||
|
&& fieldJson["show_name"].get<bool>();
|
||||||
|
|
||||||
|
table.fields.emplace_back(
|
||||||
|
DATABASE_FIELD_MAPPING(
|
||||||
|
{
|
||||||
|
column, name, visible_on_add, visible_in_chooser, show_name
|
||||||
|
} ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_Tables.emplace_back( std::move( table ) );
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{} ) );
|
||||||
|
|
||||||
m_params.emplace_back( new PARAM<int>( "cache.max_size", &m_Cache.max_size, 256 ) );
|
m_params.emplace_back( new PARAM<int>( "cache.max_size", &m_Cache.max_size, 256 ) );
|
||||||
|
|
||||||
m_params.emplace_back( new PARAM<int>( "cache.max_age", &m_Cache.max_age, 10 ) );
|
m_params.emplace_back( new PARAM<int>( "cache.max_age", &m_Cache.max_age, 10 ) );
|
||||||
|
|
||||||
|
registerMigration( 0, 1,
|
||||||
|
[&]() -> bool
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Schema 0 -> 1
|
||||||
|
* Move internal symbol properties from fields with special names to
|
||||||
|
* a separate place in the schema.
|
||||||
|
*/
|
||||||
|
if( !Contains( "libraries" ) || !At( "libraries" ).is_array() )
|
||||||
|
return true;
|
||||||
|
|
||||||
|
for( nlohmann::json& library : At( "libraries" ) )
|
||||||
|
{
|
||||||
|
if( !library.contains( "fields" ) )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
for( const nlohmann::json& field : library["fields"] )
|
||||||
|
{
|
||||||
|
if( !field.contains( "name" ) || !field.contains( "column" ) )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
std::string name = field["name"].get<std::string>();
|
||||||
|
std::string col = field["column"].get<std::string>();
|
||||||
|
|
||||||
|
if( name == "ki_description" )
|
||||||
|
library["properties"]["description"] = col;
|
||||||
|
else if( name == "ki_fp_filters" )
|
||||||
|
library["properties"]["footprint_filters"] = col;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
} );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -309,6 +309,39 @@ LIB_SYMBOL* SCH_DATABASE_PLUGIN::loadSymbolFromRow( const wxString& aSymbolName,
|
||||||
aTable.footprints_col );
|
aTable.footprints_col );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( !aTable.properties.description.empty() && aRow.count( aTable.properties.description ) )
|
||||||
|
{
|
||||||
|
wxString value(
|
||||||
|
std::any_cast<std::string>( aRow.at( aTable.properties.description ) ).c_str(),
|
||||||
|
wxConvUTF8 );
|
||||||
|
symbol->SetDescription( value );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !aTable.properties.footprint_filters.empty()
|
||||||
|
&& aRow.count( aTable.properties.footprint_filters ) )
|
||||||
|
{
|
||||||
|
wxString value( std::any_cast<std::string>( aRow.at( aTable.properties.footprint_filters ) )
|
||||||
|
.c_str(),
|
||||||
|
wxConvUTF8 );
|
||||||
|
wxArrayString filters;
|
||||||
|
filters.push_back( value );
|
||||||
|
symbol->SetFPFilters( filters );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !aTable.properties.exclude_from_board.empty()
|
||||||
|
&& aRow.count( aTable.properties.exclude_from_board ) )
|
||||||
|
{
|
||||||
|
bool exclude = std::any_cast<bool>( aRow.at( aTable.properties.exclude_from_board ) );
|
||||||
|
symbol->SetIncludeOnBoard( !exclude );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !aTable.properties.exclude_from_bom.empty()
|
||||||
|
&& aRow.count( aTable.properties.exclude_from_bom ) )
|
||||||
|
{
|
||||||
|
bool exclude = std::any_cast<bool>( aRow.at( aTable.properties.exclude_from_bom ) );
|
||||||
|
symbol->SetIncludeInBom( !exclude );
|
||||||
|
}
|
||||||
|
|
||||||
for( const DATABASE_FIELD_MAPPING& mapping : aTable.fields )
|
for( const DATABASE_FIELD_MAPPING& mapping : aTable.fields )
|
||||||
{
|
{
|
||||||
if( !aRow.count( mapping.column ) )
|
if( !aRow.count( mapping.column ) )
|
||||||
|
@ -321,22 +354,7 @@ LIB_SYMBOL* SCH_DATABASE_PLUGIN::loadSymbolFromRow( const wxString& aSymbolName,
|
||||||
wxString value( std::any_cast<std::string>( aRow.at( mapping.column ) ).c_str(),
|
wxString value( std::any_cast<std::string>( aRow.at( mapping.column ) ).c_str(),
|
||||||
wxConvUTF8 );
|
wxConvUTF8 );
|
||||||
|
|
||||||
if( mapping.name == wxT( "ki_description" ) )
|
if( mapping.name == wxT( "Value" ) )
|
||||||
{
|
|
||||||
symbol->SetDescription( value );
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
else if( mapping.name == wxT( "ki_keywords" ) )
|
|
||||||
{
|
|
||||||
symbol->SetKeyWords( value );
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
else if( mapping.name == wxT( "ki_fp_filters" ) )
|
|
||||||
{
|
|
||||||
// TODO: Handle this here?
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
else if( mapping.name == wxT( "Value" ) )
|
|
||||||
{
|
{
|
||||||
LIB_FIELD& field = symbol->GetValueField();
|
LIB_FIELD& field = symbol->GetValueField();
|
||||||
field.SetText( value );
|
field.SetText( value );
|
||||||
|
|
|
@ -52,6 +52,15 @@ struct DATABASE_FIELD_MAPPING
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
struct MAPPABLE_SYMBOL_PROPERTIES
|
||||||
|
{
|
||||||
|
std::string description;
|
||||||
|
std::string footprint_filters;
|
||||||
|
std::string exclude_from_bom;
|
||||||
|
std::string exclude_from_board;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A database library table will be mapped to a sub-library provided by the database library entry
|
* A database library table will be mapped to a sub-library provided by the database library entry
|
||||||
* in the KiCad symbol/footprint library table. A single database library config file (managed by
|
* in the KiCad symbol/footprint library table. A single database library config file (managed by
|
||||||
|
@ -73,6 +82,7 @@ struct DATABASE_LIB_TABLE
|
||||||
std::string symbols_col; ///< Column name containing KiCad symbol refs
|
std::string symbols_col; ///< Column name containing KiCad symbol refs
|
||||||
std::string footprints_col; ///< Column name containing KiCad footprint refs
|
std::string footprints_col; ///< Column name containing KiCad footprint refs
|
||||||
|
|
||||||
|
MAPPABLE_SYMBOL_PROPERTIES properties;
|
||||||
std::vector<DATABASE_FIELD_MAPPING> fields;
|
std::vector<DATABASE_FIELD_MAPPING> fields;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -60,14 +60,11 @@
|
||||||
"visible_on_add": true,
|
"visible_on_add": true,
|
||||||
"visible_in_chooser": false,
|
"visible_in_chooser": false,
|
||||||
"show_name": true
|
"show_name": true
|
||||||
},
|
|
||||||
{
|
|
||||||
"column": "Description",
|
|
||||||
"name": "ki_description",
|
|
||||||
"visible_on_add": false,
|
|
||||||
"visible_in_chooser": true
|
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"properties": {
|
||||||
|
"description": "Description"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "Capacitors",
|
"name": "Capacitors",
|
||||||
|
@ -105,14 +102,11 @@
|
||||||
"name": "Voltage Rating",
|
"name": "Voltage Rating",
|
||||||
"visible_on_add": true,
|
"visible_on_add": true,
|
||||||
"visible_in_chooser": true
|
"visible_in_chooser": true
|
||||||
},
|
|
||||||
{
|
|
||||||
"column": "Description",
|
|
||||||
"name": "ki_description",
|
|
||||||
"visible_on_add": false,
|
|
||||||
"visible_in_chooser": true
|
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"properties": {
|
||||||
|
"description": "Description"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
Loading…
Reference in New Issue