mirror of
https://github.com/deskflow/deskflow.git
synced 2026-07-01 21:02:39 +08:00
* Restore Azure macOS dist scripts
* Move steps to workflow for testing
* Always upload to GitHub
* Add codesign ID
* Echo codesign ID
* Add cert import code
* Stub file for Mac
* Self-install pyyaml and choco
* Auto add env var on Windows
* Auto add CMAKE_PREFIX_PATH to .zshrc
* Shorter var names
* Append env var instead of replace
* Only set env var if not CI
* Improve function names and print output
* Simplify Linux package command
* Support continuation sequence
* Add note about Windows
* Remove dead doc file
* Tidy up version file and move to .env format
* Use Python venv for deps
* Only use venv on Mac
* Rename package script for all OS
* Add package and dist steps, and use common upload
* Remove version source
* Fixed vars not available
* Fixed python paths
* Use RuntimeError which is sufficient
* Remove dead code
* Add extras command for Linux
* Always install deps on Linux
* Move Python deps to CI
* More env bootstrapping, ugh
* Forgot to return!
* Simplify code
* Use shell
* Simplify command
* Skip sudo if no sudo
* Update package managers
* Fixed Fedora package name
* Tidy up commands
* Use newer upload artifact
* Strip don't trim!
* Check for version file and reduce log verbosity
* Remove CentOS 7.6
* Print more info about return code and log more to stderr
* Install certificate on macOS
* Better errors for no env var
* Implement Mac signing and notary
* Move dmgbuild load
* Simplify notary
* Rename dist files to same as dest
* Fixed paths for dist
* Move checked-in dist files to res (dist is meant to be a temp dir)
* Fixed Mac path in CMake
* Fixed dmg path
* Format Python
* Ignore import warnings and move function
* Fixed cmake paths
* Add missing env var secrets
* Remove extensions from GH upload
* Make deps.yml general purpose config
* Add cspell config
* Pass codesign ID
* Use new general config file
* Sign bundle on Mac
* Move imports to functions
* Escape chars in docs
* Fixed config key accessor
* Change module import order
* Move file to tmp dir in workflow dir
* Persist temp dir
* Add tmp dir to ignore
* Flush stdio before running process
* Trying quotes around env values
* Add codesigning certificate validation for Mac signing
* Revert "Trying quotes around env values"
This reverts commit 0dd741e8cd.
* Extract codesign verify
* Fixed version number
* Ignore .cache dir
* Fix macro name
* Package name with version number and arch
* Improve package function readability
* Change order of vars
* Testing upload to GDrive
* Add missing return code
* Use positional args and declare error
* Use machine instead of arch and remove build from filename
* Remove redundant build jobs
* Replace massively over-complicated `build_version.py` script
* Move version info to env module
* Use version info script
* Fixed: too many values to unpack
* Chmod version script
* Use shebang
* Don't check return code on Linux
* Fixed function name
* Convert to GitHub specific script
* Env vars must be after configure
* Fixed Windows env var command
* Remove && from deps command so it's not conditional
* Fixed position of set env
* Change order of env script
* Only upload when not draft
* Test
* Tweak config
* Fixed if condition
* Don't package in draft (Windows and Linux)
121 lines
3.9 KiB
Python
121 lines
3.9 KiB
Python
import ctypes
|
|
import sys
|
|
import os
|
|
import xml.etree.ElementTree as ET
|
|
from lib import cmd_utils
|
|
|
|
cmake_env_var = "CMAKE_PREFIX_PATH"
|
|
|
|
|
|
def relaunch_as_admin(script):
|
|
args = " ".join(sys.argv[1:])
|
|
command = f"{script} --pause-on-exit {args}"
|
|
print(f"Re-launching script as admin: {command}")
|
|
ctypes.windll.shell32.ShellExecuteW(None, "runas", sys.executable, command, None, 1)
|
|
|
|
|
|
def is_admin():
|
|
"""Returns True if the current process has admin privileges."""
|
|
try:
|
|
return ctypes.windll.shell32.IsUserAnAdmin()
|
|
except ctypes.WinError:
|
|
return False
|
|
|
|
|
|
def set_env_var(name, value):
|
|
"""
|
|
Sets or updates an environment variable. Appends the value if it doesn't already exist.
|
|
|
|
Args:
|
|
name (str): The name of the environment variable.
|
|
value (str): The value of the environment variable.
|
|
"""
|
|
|
|
current_value = os.getenv(name, "")
|
|
|
|
if value not in current_value:
|
|
new_value = f"{current_value}{os.pathsep}{value}" if current_value else value
|
|
os.environ[name] = new_value
|
|
print(f"Setting environment variable: {name}={value}")
|
|
cmd_utils.run(["setx", name, new_value], check=True)
|
|
|
|
|
|
class WindowsChoco:
|
|
"""Chocolatey for Windows."""
|
|
|
|
def install(self, command, ci_env):
|
|
"""Installs packages using Chocolatey."""
|
|
if ci_env:
|
|
# don't show noisy choco progress bars in ci env
|
|
cmd_utils.run(f"{command} --no-progress")
|
|
else:
|
|
cmd_utils.run("winget install chocolatey", check=False)
|
|
cmd_utils.run(command)
|
|
|
|
def config_ci_cache(self):
|
|
"""Configures Chocolatey cache for CI."""
|
|
|
|
runner_temp_key = "RUNNER_TEMP"
|
|
runner_temp = os.environ.get(runner_temp_key)
|
|
if runner_temp:
|
|
# sets the choco cache dir, which should match the dir in the ci cache action.
|
|
key_arg = '--name="cacheLocation"'
|
|
value_arg = f'--value="{runner_temp}/choco"'
|
|
cmd_utils.run(["choco", "config", "set", key_arg, value_arg])
|
|
else:
|
|
print(f"Warning: CI environment variable {runner_temp_key} not set")
|
|
|
|
def remove_from_config(self, choco_config_file, remove_packages):
|
|
"""Removes a package from the Chocolatey configuration."""
|
|
|
|
tree = ET.parse(choco_config_file)
|
|
root = tree.getroot()
|
|
for remove in remove_packages:
|
|
for package in root.findall("package"):
|
|
if package.get("id") == remove:
|
|
root.remove(package)
|
|
print(f"Removed package from choco config: {remove}")
|
|
|
|
tree.write(choco_config_file)
|
|
|
|
|
|
class WindowsQt:
|
|
"""Qt for Windows."""
|
|
|
|
def __init__(self, mirror_url, default_version, default_base_dir):
|
|
self.mirror_url = mirror_url
|
|
|
|
self.version = os.environ.get("QT_VERSION")
|
|
if not self.version:
|
|
print(f"QT_VERSION not set, using: {default_version}")
|
|
self.version = default_version
|
|
|
|
self.base_dir = os.environ.get("QT_BASE_DIR")
|
|
if not self.base_dir:
|
|
print(f"QT_BASE_DIR not set, using: {default_base_dir}")
|
|
self.base_dir = default_base_dir
|
|
|
|
self.install_dir = f"{self.base_dir}\\{self.version}"
|
|
|
|
def get_install_dir(self):
|
|
if os.path.isdir(self.install_dir):
|
|
return self.install_dir
|
|
|
|
def install(self):
|
|
"""Installs Qt on Windows."""
|
|
|
|
cmd_utils.run(["pip", "install", "aqtinstall"])
|
|
|
|
args = ["python", "-m", "aqt", "install-qt"]
|
|
args.extend(["--outputdir", self.base_dir])
|
|
args.extend(["--base", self.mirror_url])
|
|
args.extend(["windows", "desktop", self.version, "win64_msvc2019_64"])
|
|
cmd_utils.run(args)
|
|
|
|
install_dir = self.get_install_dir()
|
|
if not install_dir:
|
|
raise RuntimeError(f"Qt not installed, path not found: {install_dir}")
|
|
|
|
def set_env_vars(self):
|
|
set_env_var(cmake_env_var, f"{self.get_install_dir()}\\msvc2019_64")
|