2011-11-10 15:55:05 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
*
|
2020-02-11 15:01:55 +00:00
|
|
|
* Copyright (C) 2014-2020 Jean-Pierre Charras, jp.charras at wanadoo.fr
|
2015-01-07 15:04:57 +00:00
|
|
|
* Copyright (C) 2007-2015 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com>
|
2018-05-07 15:47:16 +00:00
|
|
|
* Copyright (C) 2008 Wayne Stambaugh <stambaughw@gmail.com>
|
2021-01-25 12:42:36 +00:00
|
|
|
* Copyright (C) 1992-2021 KiCad Developers, see AUTHORS.txt for contributors.
|
2011-11-10 15:55:05 +00:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
2009-01-19 19:08:42 +00:00
|
|
|
/**
|
|
|
|
* The common library
|
|
|
|
* @file common.h
|
|
|
|
*/
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2011-11-24 17:32:51 +00:00
|
|
|
#ifndef INCLUDE__COMMON_H_
|
|
|
|
#define INCLUDE__COMMON_H_
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2020-03-30 16:35:11 +00:00
|
|
|
#include <functional>
|
2021-03-20 15:35:37 +00:00
|
|
|
#include <memory>
|
2011-12-22 21:57:50 +00:00
|
|
|
|
2012-01-23 04:33:36 +00:00
|
|
|
#include <wx/fileconf.h>
|
2020-10-01 15:15:15 +00:00
|
|
|
#include <wx/string.h>
|
2020-10-25 16:41:38 +00:00
|
|
|
#include <wx/process.h>
|
2007-05-06 16:03:28 +00:00
|
|
|
|
2020-03-26 11:02:59 +00:00
|
|
|
class PROJECT;
|
* KIWAY Milestone A): Make major modules into DLL/DSOs.
! The initial testing of this commit should be done using a Debug build so that
all the wxASSERT()s are enabled. Also, be sure and keep enabled the
USE_KIWAY_DLLs option. The tree won't likely build without it. Turning it
off is senseless anyways. If you want stable code, go back to a prior version,
the one tagged with "stable".
* Relocate all functionality out of the wxApp derivative into more finely
targeted purposes:
a) DLL/DSO specific
b) PROJECT specific
c) EXE or process specific
d) configuration file specific data
e) configuration file manipulations functions.
All of this functionality was blended into an extremely large wxApp derivative
and that was incompatible with the desire to support multiple concurrently
loaded DLL/DSO's ("KIFACE")s and multiple concurrently open projects.
An amazing amount of organization come from simply sorting each bit of
functionality into the proper box.
* Switch to wxConfigBase from wxConfig everywhere except instantiation.
* Add classes KIWAY, KIFACE, KIFACE_I, SEARCH_STACK, PGM_BASE, PGM_KICAD,
PGM_SINGLE_TOP,
* Remove "Return" prefix on many function names.
* Remove obvious comments from CMakeLists.txt files, and from else() and endif()s.
* Fix building boost for use in a DSO on linux.
* Remove some of the assumptions in the CMakeLists.txt files that windows had
to be the host platform when building windows binaries.
* Reduce the number of wxStrings being constructed at program load time via
static construction.
* Pass wxConfigBase* to all SaveSettings() and LoadSettings() functions so that
these functions are useful even when the wxConfigBase comes from another
source, as is the case in the KICAD_MANAGER_FRAME.
* Move the setting of the KIPRJMOD environment variable into class PROJECT,
so that it can be moved into a project variable soon, and out of FP_LIB_TABLE.
* Add the KIWAY_PLAYER which is associated with a particular PROJECT, and all
its child wxFrames and wxDialogs now have a Kiway() member function which
returns a KIWAY& that that window tree branch is in support of. This is like
wxWindows DNA in that child windows get this member with proper value at time
of construction.
* Anticipate some of the needs for milestones B) and C) and make code
adjustments now in an effort to reduce work in those milestones.
* No testing has been done for python scripting, since milestone C) has that
being largely reworked and re-thought-out.
2014-03-20 00:42:08 +00:00
|
|
|
class SEARCH_STACK;
|
2014-10-26 13:59:01 +00:00
|
|
|
class REPORTER;
|
* KIWAY Milestone A): Make major modules into DLL/DSOs.
! The initial testing of this commit should be done using a Debug build so that
all the wxASSERT()s are enabled. Also, be sure and keep enabled the
USE_KIWAY_DLLs option. The tree won't likely build without it. Turning it
off is senseless anyways. If you want stable code, go back to a prior version,
the one tagged with "stable".
* Relocate all functionality out of the wxApp derivative into more finely
targeted purposes:
a) DLL/DSO specific
b) PROJECT specific
c) EXE or process specific
d) configuration file specific data
e) configuration file manipulations functions.
All of this functionality was blended into an extremely large wxApp derivative
and that was incompatible with the desire to support multiple concurrently
loaded DLL/DSO's ("KIFACE")s and multiple concurrently open projects.
An amazing amount of organization come from simply sorting each bit of
functionality into the proper box.
* Switch to wxConfigBase from wxConfig everywhere except instantiation.
* Add classes KIWAY, KIFACE, KIFACE_I, SEARCH_STACK, PGM_BASE, PGM_KICAD,
PGM_SINGLE_TOP,
* Remove "Return" prefix on many function names.
* Remove obvious comments from CMakeLists.txt files, and from else() and endif()s.
* Fix building boost for use in a DSO on linux.
* Remove some of the assumptions in the CMakeLists.txt files that windows had
to be the host platform when building windows binaries.
* Reduce the number of wxStrings being constructed at program load time via
static construction.
* Pass wxConfigBase* to all SaveSettings() and LoadSettings() functions so that
these functions are useful even when the wxConfigBase comes from another
source, as is the case in the KICAD_MANAGER_FRAME.
* Move the setting of the KIPRJMOD environment variable into class PROJECT,
so that it can be moved into a project variable soon, and out of FP_LIB_TABLE.
* Add the KIWAY_PLAYER which is associated with a particular PROJECT, and all
its child wxFrames and wxDialogs now have a Kiway() member function which
returns a KIWAY& that that window tree branch is in support of. This is like
wxWindows DNA in that child windows get this member with proper value at time
of construction.
* Anticipate some of the needs for milestones B) and C) and make code
adjustments now in an effort to reduce work in those milestones.
* No testing has been done for python scripting, since milestone C) has that
being largely reworked and re-thought-out.
2014-03-20 00:42:08 +00:00
|
|
|
|
2008-04-24 16:55:35 +00:00
|
|
|
/**
|
2018-05-07 15:47:16 +00:00
|
|
|
* Run a command in a child process.
|
|
|
|
*
|
2020-12-18 14:04:03 +00:00
|
|
|
* @param aCommandLine The process and any arguments to it all in a single string.
|
2008-04-24 16:55:35 +00:00
|
|
|
* @param aFlags The same args as allowed for wxExecute()
|
2013-01-18 10:42:23 +00:00
|
|
|
* @param callback wxProcess implementing OnTerminate to be run when the
|
|
|
|
child process finishes
|
2020-12-18 14:04:03 +00:00
|
|
|
* @return pid of process, 0 in case of error (like return values of wxExecute()).
|
2008-04-24 16:55:35 +00:00
|
|
|
*/
|
2013-01-18 10:42:23 +00:00
|
|
|
int ProcessExecute( const wxString& aCommandLine, int aFlags = wxEXEC_ASYNC,
|
2020-12-18 14:04:03 +00:00
|
|
|
wxProcess *callback = nullptr );
|
2008-04-24 16:55:35 +00:00
|
|
|
|
2014-04-14 18:49:52 +00:00
|
|
|
/**
|
2018-05-07 15:47:16 +00:00
|
|
|
* Return the help file's full path.
|
2021-04-05 17:03:36 +00:00
|
|
|
*
|
|
|
|
* Return the full path and name (including extension) of the given KiCad help file. It is expected
|
|
|
|
* to be found in a subfolder help/\<_LANG_\>/ in one of the system paths. Supported file types are
|
|
|
|
* *.html and *.pdf. If no such file is available for the current locale, an attempt to find the
|
|
|
|
* English version is made. The search order for \<_LANG_\> is: 1) canonical form (e.g., "fr_FR"),
|
|
|
|
* 2) short form (e.g., "fr"), and 3) "en".
|
|
|
|
*
|
|
|
|
* @param aBaseName is the name of the help file to search for (without extension).
|
|
|
|
* @return the full path and filename if \a aBaseName is found, else wxEmptyString.
|
2014-04-14 18:49:52 +00:00
|
|
|
*/
|
2021-04-05 17:03:36 +00:00
|
|
|
wxString SearchHelpFileFullPath( const wxString& aBaseName );
|
2014-04-14 18:49:52 +00:00
|
|
|
|
2014-10-26 13:59:01 +00:00
|
|
|
/**
|
2018-05-07 15:47:16 +00:00
|
|
|
* Make \a aTargetFullFileName absolute and create the path of this file if it doesn't yet exist.
|
|
|
|
*
|
|
|
|
* @param aTargetFullFileName the wxFileName containing the full path and file name to modify.
|
|
|
|
* The path may be absolute or relative to \a aBaseFilename .
|
2014-10-26 13:59:01 +00:00
|
|
|
* @param aBaseFilename a full filename. Only its path is used to set the aTargetFullFileName path.
|
|
|
|
* @param aReporter a point to a REPORTER object use to show messages (can be NULL)
|
|
|
|
* @return true if \a aOutputDir already exists or was successfully created.
|
|
|
|
*/
|
|
|
|
bool EnsureFileDirectoryExists( wxFileName* aTargetFullFileName,
|
2018-05-07 15:47:16 +00:00
|
|
|
const wxString& aBaseFilename,
|
2020-12-18 14:04:03 +00:00
|
|
|
REPORTER* aReporter = nullptr );
|
2014-10-26 13:59:01 +00:00
|
|
|
|
2014-12-23 13:01:59 +00:00
|
|
|
/**
|
2020-04-05 19:51:48 +00:00
|
|
|
* Replace any environment variable & text variable references with their values.
|
2018-05-07 15:47:16 +00:00
|
|
|
*
|
2020-12-18 14:04:03 +00:00
|
|
|
* @param aString a string containing (perhaps) references to env var
|
|
|
|
* @return the expanded environment variable.
|
2014-12-23 13:01:59 +00:00
|
|
|
*/
|
2020-04-05 19:51:48 +00:00
|
|
|
const wxString ExpandEnvVarSubstitutions( const wxString& aString, PROJECT* aProject );
|
2014-12-23 13:01:59 +00:00
|
|
|
|
2020-03-26 11:02:59 +00:00
|
|
|
/**
|
|
|
|
* Expand '${var-name}' templates in text. The LocalResolver is given first crack at it,
|
|
|
|
* after which the PROJECT's resolver is called.
|
|
|
|
*/
|
|
|
|
wxString ExpandTextVars( const wxString& aSource,
|
2020-04-05 19:51:48 +00:00
|
|
|
const std::function<bool( wxString* )>* aLocalResolver,
|
2021-01-17 15:47:04 +00:00
|
|
|
const std::function<bool( wxString* )>* aFallbackResolver,
|
|
|
|
const PROJECT* aProject );
|
|
|
|
|
|
|
|
wxString ExpandTextVars( const wxString& aSource, const PROJECT* aProject );
|
2020-03-26 11:02:59 +00:00
|
|
|
|
2018-03-08 22:57:31 +00:00
|
|
|
/**
|
2020-04-05 19:51:48 +00:00
|
|
|
* Replace any environment and/or text variables in file-path uris (leaving network-path URIs
|
|
|
|
* alone).
|
2018-03-08 22:57:31 +00:00
|
|
|
*/
|
2020-04-05 19:51:48 +00:00
|
|
|
const wxString ResolveUriByEnvVars( const wxString& aUri, PROJECT* aProject );
|
2018-03-08 22:57:31 +00:00
|
|
|
|
2019-05-28 10:57:30 +00:00
|
|
|
|
2018-08-05 11:56:02 +00:00
|
|
|
long long TimestampDir( const wxString& aDirPath, const wxString& aFilespec );
|
2018-08-03 16:53:38 +00:00
|
|
|
|
|
|
|
|
2011-11-24 17:32:51 +00:00
|
|
|
#endif // INCLUDE__COMMON_H_
|