From e7cc177d946e0037aa987e593c57b7ff20f9a617 Mon Sep 17 00:00:00 2001 From: Jeff Young Date: Thu, 23 Dec 2021 13:55:59 +0000 Subject: [PATCH] Allow a 0 pin-symbol-size. This is particularly important when reading legacy projects as 0 is what signals the painter to use the old algorithm (1/2 pin name/number size). Fixes https://gitlab.com/kicad/code/kicad/issues/10100 (cherry picked from commit f089cf44a78db2e4fc3487fa1ca8661202daa2dc) --- common/project/project_file.cpp | 22 ++++++++++++++-------- eeschema/schematic_settings.cpp | 2 +- 2 files changed, 15 insertions(+), 9 deletions(-) diff --git a/common/project/project_file.cpp b/common/project/project_file.cpp index dff2e823ae..d0ff2b9baf 100644 --- a/common/project/project_file.cpp +++ b/common/project/project_file.cpp @@ -235,16 +235,22 @@ bool PROJECT_FILE::MigrateFromLegacy( wxConfigBase* aCfg ) fromLegacy( aCfg, "SubpartIdSeparator", "schematic.subpart_id_separator" ); fromLegacy( aCfg, "SubpartFirstId", "schematic.subpart_first_id" ); - fromLegacy( aCfg, "LineThickness", "schematic.drawing.default_line_thickness" ); - fromLegacy( aCfg, "WireThickness", "schematic.drawing.default_wire_thickness" ); - fromLegacy( aCfg, "BusThickness", "schematic.drawing.default_bus_thickness" ); - fromLegacy( aCfg, "LabSize", "schematic.drawing.default_text_size" ); - fromLegacy( aCfg, "PinSymbolSize", "schematic.drawing.pin_symbol_size" ); - fromLegacy( aCfg, "JunctionSize", "schematic.drawing.default_junction_size" ); + fromLegacy( aCfg, "LineThickness", "schematic.drawing.default_line_thickness" ); + fromLegacy( aCfg, "WireThickness", "schematic.drawing.default_wire_thickness" ); + fromLegacy( aCfg, "BusThickness", "schematic.drawing.default_bus_thickness" ); + fromLegacy( aCfg, "LabSize", "schematic.drawing.default_text_size" ); - fromLegacyString( aCfg, "FieldNameTemplates", "schematic.drawing.field_names" ); + if( !fromLegacy( aCfg, "PinSymbolSize", "schematic.drawing.pin_symbol_size" ) ) + { + // Use the default symbol size algorithm of Eeschema V5 (based on pin name/number size) + Set( "schematic.drawing.pin_symbol_size", 0 ); + } - if( !fromLegacy( aCfg, "TextOffsetRatio", "schematic.drawing.text_offset_ratio" ) ) + fromLegacy( aCfg, "JunctionSize", "schematic.drawing.default_junction_size" ); + + fromLegacyString( aCfg, "FieldNameTemplates", "schematic.drawing.field_names" ); + + if( !fromLegacy( aCfg, "TextOffsetRatio", "schematic.drawing.text_offset_ratio" ) ) { // Use the spacing of Eeschema V5 Set( "schematic.drawing.text_offset_ratio", 0.08 ); diff --git a/eeschema/schematic_settings.cpp b/eeschema/schematic_settings.cpp index e87ccacffd..08bd205647 100644 --- a/eeschema/schematic_settings.cpp +++ b/eeschema/schematic_settings.cpp @@ -104,7 +104,7 @@ SCHEMATIC_SETTINGS::SCHEMATIC_SETTINGS( JSON_SETTINGS* aParent, const std::strin &m_LabelSizeRatio, DEFAULT_LABEL_SIZE_RATIO, 0.0, 2.0 ) ); m_params.emplace_back( new PARAM_SCALED( "drawing.pin_symbol_size", - &m_PinSymbolSize, Mils2iu( defaultPinSymbolSize ), Mils2iu( 5 ), Mils2iu( 1000 ), + &m_PinSymbolSize, Mils2iu( defaultPinSymbolSize ), Mils2iu( 0 ), Mils2iu( 1000 ), 1 / IU_PER_MILS ) ); // m_JunctionSize is only a run-time cache of the calculated size. Do not save it.