Skip to content

Latest commit

 

History

History
96 lines (81 loc) · 4.18 KB

readme.md

File metadata and controls

96 lines (81 loc) · 4.18 KB

Hierosoft Update

Solve Python distribution with a one-click install solution!

Integrate Python programs with the system in various ways:

  • Request an assigned directory where files can be placed such as for icons (pixmaps), shortcuts, or cache.
    • hierosoft.get_unique_path
      • Has an "allow_cloud" option to detect a Nextcloud or ownCloud directory containing a "profile" directory (for the "Configs:Unique" option)
  • Create a desktop shortcut in a way that works in any operating system.
    • from hierosoft.moreplatform import make_shortcut
  • Get more metadata such as for images.
    • hierosoft.moremeta
  • Emulate grep but also: Get a list of files; Process .gitignore files (and optionally get include and exclude filters for rsync).
    • from hierosoft.ggrep import (ggrep, gitignore_to_rsync_pair)
  • Emulate netcat but get callbacks during the upload.
    • from hierosoft.moreweb import netcat
  • See nonexistent paths that may be safe to remove from the environment's PATH variable.
    • hierosoft.checkpath
  • See if your repo's latest tag matches the version stored in your repo.
    • hierosoft.checkversion
  • Process URL requests in a Python 3 way regardless of the Python version.
    • hierosoft.moreweb

Filesystem shortcuts

Example projects

(using this module)

Core features

Hierosoft Update is the Python manager and virtualenv manager module to download or run a Python program such as an updated copy of:

  • itself
  • the Hierosoft Launcher (See Project Status).
  • any program (when used by the launcher or blendernightly)

Checkpath

To learn more, see the comment (docstring) at the top of checkpath.py.

Project Status

  • The gui_tk main function should be launched by the icon.
  • In Windows, Hierosoft Icon should be compiled as an exe such as using PyOxidizer so that it runs without having to install anything first.
  • Download and run itself (updated Python copy) as the main program which should run the launcher.
    • The process of installing apps should move to the launcher which should use the downloaded python version of this module.
  • Complete the launcher a separate project and run that instead of running a single program.
    • Potentially, nopackage could become the launcher or a component in the same virtualenv). It has the advantage of having download locations of icons for certain programs.
    • Make a special virtualenv named hierosoft-launcher that only contains what Hierosoft Launcher needs to operate, and a copy of Hierosoft Update.
  • Add https://pypi.org/project/eric-ide as a test case except use ~/.virtualenvs. Keep the eric7_venv directory if it exists in case manual steps were used prior.
    • Remember to include eric7_post_install.
  • Check for an existing venv directory such as if ~/venv/kivy were used according to manual instructions.

Development

Purpose

The purpose of Hierosoft Update is to ensure that the launcher can start, and serve as a platform for installing other Python programs as well. The way the Hierosoft Update works is by setting up a virtualenv for a program or set of programs after trying to detect the correct version of Python regardless of how the program is packaged.

The Python distribution dilemma is that programs are scripts users must open unless the author puts some custom system in place to install an icon and to do one of the following:

  • Ensure a correct Python version is installed, and where it is.
  • Compile the Python code into an exe such as using PyOxidizer.

The dilemma is that though solutions exist, there isn't a de facto standard other than solutions which already assume you have Python and require Command-Line Interface (CLI) commands.