diff options
Diffstat (limited to 'include/config_params.h')
-rw-r--r-- | include/config_params.h | 366 |
1 files changed, 366 insertions, 0 deletions
diff --git a/include/config_params.h b/include/config_params.h new file mode 100644 index 0000000..16cd089 --- /dev/null +++ b/include/config_params.h @@ -0,0 +1,366 @@ +#ifndef CONFIG_PARAMS_H_ +#define CONFIG_PARAMS_H_ +/* + * This program source code file is part of KiCad, a free EDA CAD application. + * + * Copyright (C) 2004 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com + * Copyright (C) 2008-2011 Wayne Stambaugh <stambaughw@verizon.net> + * Copyright (C) 1992-2011 KiCad Developers, see AUTHORS.txt for contributors. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, you may find one here: + * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html + * or you may search the http://www.gnu.org website for the version 2 license, + * or you may write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + */ + +/** + * The common library + * @file config_params.h + */ + +#include <wx/confbase.h> +#include <wx/fileconf.h> +#include <boost/ptr_container/ptr_vector.hpp> +#include <colors.h> +#include <limits> + +/// Names of sub sections where to store project info in *.pro project config files +#define GROUP_PCB wxT( "/pcbnew" ) /// parameters for Pcbnew/Modedit +#define GROUP_SCH wxT( "/eeschema" ) /// library list and lib paths list +#define GROUP_SCH_EDITOR wxT( "/schematic_editor" ) /// parameters for schematic editor + /// (and few for component editor). + /// Does not store libs list +#define GROUP_PCB_LIBS wxT( "/pcbnew/libraries" ) /// PCB library list, should be removed soon + /// (Now in fp lib tables) +#define GROUP_SCH_LIBS wxT( "/eeschema/libraries" ) /// library list section + +#define GROUP_CVP wxT("/cvpcb") +#define GROUP_CVP_EQU wxT("/cvpcb/equfiles") + + +#define CONFIG_VERSION 1 + + +/** + * Function ConfigBaseWriteDouble + * This is a helper function to write doubles in config + * We cannot use wxConfigBase->Write for a double, because + * this function uses a format with very few digits in mantissa, + * and truncation issues are frequent. + * We use here a better floating format. + */ +void ConfigBaseWriteDouble( wxConfigBase* aConfig, const wxString& aKey, double aValue ); + + +/** Type of parameter in the configuration file */ +enum paramcfg_id { + PARAM_INT, + PARAM_INT_WITH_SCALE, + PARAM_SETCOLOR, + PARAM_DOUBLE, + PARAM_BOOL, + PARAM_LIBNAME_LIST, + PARAM_WXSTRING, + PARAM_FILENAME, + PARAM_COMMAND_ERASE, + PARAM_FIELDNAME_LIST +}; + + +/** + * Class PARAM_CFG_BASE + * is a base class which establishes the interface functions ReadParam and SaveParam, + * which are implemented by a number of derived classes, and these function's + * doxygen comments are inherited also. + * <p> + * See kicad.odt or kicad.pdf, chapter 2 : + * "Installation and configuration/Initialization of the default config". + */ +class PARAM_CFG_BASE +{ +public: + wxString m_Ident; ///< Keyword in config data + paramcfg_id m_Type; ///< Type of parameter + wxString m_Group; ///< Group name (this is like a path in the config data) + bool m_Setup; ///< Install or Project based parameter, true == install + +public: + PARAM_CFG_BASE( const wxString& ident, const paramcfg_id type, + const wxChar* group = NULL ); + virtual ~PARAM_CFG_BASE() {} + + /** + * Function ReadParam + * reads the value of the parameter stored in aConfig + * @param aConfig = the wxConfigBase that holds the parameter + */ + virtual void ReadParam( wxConfigBase* aConfig ) const {}; + + /** + * Function SaveParam + * saves the value of the parameter stored in aConfig + * @param aConfig = the wxConfigBase that can store the parameter + */ + virtual void SaveParam( wxConfigBase* aConfig ) const {}; +}; + + +/** + * Configuration parameter - Integer Class + * + */ +class PARAM_CFG_INT : public PARAM_CFG_BASE +{ +public: + int* m_Pt_param; ///< Pointer to the parameter value + int m_Min, m_Max; ///< Minimum and maximum values of the param type + int m_Default; ///< The default value of the parameter + +public: + PARAM_CFG_INT( const wxString& ident, int* ptparam, + int default_val = 0, + int min = std::numeric_limits<int>::min(), + int max = std::numeric_limits<int>::max(), + const wxChar* group = NULL ); + PARAM_CFG_INT( bool Insetup, const wxString& ident, int* ptparam, + int default_val = 0, + int min = std::numeric_limits<int>::min(), + int max = std::numeric_limits<int>::max(), + const wxChar* group = NULL ); + + virtual void ReadParam( wxConfigBase* aConfig ) const; + virtual void SaveParam( wxConfigBase* aConfig ) const; +}; + +/** + * Configuration parameter - Integer Class + * with unit conversion. + * Mainly used to store an integer value in millimeters (or inches) + * and retrieve it in internal units + * the stored value is a floating number + */ +class PARAM_CFG_INT_WITH_SCALE : public PARAM_CFG_INT +{ +public: + double m_BIU_to_cfgunit; ///< the factor to convert the saved value in internal value + +public: + PARAM_CFG_INT_WITH_SCALE( const wxString& ident, int* ptparam, + int default_val = 0, + int min = std::numeric_limits<int>::min(), + int max = std::numeric_limits<int>::max(), + const wxChar* group = NULL, + double aBiu2cfgunit = 1.0); + PARAM_CFG_INT_WITH_SCALE( bool Insetup, const wxString& ident, int* ptparam, + int default_val = 0, + int min = std::numeric_limits<int>::min(), + int max = std::numeric_limits<int>::max(), + const wxChar* group = NULL, + double aBiu2cfgunit = 1.0 ); + + virtual void ReadParam( wxConfigBase* aConfig ) const; + virtual void SaveParam( wxConfigBase* aConfig ) const; +}; + + +/** + * Configuration parameter - SetColor Class + * + */ +class PARAM_CFG_SETCOLOR : public PARAM_CFG_BASE +{ +public: + EDA_COLOR_T* m_Pt_param; ///< Pointer to the parameter value + EDA_COLOR_T m_Default; ///< The default value of the parameter + +public: + PARAM_CFG_SETCOLOR( const wxString& ident, EDA_COLOR_T* ptparam, + EDA_COLOR_T default_val, const wxChar* group = NULL ); + PARAM_CFG_SETCOLOR( bool Insetup, const wxString& ident, EDA_COLOR_T* ptparam, + EDA_COLOR_T default_val, const wxChar* group = NULL ); + + virtual void ReadParam( wxConfigBase* aConfig ) const; + virtual void SaveParam( wxConfigBase* aConfig ) const; +}; + + +/** + * Configuration parameter - Double Precision Class + * + */ +class PARAM_CFG_DOUBLE : public PARAM_CFG_BASE +{ +public: + double* m_Pt_param; ///< Pointer to the parameter value + double m_Default; ///< The default value of the parameter + double m_Min, m_Max; ///< Minimum and maximum values of the param type + +public: + PARAM_CFG_DOUBLE( const wxString& ident, double* ptparam, + double default_val = 0.0, double min = 0.0, double max = 10000.0, + const wxChar* group = NULL ); + PARAM_CFG_DOUBLE( bool Insetup, const wxString& ident, double* ptparam, + double default_val = 0.0, double min = 0.0, double max = 10000.0, + const wxChar* group = NULL ); + + virtual void ReadParam( wxConfigBase* aConfig ) const; + virtual void SaveParam( wxConfigBase* aConfig ) const; +}; + + +/** + * Configuration parameter - Boolean Class + * + */ +class PARAM_CFG_BOOL : public PARAM_CFG_BASE +{ +public: + bool* m_Pt_param; ///< Pointer to the parameter value + int m_Default; ///< The default value of the parameter + +public: + PARAM_CFG_BOOL( const wxString& ident, bool* ptparam, + int default_val = false, const wxChar* group = NULL ); + PARAM_CFG_BOOL( bool Insetup, const wxString& ident, bool* ptparam, + int default_val = false, const wxChar* group = NULL ); + + virtual void ReadParam( wxConfigBase* aConfig ) const; + virtual void SaveParam( wxConfigBase* aConfig ) const; +}; + + +/** + * Configuration parameter - wxString Class + * + */ +class PARAM_CFG_WXSTRING : public PARAM_CFG_BASE +{ +public: + wxString* m_Pt_param; ///< Pointer to the parameter value + wxString m_default; ///< The default value of the parameter + +public: + PARAM_CFG_WXSTRING( const wxString& ident, wxString* ptparam, const wxChar* group = NULL ); + + PARAM_CFG_WXSTRING( bool Insetup, + const wxString& ident, + wxString* ptparam, + const wxString& default_val = wxEmptyString, + const wxChar* group = NULL ); + + virtual void ReadParam( wxConfigBase* aConfig ) const; + virtual void SaveParam( wxConfigBase* aConfig ) const; +}; + + +/** + * Configuration parameter - PARAM_CFG_FILENAME Class + * Same as PARAM_CFG_WXSTRING, but stores "\" as "/". + * and replace "/" by "\" under Windows. + * Used to store paths and filenames in config files + */ +class PARAM_CFG_FILENAME : public PARAM_CFG_BASE +{ +public: + wxString* m_Pt_param; ///< Pointer to the parameter value + +public: + PARAM_CFG_FILENAME( const wxString& ident, wxString* ptparam, + const wxChar* group = NULL ); + virtual void ReadParam( wxConfigBase* aConfig ) const; + virtual void SaveParam( wxConfigBase* aConfig ) const; +}; + + +class PARAM_CFG_LIBNAME_LIST : public PARAM_CFG_BASE +{ +public: + wxArrayString* m_Pt_param; ///< Pointer to the parameter value + +public: + PARAM_CFG_LIBNAME_LIST( const wxChar* ident, + wxArrayString* ptparam, + const wxChar* group = NULL ); + + virtual void ReadParam( wxConfigBase* aConfig ) const; + virtual void SaveParam( wxConfigBase* aConfig ) const; +}; + + +/** A list of parameters type */ +//typedef boost::ptr_vector<PARAM_CFG_BASE> PARAM_CFG_ARRAY; +class PARAM_CFG_ARRAY : public boost::ptr_vector<PARAM_CFG_BASE> +{ +}; + + +/** + * Function wxConfigSaveSetups + * writes @a aList of PARAM_CFG_ARRAY elements to save configuration values + * to @a aCfg. Only elements with m_Setup set true will be saved, hence the + * function name. + * + * @param aCfg where to save + * @param aList holds some configuration parameters, not all of which will + * necessarily be saved. + */ +void wxConfigSaveSetups( wxConfigBase* aCfg, const PARAM_CFG_ARRAY& aList ); + +/** + * Function wxConfigSaveParams + * writes @a aList of PARAM_CFG_ARRAY elements to save configuration values + * to @a aCfg. Only elements with m_Setup set false will be saved, hence the + * function name. + * + * @param aCfg where to save + * @param aList holds some configuration parameters, not all of which will + * necessarily be saved. + * @param aGroup indicates in which group the value should be saved, + * unless the PARAM_CFG_ARRAY element provides its own group, in which case it will + * take precedence. aGroup may be empty. + */ +void wxConfigSaveParams( wxConfigBase* aCfg, + const PARAM_CFG_ARRAY& aList, const wxString& aGroup ); + +/** + * Function wxConfigLoadSetups + * uses @a aList of PARAM_CFG_ARRAY elements to load configuration values + * from @a aCfg. Only elements whose m_Setup field is true will be loaded. + * + * @param aCfg where to load from. + * @param aList holds some configuration parameters, not all of which will + * necessarily be loaded. + */ +void wxConfigLoadSetups( wxConfigBase* aCfg, const PARAM_CFG_ARRAY& aList ); + +/** + * Function wxConfigLoadParams + * uses @a aList of PARAM_CFG_ARRAY elements to load configuration values + * from @a aCfg. Only elements whose m_Setup field is false will be loaded. + * + * @param aCfg where to load from. + * + * @param aList holds some configuration parameters, not all of which will + * necessarily be loaded. + * + * @param aGroup indicates in which group the value should be saved, + * unless the PARAM_CFG_ARRAY element provides its own group, in which case it will + * take precedence. aGroup may be empty. + */ +void wxConfigLoadParams( wxConfigBase* aCfg, + const PARAM_CFG_ARRAY& aList, const wxString& aGroup ); + + +#endif // CONFIG_PARAMS_H_ |