KiCad PCB EDA Suite
Loading...
Searching...
No Matches
bitmap2cmp_settings.cpp
Go to the documentation of this file.
1/*
2* This program source code file is part of KiCad, a free EDA CAD application.
3*
4* Copyright The KiCad Developers, see AUTHORS.txt for contributors.
5*
6* This program is free software; you can redistribute it and/or
7* modify it under the terms of the GNU General Public License
8* as published by the Free Software Foundation; either version 2
9* of the License, or (at your option) any later version.
10*
11* This program is distributed in the hope that it will be useful,
12* but WITHOUT ANY WARRANTY; without even the implied warranty of
13* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14* GNU General Public License for more details.
15*
16* You should have received a copy of the GNU General Public License
17* along with this program. If not, see <https://www.gnu.org/licenses/>.
18*/
19
20#include <bitmap2cmp_settings.h>
21#include <settings/parameters.h>
22#include <wx/config.h>
23
24
27
28
30 APP_SETTINGS_BASE( "bitmap2component", bitmap2cmpSchemaVersion ),
33 m_Units(),
35 m_Negative(),
38{
39 m_params.emplace_back( new PARAM<wxString>( "bitmap_file_name", &m_BitmapFileName, "" ) );
40 m_params.emplace_back( new PARAM<wxString>( "converted_file_name", &m_ConvertedFileName, "" ) );
41 m_params.emplace_back( new PARAM<int>( "units", &m_Units, 0 ) );
42 m_params.emplace_back( new PARAM<int>( "threshold", &m_Threshold, 50 ) );
43 m_params.emplace_back( new PARAM<bool>( "negative", &m_Negative, false ) );
44 m_params.emplace_back( new PARAM<int>( "last_format", &m_LastFormat, 0 ) );
45 m_params.emplace_back( new PARAM<int>( "last_mod_layer", &m_LastLayer, 0 ) );
46
48 [&]() -> bool
49 {
50 // Version 1 introduced a new layer (F.Cu), and changed the ordering to
51 // be consistent with PCBNew.
52 switch( Get<int>( "last_mod_layer" ).value_or( 0 ) )
53 {
54 default:
55 case 0: Set( "last_mod_layer", 1 ); break;
56 case 1: Set( "last_mod_layer", 2 ); break;
57 case 2: Set( "last_mod_layer", 7 ); break;
58 case 3: Set( "last_mod_layer", 3 ); break;
59 case 4: Set( "last_mod_layer", 4 ); break;
60 case 5: Set( "last_mod_layer", 5 ); break;
61 case 6: Set( "last_mod_layer", 6 ); break;
62 }
63 return true;
64 } );
65}
66
67
69{
70 bool ret = APP_SETTINGS_BASE::MigrateFromLegacy( aCfg );
71
72 ret &= fromLegacyString( aCfg, "Last_input", "bitmap_file_name" );
73 ret &= fromLegacyString( aCfg, "Last_output", "converted_file_name" );
74 ret &= fromLegacy<int>( aCfg, "Last_format", "last_format" );
75 ret &= fromLegacy<int>( aCfg, "Last_modlayer", "last_mod_layer" );
76 ret &= fromLegacy<int>( aCfg, "Threshold", "threshold" );
77 ret &= fromLegacy<bool>( aCfg, "Negative_choice", "negative" );
78 ret &= fromLegacy<int>( aCfg, "Unit_selection", "units" );
79
80 return ret;
81}
const int bitmap2cmpSchemaVersion
! Update the schema version whenever a migration is required
APP_SETTINGS_BASE(const std::string &aFilename, int aSchemaVersion)
virtual bool MigrateFromLegacy(wxConfigBase *aCfg) override
Migrates from wxConfig to JSON-based configuration.
virtual bool MigrateFromLegacy(wxConfigBase *aLegacyConfig) override
Migrates from wxConfig to JSON-based configuration.
bool fromLegacyString(wxConfigBase *aConfig, const std::string &aKey, const std::string &aDest)
Translates a legacy wxConfig string value to a given JSON pointer value.
bool fromLegacy(wxConfigBase *aConfig, const std::string &aKey, const std::string &aDest)
Translates a legacy wxConfig value to a given JSON pointer value.
void Set(const std::string &aPath, ValueType aVal)
Stores a value into the JSON document Will throw an exception if ValueType isn't something that the l...
std::optional< ValueType > Get(const std::string &aPath) const
Fetches a value from within the JSON document.
std::vector< PARAM_BASE * > m_params
The list of parameters (owned by this object)
void registerMigration(int aOldSchemaVersion, int aNewSchemaVersion, std::function< bool(void)> aMigrator)
Registers a migration from one schema version to another.