You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

69 lines
2.3 KiB

  1. /*
  2. * This program source code file is part of KiCad, a free EDA CAD application.
  3. *
  4. * Copyright (C) 2023 Jon Evans <jon@craftyjon.com>
  5. * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
  6. *
  7. * This program is free software: you can redistribute it and/or modify it
  8. * under the terms of the GNU General Public License as published by the
  9. * Free Software Foundation, either version 3 of the License, or (at your
  10. * option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful, but
  13. * WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License along
  18. * with this program. If not, see <http://www.gnu.org/licenses/>.
  19. */
  20. #ifndef KICAD_PYTHON_MANAGER_H
  21. #define KICAD_PYTHON_MANAGER_H
  22. #include <functional>
  23. #include <optional>
  24. #include <wx/wx.h>
  25. #include <kicommon.h>
  26. class KICOMMON_API PYTHON_MANAGER
  27. {
  28. public:
  29. PYTHON_MANAGER( const wxString& aInterpreterPath );
  30. /**
  31. * Launches the Python interpreter with the given arguments
  32. * @param aArgs
  33. * @param aCallback
  34. * @param aEnv
  35. * @param aSaveOutput
  36. * @return the process ID of the created process, or 0 if one was not created
  37. */
  38. long Execute( const std::vector<wxString>& aArgs,
  39. const std::function<void(int, const wxString&, const wxString&)>& aCallback,
  40. const wxExecuteEnv* aEnv = nullptr,
  41. bool aSaveOutput = false );
  42. wxString GetInterpreterPath() const { return m_interpreterPath; }
  43. void SetInterpreterPath( const wxString& aPath ) { m_interpreterPath = aPath; }
  44. /**
  45. * Searches for a Python intepreter on the user's system
  46. * @return the absolute path to a Python interpreter, or an empty string if one was not found
  47. */
  48. static wxString FindPythonInterpreter();
  49. static std::optional<wxString> GetPythonEnvironment( const wxString& aNamespace );
  50. /// Returns a full path to the python binary in a venv, if it exists
  51. static std::optional<wxString> GetVirtualPython( const wxString& aNamespace );
  52. private:
  53. wxString m_interpreterPath;
  54. };
  55. #endif //KICAD_PYTHON_MANAGER_H