* Only install Python deps with deps script * Remove hard-coded Qt version in CI * Add example .env * Improve comments in .env file * Simplify config reader and Choco CI config * Actually return the config value * Move deps before Qt version env call * Remove `self.` * Move venv ensure to main * Fixed arg * Move config import to function * Move ensure_module to function * Simplify over-complicated `Version.cmake` * Move code to `github` module * Use `symless/next-version-action` * Make CMake version file even simpler * Set version from tag * Create release when master or release branch * Don't run CI on master push, only release * Fixed bac macro * Use new version values * Handle empty version env var * Also strip version file value * Remove quotes * Add @master to action * Read version from file * Simplify version file read * Fixed typo in env var * Remove unused var * Delete legacy build number action * Fixed env var * Version file read shouldn't be needed * Remove weird and unnecessary include path * Update ChangeLog * Remove unused config value * Better name for changelog check * Delete broken Flatpak CI * Run stale issue cron at midnight * Update ChangeLog * Add version input for manual run * Print next version * Fetch all tags * Use more idiomatic approach * Set to pre-release when master * Remove unnecessary `commitish` * Fixed wrong ID * More specific IDs * Reduce config needed for upload * Only /release can be non-pre-release * More discreet package path for gdrive * Try without setting path * Remove seemly unused step * Better name for Qt version step * Fixed bad var ref * Better name for package dir * Fixed bad input name * Add missing shell * Workflow to test upload action * Remove fetch tags * Use bash to cut version * Remove name and make conditional * Replace deprecated set-output * Fixed env var name * Missing dir sep char * Add comment to test workflow * Improve input descriptions * Replace deprecated set-output
172 lines
4.8 KiB
Python
172 lines
4.8 KiB
Python
import os, sys, subprocess, platform
|
|
from lib import env, cmd_utils
|
|
|
|
venv_path = "build/python"
|
|
version_file = "VERSION"
|
|
version_env_var = "SYNERGY_VERSION"
|
|
|
|
|
|
def check_module(module):
|
|
try:
|
|
__import__(module)
|
|
return True
|
|
except ImportError:
|
|
print(f"Python is missing {module} module", file=sys.stderr)
|
|
return False
|
|
|
|
|
|
def get_os():
|
|
"""Detects the operating system."""
|
|
if sys.platform == "win32":
|
|
return "windows"
|
|
elif sys.platform == "darwin":
|
|
return "mac"
|
|
elif sys.platform.startswith("linux"):
|
|
return "linux"
|
|
else:
|
|
raise RuntimeError(f"Unsupported platform: {sys.platform}")
|
|
|
|
|
|
def is_windows():
|
|
return get_os() == "windows"
|
|
|
|
|
|
def is_mac():
|
|
return get_os() == "mac"
|
|
|
|
|
|
def is_linux():
|
|
return get_os() == "linux"
|
|
|
|
|
|
def is_running_in_ci():
|
|
"""Returns True if running in a CI environment."""
|
|
return os.environ.get("CI")
|
|
|
|
|
|
def get_linux_distro():
|
|
"""Detects the Linux distro."""
|
|
os_file = "/etc/os-release"
|
|
if os.path.isfile(os_file):
|
|
with open(os_file) as f:
|
|
for line in f:
|
|
if line.startswith("ID="):
|
|
return line.strip().split("=")[1].strip('"')
|
|
return None
|
|
|
|
|
|
def get_env_var(name):
|
|
"""Returns an env var or raises an error if it is not set."""
|
|
value = os.getenv(name)
|
|
if not value:
|
|
raise ValueError(f"Environment variable not set: {name}")
|
|
return value
|
|
|
|
|
|
def get_python_executable(binary="python"):
|
|
if sys.platform == "win32":
|
|
return os.path.join(venv_path, "Scripts", binary)
|
|
else:
|
|
return os.path.join(venv_path, "bin", binary)
|
|
|
|
|
|
def in_venv():
|
|
"""Returns True if the script is running in a Python virtual environment."""
|
|
return sys.prefix != sys.base_prefix
|
|
|
|
|
|
def ensure_in_venv(script):
|
|
"""
|
|
Ensures the script is running in a Python virtual environment (venv).
|
|
If the script is not running in a venv, it will create one and re-run the script in the venv.
|
|
"""
|
|
|
|
assert_dependencies()
|
|
import venv
|
|
|
|
if not in_venv():
|
|
if not os.path.exists(venv_path):
|
|
print(f"Creating virtual environment at {venv_path}")
|
|
venv.create(venv_path, with_pip=True)
|
|
|
|
script_file = os.path.basename(script)
|
|
print(f"Using virtual environment for {script_file}")
|
|
sys.stdout.flush()
|
|
python_executable = get_python_executable()
|
|
result = subprocess.run([python_executable, script] + sys.argv[1:])
|
|
sys.exit(result.returncode)
|
|
|
|
|
|
# TODO: Use requirements.txt or pyproject.toml to specify dependencies
|
|
def ensure_module(module, package):
|
|
"""
|
|
Ensures that a Python module is available, and installs the package if it is not.
|
|
"""
|
|
|
|
assert_dependencies()
|
|
|
|
try:
|
|
__import__(module)
|
|
except ImportError:
|
|
print(f"Python missing {module}, installing {package}...", file=sys.stderr)
|
|
cmd_utils.run([sys.executable, "-m", "pip", "install", package], shell=False)
|
|
|
|
|
|
def assert_dependencies(raise_error=True):
|
|
"""
|
|
Returns True if pip and venv are available.
|
|
"""
|
|
|
|
has_pip = check_module("pip")
|
|
has_venv = check_module("venv")
|
|
|
|
if raise_error:
|
|
if not has_pip:
|
|
raise RuntimeError("Python is missing pip")
|
|
if not has_venv:
|
|
raise RuntimeError("Python is missing venv")
|
|
else:
|
|
return has_pip and has_venv
|
|
|
|
|
|
def ensure_dependencies():
|
|
"""
|
|
Ensures that pip and venv are available, and installs them if they are not.
|
|
This is normally only installs on Linux, as Windows and Mac usually come with pip and venv.
|
|
"""
|
|
|
|
if assert_dependencies(raise_error=False):
|
|
return
|
|
|
|
print("Installing Python dependencies...")
|
|
|
|
os = get_os()
|
|
if os != "linux":
|
|
# should not be a problem, since windows and mac come with pip and venv
|
|
raise RuntimeError(f"Unable to install Python dependencies on {os}")
|
|
|
|
has_sudo = cmd_utils.has_command("sudo")
|
|
sudo = "sudo" if has_sudo else ""
|
|
|
|
distro = get_linux_distro()
|
|
if distro == "ubuntu" or distro == "debian":
|
|
cmd_utils.run(f"{sudo} apt update".strip(), check=False)
|
|
cmd_utils.run(f"{sudo} apt install -y python3-pip python3-venv".strip())
|
|
elif distro == "fedora" or distro == "centos":
|
|
cmd_utils.run(f"{sudo} dnf check-update".strip(), check=False)
|
|
cmd_utils.run(f"{sudo} dnf install -y python3-pip python3-virtualenv".strip())
|
|
else:
|
|
# arch, opensuse, etc, patches welcome! :)
|
|
raise RuntimeError(f"Unable to install Python dependencies on {distro}")
|
|
|
|
|
|
def get_app_version():
|
|
"""
|
|
Returns the version either from the env var, or from the version file.
|
|
"""
|
|
if version_env_var in os.environ:
|
|
return os.environ[version_env_var]
|
|
|
|
with open(version_file, "r") as f:
|
|
return f.read().strip()
|