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, you may find one here:
18* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
19* or you may search the http://www.gnu.org website for the version 2 license,
20* or you may write to the Free Software Foundation, Inc.,
21* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
22*/
23
24#include <bitmap2cmp_settings.h>
25#include <settings/parameters.h>
26#include <wx/config.h>
27
28
31
32
34 APP_SETTINGS_BASE( "bitmap2component", bitmap2cmpSchemaVersion ),
35 m_BitmapFileName(),
36 m_ConvertedFileName(),
37 m_Units(),
38 m_Threshold(),
39 m_Negative(),
40 m_LastFormat(),
41 m_LastLayer()
42{
43 m_params.emplace_back( new PARAM<wxString>( "bitmap_file_name", &m_BitmapFileName, "" ) );
44 m_params.emplace_back( new PARAM<wxString>( "converted_file_name", &m_ConvertedFileName, "" ) );
45 m_params.emplace_back( new PARAM<int>( "units", &m_Units, 0 ) );
46 m_params.emplace_back( new PARAM<int>( "threshold", &m_Threshold, 50 ) );
47 m_params.emplace_back( new PARAM<bool>( "negative", &m_Negative, false ) );
48 m_params.emplace_back( new PARAM<int>( "last_format", &m_LastFormat, 0 ) );
49 m_params.emplace_back( new PARAM<int>( "last_mod_layer", &m_LastLayer, 0 ) );
50
52 [&]() -> bool
53 {
54 // Version 1 introduced a new layer (F.Cu), and changed the ordering to
55 // be consistent with PCBNew.
56 switch( Get<int>( "last_mod_layer" ).value_or( 0 ) )
57 {
58 default:
59 case 0: Set( "last_mod_layer", 1 ); break;
60 case 1: Set( "last_mod_layer", 2 ); break;
61 case 2: Set( "last_mod_layer", 7 ); break;
62 case 3: Set( "last_mod_layer", 3 ); break;
63 case 4: Set( "last_mod_layer", 4 ); break;
64 case 5: Set( "last_mod_layer", 5 ); break;
65 case 6: Set( "last_mod_layer", 6 ); break;
66 }
67 return true;
68 } );
69}
70
71
73{
74 bool ret = APP_SETTINGS_BASE::MigrateFromLegacy( aCfg );
75
76 ret &= fromLegacyString( aCfg, "Last_input", "bitmap_file_name" );
77 ret &= fromLegacyString( aCfg, "Last_output", "converted_file_name" );
78 ret &= fromLegacy<int>( aCfg, "Last_format", "last_format" );
79 ret &= fromLegacy<int>( aCfg, "Last_modlayer", "last_mod_layer" );
80 ret &= fromLegacy<int>( aCfg, "Threshold", "threshold" );
81 ret &= fromLegacy<bool>( aCfg, "Negative_choice", "negative" );
82 ret &= fromLegacy<int>( aCfg, "Unit_selection", "units" );
83
84 return ret;
85}
const int bitmap2cmpSchemaVersion
! Update the schema version whenever a migration is required
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
Definition: app_settings.h:92
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.
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::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.