341 lines
11 KiB
C++
341 lines
11 KiB
C++
/**
|
|
* @file appl_wxstruct.h
|
|
* @brief Base class implementation for all Kicad applications.
|
|
*/
|
|
|
|
#ifndef APPL_WXSTRUCT_H
|
|
#define APPL_WXSTRUCT_H
|
|
|
|
/* Use wxFileHistory for most recently used file handling. */
|
|
#include <wx/docview.h>
|
|
#include <wx/config.h>
|
|
#include <wx/filename.h>
|
|
#include "param_config.h"
|
|
|
|
|
|
enum EDA_APP_T {
|
|
APP_UNKNOWN_T,
|
|
APP_EESCHEMA_T,
|
|
APP_PCBNEW_T,
|
|
APP_CVPCB_T,
|
|
APP_GERBVIEW_T,
|
|
APP_KICAD_T
|
|
};
|
|
|
|
class wxConfigBase;
|
|
class wxFileConfig;
|
|
class wxSingleInstanceChecker;
|
|
class wxHtmlHelpController;
|
|
|
|
|
|
/**
|
|
* Class EDA_APP
|
|
* is the base class representing all of Kicad applications.
|
|
*/
|
|
class EDA_APP : public wxApp
|
|
{
|
|
public:
|
|
EDA_APP_T m_Id; /* Used mainly to handle default paths libs
|
|
* m_Id = APP_EESCHEMA_T, APP_PCBNEW_T ... */
|
|
wxString m_Project;
|
|
wxSingleInstanceChecker* m_Checker;
|
|
|
|
wxPoint m_HelpPos;
|
|
wxSize m_HelpSize;
|
|
wxHtmlHelpController* m_HtmlCtrl;
|
|
wxConfig* m_EDA_Config;
|
|
wxConfig* m_EDA_CommonConfig;
|
|
wxFileConfig* m_ProjectConfig;
|
|
wxString m_HelpFileName;
|
|
wxString m_EditorName;
|
|
wxString m_CurrentOptionFile;
|
|
wxString m_CurrentOptionFileDateAndTime;
|
|
|
|
wxString m_BinDir; /* Kicad executable path.*/
|
|
wxString m_KicadEnv; /* environment variable KICAD */
|
|
bool m_Env_Defined; // TRUE if environment KICAD is defined.
|
|
|
|
wxLocale* m_Locale; // The current locale.
|
|
int m_LanguageId; // The current language setting.
|
|
wxString m_PdfBrowser; // Name of the selected browser,
|
|
// for browsing pdf datasheets
|
|
bool m_PdfBrowserIsDefault; // True if the pdf browser is the
|
|
// default (m_PdfBrowser not used)
|
|
wxPathList m_searchPaths;
|
|
wxFileHistory m_fileHistory;
|
|
|
|
protected:
|
|
wxString m_Title;
|
|
wxPathList m_libSearchPaths;
|
|
wxFileName m_projectFileName;
|
|
wxString m_LastVisitedLibPath;
|
|
|
|
public: EDA_APP();
|
|
~EDA_APP();
|
|
|
|
/**
|
|
* Function OnInit
|
|
* this is the first executed function (like main() )
|
|
* @return true if the application can be started.
|
|
*/
|
|
bool OnInit();
|
|
|
|
/**
|
|
* Function SetBinDir
|
|
* finds the path to the executable and store it in EDA_APP::m_BinDir
|
|
*
|
|
* @return TODO
|
|
*/
|
|
bool SetBinDir();
|
|
|
|
/**
|
|
* Function SetDefaultSearchPaths
|
|
* sets search paths for libraries, modules, internationalization files, etc.
|
|
*/
|
|
void SetDefaultSearchPaths( void );
|
|
|
|
/**
|
|
* Function MacOpenFile
|
|
* Specific to MacOSX. Not used under Linux or Windows
|
|
* MacOSX: Needed for file association
|
|
* http://wiki.wxwidgets.org/WxMac-specific_topics
|
|
*/
|
|
virtual void MacOpenFile(const wxString &fileName);
|
|
|
|
/**
|
|
* Function InitEDA_Appl
|
|
* initialize some general parameters
|
|
* - Default paths (help, libs, bin)and configuration files names
|
|
* - Language and locale
|
|
* - fonts
|
|
* @param aName : used as paths in configuration files
|
|
* @param aId = flag : LIBRARY_TYPE_EESCHEMA or LIBRARY_TYPE_PCBNEW
|
|
* used to choose what default library path must be used
|
|
*/
|
|
void InitEDA_Appl( const wxString& aName, EDA_APP_T aId = APP_UNKNOWN_T );
|
|
|
|
/**
|
|
* Function SetLanguage
|
|
* sets the dictionary file name for internationalization.
|
|
* <p>
|
|
* The files are in kicad/internat/xx or kicad/internat/xx_XX and are named kicad.mo
|
|
* </p>
|
|
* @param first_time must be set to true the first time this funct is
|
|
* called, false otherwise
|
|
* @return true if the language can be set (i.e. if the locale is available)
|
|
*/
|
|
bool SetLanguage( bool first_time = false );
|
|
|
|
/**
|
|
* Function AddMenuLanguageList
|
|
* creates a menu list for language choice, and add it as submenu to \a MasterMenu.
|
|
*
|
|
* @param MasterMenu The main menu. The sub menu list will be accessible from the menu
|
|
* item with id ID_LANGUAGE_CHOICE
|
|
*/
|
|
void AddMenuLanguageList( wxMenu* MasterMenu );
|
|
|
|
/**
|
|
* Function SetLanguageIdentifier
|
|
* sets in .m_LanguageId member the wxWidgets language identifier Id from
|
|
* the kicad menu id (internal menu identifier).
|
|
*
|
|
* @param menu_id The kicad menuitem id (returned by Menu Event, when
|
|
* clicking on a menu item)
|
|
*/
|
|
void SetLanguageIdentifier( int menu_id );
|
|
|
|
void SetLanguagePath( void );
|
|
|
|
/**
|
|
* Function InitOnLineHelp
|
|
* initializes Kicad's online help.
|
|
*/
|
|
void InitOnLineHelp();
|
|
|
|
/**
|
|
* Function GetSettings
|
|
* gets the application settings.
|
|
* @param aReopenLastUsedDirectory True to switch to last opened directory, false
|
|
* to use current CWD
|
|
*/
|
|
void GetSettings( bool aReopenLastUsedDirectory );
|
|
|
|
/**
|
|
* Function SaveSettings
|
|
* saves the application settings.
|
|
*/
|
|
void SaveSettings();
|
|
|
|
/**
|
|
* Function WriteProjectConfig
|
|
* Save the current "projet" parameters
|
|
* saved parameters are parameters that have the .m_Setup member set to false
|
|
* saving file is the .pro file project
|
|
*/
|
|
void WriteProjectConfig( const wxString& local_config_filename,
|
|
const wxString& GroupName,
|
|
PARAM_CFG_BASE** List );
|
|
void WriteProjectConfig( const wxString& fileName,
|
|
const wxString& GroupName,
|
|
PARAM_CFG_ARRAY& params );
|
|
|
|
/**
|
|
* Function SaveCurrentSetupValues
|
|
* Save the current setup values in m_EDA_Config
|
|
* saved parameters are parameters that have the .m_Setup member set to
|
|
* true
|
|
* @param aList = array of PARAM_CFG_BASE pointers
|
|
*/
|
|
void SaveCurrentSetupValues( PARAM_CFG_BASE** aList );
|
|
void SaveCurrentSetupValues( PARAM_CFG_ARRAY& List );
|
|
|
|
/**
|
|
* Function ReadCurrentSetupValues
|
|
* Read the current setup values previously saved, from m_EDA_Config
|
|
* saved parameters are parameters that have the .m_Setup member set to
|
|
* true
|
|
* @param aList = array of PARAM_CFG_BASE pointers
|
|
*/
|
|
void ReadCurrentSetupValues( PARAM_CFG_BASE** aList );
|
|
void ReadCurrentSetupValues( PARAM_CFG_ARRAY& List );
|
|
|
|
/**
|
|
* Function ReadProjectConfig
|
|
* Read the current "projet" parameters
|
|
* Parameters are parameters that have the .m_Setup member set to false
|
|
* read file is the .pro file project
|
|
*
|
|
* if Load_Only_if_New == true, this file is read only if it differs from
|
|
* the current config (different dates )
|
|
*
|
|
* @return true if read.
|
|
* Also set:
|
|
* wxGetApp().m_CurrentOptionFileDateAndTime
|
|
* wxGetApp().m_CurrentOptionFile
|
|
*/
|
|
bool ReadProjectConfig( const wxString& local_config_filename,
|
|
const wxString& GroupName,
|
|
PARAM_CFG_BASE** List,
|
|
bool Load_Only_if_New );
|
|
bool ReadProjectConfig( const wxString& local_config_filename,
|
|
const wxString& GroupName,
|
|
PARAM_CFG_ARRAY& List,
|
|
bool Load_Only_if_New );
|
|
|
|
/**
|
|
* Creates or recreates the kicad project file. (filename.pro)
|
|
* Initialize:
|
|
* G_Prj_Config
|
|
* G_Prj_Config_LocalFilename
|
|
* G_Prj_Default_Config_FullFilename
|
|
* Return:
|
|
* True if local config
|
|
* False if default config
|
|
*/
|
|
bool ReCreatePrjConfig( const wxString& local_config_filename,
|
|
const wxString& GroupName,
|
|
bool ForceUseLocalConfig );
|
|
|
|
void ReadPdfBrowserInfos();
|
|
void WritePdfBrowserInfos();
|
|
|
|
/**
|
|
* Function FindFileInSearchPaths
|
|
* looks in search paths for \a filename.
|
|
*/
|
|
wxString FindFileInSearchPaths( const wxString& filename,
|
|
const wxArrayString* subdirs = NULL );
|
|
|
|
/**
|
|
* Function GetHelpFile
|
|
* get the help file path.
|
|
* <p>
|
|
* Return the Kicad help file with path. The base paths defined in
|
|
* m_searchPaths are tested for a valid file. The path returned can
|
|
* be relative depending on the paths added to m_searchPaths. See the
|
|
* documentation for wxPathList for more information. If the help file
|
|
* for the current locale is not found, an attempt to find the English
|
|
* version of the help file is made.
|
|
* wxEmptyString is returned if help file not found.
|
|
* Help file is searched in directories in this order:
|
|
* help/\<canonical name\> like help/en_GB
|
|
* help/\<short name\> like help/en
|
|
* help/en
|
|
* </p>
|
|
*/
|
|
wxString GetHelpFile( void );
|
|
|
|
wxString GetLibraryFile( const wxString& filename );
|
|
|
|
/**
|
|
* Return the preferred editor name.
|
|
*/
|
|
wxString& GetEditorName();
|
|
|
|
const wxString& GetTitle() { return m_Title; }
|
|
void SetTitle( const wxString& title ) { m_Title = title; }
|
|
|
|
wxPathList& GetLibraryPathList() { return m_libSearchPaths; }
|
|
wxString FindLibraryPath( const wxString& fileName );
|
|
|
|
/**
|
|
* Function FindLibraryPath
|
|
* Kicad saves user defined library files that are not in the standard
|
|
* library search path list with the full file path. Calling the library
|
|
* search path list with a user library file will fail. This helper method
|
|
* solves that problem.
|
|
* @param fileName
|
|
* @return a wxEmptyString if library file is not found.
|
|
*/
|
|
wxString FindLibraryPath( const wxFileName& fileName )
|
|
{
|
|
return FindLibraryPath( fileName.GetFullPath() );
|
|
}
|
|
|
|
|
|
/**
|
|
* Function ReturnLastVisitedLibraryPath
|
|
* returns the last visited library directory, or (if void) the first
|
|
* path in lib path list ( but not the CWD )
|
|
*
|
|
* @param aSubPathToSearch = Preferred sub path to search in path list
|
|
*/
|
|
wxString ReturnLastVisitedLibraryPath( const wxString& aSubPathToSearch = wxEmptyString );
|
|
|
|
void SaveLastVisitedLibraryPath( const wxString& aPath );
|
|
|
|
/**
|
|
* Function ReturnFilenameWithRelativePathInLibPath
|
|
* @return a short filename (with extension) with only a relative path if
|
|
* this filename can be found in library paths
|
|
* @param aFullFilename The filename with path and extension.
|
|
*/
|
|
wxString ReturnFilenameWithRelativePathInLibPath( const wxString& aFullFilename );
|
|
|
|
/**
|
|
* Function RemoveLibraryPath
|
|
* Removes the given path(s) from the library path list
|
|
* @param aPaths = path or path list to remove. paths must be separated by
|
|
* ";"
|
|
*/
|
|
void RemoveLibraryPath( const wxString& aPaths );
|
|
|
|
/**
|
|
* Function InsertLibraryPath
|
|
* insert path(s) int lib paths list.
|
|
* @param aPaths = path or path list to add. paths must be separated by ";"
|
|
* @param aIndex = insertion point
|
|
*/
|
|
void InsertLibraryPath( const wxString& aPaths, size_t aIndex );
|
|
};
|
|
|
|
/*
|
|
* Use wxGetApp() to access EDA_APP. It is not necessary to keep copies
|
|
* of the application pointer all over the place or worse yet in a global
|
|
* variable.
|
|
*/
|
|
DECLARE_APP( EDA_APP )
|
|
|
|
#endif /* APPL_WXSTRUCT_H */
|