KiCad PCB EDA Suite
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 (C) 2020 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(), m_ConvertedFileName(), m_Units(), m_Threshold(), m_Negative(),
36 m_LastFormat(), m_LastModLayer()
37{
38 m_params.emplace_back( new PARAM<wxString>( "bitmap_file_name", &m_BitmapFileName, "" ) );
39
40 m_params.emplace_back(
41 new PARAM<wxString>( "converted_file_name", &m_ConvertedFileName, "" ) );
42
43 m_params.emplace_back( new PARAM<int>( "units", &m_Units, 0 ) );
44
45 m_params.emplace_back( new PARAM<int>( "threshold", &m_Threshold, 50 ) );
46
47 m_params.emplace_back( new PARAM<bool>( "negative", &m_Negative, false ) );
48
49 m_params.emplace_back( new PARAM<int>( "last_format", &m_LastFormat, 0 ) );
50
51 m_params.emplace_back( new PARAM<int>( "last_mod_layer", &m_LastModLayer, 0 ) );
52}
53
54
56{
57 bool ret = APP_SETTINGS_BASE::MigrateFromLegacy( aCfg );
58
59 ret &= fromLegacyString( aCfg, "Last_input", "bitmap_file_name" );
60 ret &= fromLegacyString( aCfg, "Last_output", "converted_file_name" );
61 ret &= fromLegacy<int>( aCfg, "Last_format", "last_format" );
62 ret &= fromLegacy<int>( aCfg, "Last_modlayer", "last_mod_layer" );
63 ret &= fromLegacy<int>( aCfg, "Threshold", "threshold" );
64 ret &= fromLegacy<bool>( aCfg, "Negative_choice", "negative" );
65 ret &= fromLegacy<int>( aCfg, "Unit_selection", "units" );
66
67 return ret;
68}
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:101
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.
std::vector< PARAM_BASE * > m_params
The list of parameters (owned by this object)