mirror of
https://github.com/deskflow/deskflow.git
synced 2026-07-01 21:02:39 +08:00
* Add libei and libportal * Port libei and libportal code by Peter Hutterer and Olivier Fourdan * Add Peter Hutterer and Olivier Fourdan to important devs list * Improve error handling for libei and libportal builds * Checkout libportal tags/0.7.1 * Hack out the gi-docgen clone * Remove new submodules in favor of using ExternalProject_Add * Remove submodule dirs * Use ExternalProject_Add instead of submodules * Fixed namespace * Hack to work around type libportal causing type conflicts * Add log helper functions * Use original log functions * Switch to FetchContent, use libportal a1530a9 (unreleased) and use camelCase member names for consistency * Restore a few events (much more work required) * Add TODOs for supporting multiple lib versions * Revert "Switch to FetchContent, use libportal a1530a9 (unreleased) and use camelCase member names for consistency" This reverts commit610cebb5b6. * Simplify cmake config by removing builds for libei and libportal (will do this in `install_deps.py` instead) * Remove submodules * Remove .gitmodules * Use meson to build subprojects * Update copyright with Peter Hutterer's guidance * Use meson for installing deps * Fixed typo in tag name * Remove submodules * Remove old submodules * Fixed libei name * Defaults for pugixml and gtest depending on whether source exists in subprojects * Ignore some subproject dirs * Make deps OS-specific * Move python deps to pyproject * Only compile and install on Linux with Meson * Revert "Move python deps to pyproject" This reverts commit92c8a287b8. * Add ninja to brewfile * Add python3-attr * Restore original coverage config * Add ninja for meson * Include meson in same try-except * Fixed ninja dep name * Move libs to correct oS * Fixed include for wintoast * Disable docs for libportal * More options for libei and libportal * Fixed option for libei * Use ninja directly to install * Revert "Use ninja directly to install" This reverts commitc926d78ba4. * Meson install verbose * Prints stdout/stderr * Remove `from None` * Remove submodules that somehow crept back in?! * Prepend sudo if exists * Add libei deps for all distros * Fixed Fedora package name * Add more deps for other distros * Add more libs (including pugixml) * Fix lib name * Drop -u from pacman * Add vala to rhel * Make libportal optional * Make portal link optional * Remove example code * Always use system pugixml * Disable interactive apt through install_deps.py * Revert "Disable interactive apt through install_deps.py" This reverts commit5bbc8fd689. * Set DEBIAN_FRONTEND in workflows * Set DEBIAN_FRONTEND in CodeQL workflow * Add gtest dep * Add bundled libei dep * Add libei dep to Arch * Use `googletest` on openSUSE * Add gmock dep * Remove gtest dep from openSUSE * Add libei on Fedora * Bundle libei for older Linux distros * Disable libei dep for RPM * Also bundle symlink to .so * Use ${CMAKE_INSTALL_LIBDIR} * Rename libei to fix openSUSE * List installed files * Add libei-devel to openSUSE * Add googletest-devel to openSUSE * Remove manual deps (probably resolved automatically) * Remove googletest from openSUSE (doesn't provide google mock) * Only add Portal* if libportal found * WIP - Partial work on using old events system :'( * Add deps install commands for subprojects * Solved more compile issues related to events system, threads, etc * Fixed bad config for adding x, ei, portal sources * Remove redundant deps * Remove (another) redundant dep * Fixed pacman command * Add Ubuntu and Linux Mint libei deps * Fixed Ubuntu and Linux Mint libei deps aliases * Only iterate subprojects if not None * Add rhel, rocky, and alma for libei * Make rhel-like deps same as fedora again * Build libportal on rhel-like * Re-enable meson rhel-like for libportal * Remove dbus-python * Make libportal optional (for rhel-like) * Handle ei event queue results * Re-introduce libportal * Print libei and libportal versions * Add ei/portal args and client screen * Switch --use args to --no * Don't build libei/libportal on older distros as it's pointless * Make libei and libportal optional * Add Debian 13 runner * Make some packages optional * Remove subprojects * Improve comment * Add comment for libportal * Improve comment * Add Debian 13 runner * Make optional... optional * Change continuation stripper to remove newline and continuation char * Make command strip more uniform * Fixed help var syntax * Fixed libei linking * Ensure `kHelpNoWayland` is always defined * Improve help message * Fixed Debian 13 runner name * Include sstream and use const var * Update ChangeLog * Remove Wayland block * Return new timer * Make tray icon logging verbose * Fixed arg parser for wayland args * Fixed init of EI screen * Fixed lint issues * Update README to indicate Wayland support in GNOME 46 * Add missing word * Fixed comment positions * Automate CI env * Tone down debug log messages * Add missing comma * Remove redundant log line
115 lines
4.0 KiB
Python
115 lines
4.0 KiB
Python
import yaml
|
|
import lib.env as env
|
|
import lib.cmd_utils as cmd_utils
|
|
|
|
config_file = "config.yaml"
|
|
root_key = "config"
|
|
deps_key = "dependencies"
|
|
command_key = "command"
|
|
command_pre_key = "command-pre"
|
|
subprojects_key = "subprojects"
|
|
arrow = " ➤ "
|
|
|
|
|
|
class ConfigKeyError(RuntimeError):
|
|
def __init__(self, config_file, key):
|
|
self.config_file = config_file
|
|
self.key = key
|
|
|
|
def __str__(self):
|
|
return f"Not found in {self.config_file}: {self.key}"
|
|
|
|
|
|
def _get(dict, key, key_parent=None, required=True):
|
|
value = dict.get(key)
|
|
|
|
if required and not value:
|
|
key_path = f"{root_key}{arrow}{key_parent}{arrow}{key}" if key_parent else key
|
|
raise ConfigKeyError(config_file, key_path)
|
|
|
|
return value
|
|
|
|
|
|
class Config:
|
|
"""Reads the project configuration YAML file."""
|
|
|
|
def __init__(self):
|
|
|
|
with open(config_file, "r") as f:
|
|
data = yaml.safe_load(f)
|
|
|
|
self.os_name = env.get_os()
|
|
|
|
print("Config for OS:", self.os_name)
|
|
self.root = _get(data, root_key)
|
|
self.os = _get(self.root, self.os_name)
|
|
|
|
def get_os_value(self, key, required=True, linux_distro=None):
|
|
if linux_distro:
|
|
# recurse with the linux distro as the key parameter to get the base distro key.
|
|
distro = self.get_os_value(key=linux_distro)
|
|
return _get(distro, key, f"{self.os_name}{arrow}{linux_distro}", required)
|
|
else:
|
|
return _get(self.os, key, self.os_name, required)
|
|
|
|
def get_qt_config(self):
|
|
qt_key = "qt"
|
|
qt = self.get_os_deps_value(qt_key)
|
|
|
|
parent_key = f"{self.os_name}{arrow}{deps_key}"
|
|
mirror_url = _get(qt, "mirror", parent_key)
|
|
version = _get(qt, "version", parent_key)
|
|
base_dir = _get(qt, "base-dir", parent_key)
|
|
modules = _get(qt, "modules", parent_key, required=False)
|
|
|
|
return mirror_url, version, base_dir, modules
|
|
|
|
def get_os_deps_value(self, key, required=True, linux_distro=None):
|
|
deps = self.get_os_value(deps_key, required, linux_distro)
|
|
if linux_distro:
|
|
key_parent = f"{self.os_name}{arrow}{linux_distro}{arrow}{deps_key}"
|
|
else:
|
|
key_parent = f"{self.os_name}{arrow}{deps_key}"
|
|
return _get(deps, key, key_parent, required)
|
|
|
|
def get_os_deps_command(self, key=command_key, required=True, linux_distro=None):
|
|
command = self.get_os_deps_value(key, required, linux_distro)
|
|
if command:
|
|
return cmd_utils.strip_continuation_sequences(command)
|
|
else:
|
|
return None
|
|
|
|
def get_os_subprojects(self):
|
|
distro, _distro_like, _distro_version = env.get_linux_distro()
|
|
return self.get_os_value(subprojects_key, linux_distro=distro, required=False)
|
|
|
|
def get_subproject_deps_command(self, subproject_name):
|
|
subprojects = _get(self.root, subprojects_key)
|
|
subproject = _get(subprojects, subproject_name, subprojects_key)
|
|
deps_parent = f"{subprojects_key}{arrow}{subproject_name}"
|
|
deps = _get(subproject, deps_key, deps_parent)
|
|
|
|
if env.is_linux():
|
|
distro, _distro_like, _distro_version = env.get_linux_distro()
|
|
if not distro:
|
|
raise RuntimeError("Unable to detect Linux distro")
|
|
|
|
command = _get(deps, distro, f"{deps_parent}{arrow}{deps_key}")
|
|
else:
|
|
command = _get(deps, self.os_name, f"{deps_parent}{arrow}{deps_key}")
|
|
|
|
return cmd_utils.strip_continuation_sequences(command)
|
|
|
|
def get_os_deps_command_pre(self, required=True, linux_distro=None):
|
|
return self.get_os_deps_command(command_pre_key, required, linux_distro)
|
|
|
|
def get_windows_ci_config(self):
|
|
choco_ci_key = "ci"
|
|
choco_ci = self.get_os_deps_value(choco_ci_key)
|
|
|
|
choco_ci_path = f"{self.os_name}{arrow}{deps_key}{arrow}{choco_ci_key}"
|
|
edit_config = _get(choco_ci, "edit-config", choco_ci_path)
|
|
skip_packages = _get(choco_ci, "skip-packages", choco_ci_path)
|
|
|
|
return edit_config, skip_packages
|