machineconfig 8.14__py3-none-any.whl → 8.50__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of machineconfig might be problematic. Click here for more details.
- machineconfig/cluster/remote/run_cluster.py +1 -1
- machineconfig/cluster/remote/run_remote.py +1 -1
- machineconfig/cluster/sessions_managers/utils/maker.py +10 -8
- machineconfig/cluster/sessions_managers/wt_local.py +1 -1
- machineconfig/cluster/sessions_managers/wt_local_manager.py +1 -1
- machineconfig/cluster/sessions_managers/zellij_local.py +1 -1
- machineconfig/cluster/sessions_managers/zellij_local_manager.py +1 -1
- machineconfig/jobs/installer/checks/check_installations.py +133 -0
- machineconfig/jobs/installer/checks/install_utils.py +132 -0
- machineconfig/jobs/installer/checks/report_utils.py +39 -0
- machineconfig/jobs/installer/checks/vt_utils.py +89 -0
- machineconfig/jobs/installer/installer_data.json +225 -140
- machineconfig/jobs/installer/linux_scripts/docker.sh +6 -9
- machineconfig/jobs/installer/package_groups.py +10 -9
- machineconfig/jobs/installer/python_scripts/boxes.py +1 -2
- machineconfig/jobs/installer/python_scripts/code.py +10 -8
- machineconfig/jobs/installer/python_scripts/hx.py +30 -13
- machineconfig/jobs/installer/python_scripts/nerfont_windows_helper.py +6 -5
- machineconfig/jobs/installer/python_scripts/sysabc.py +25 -19
- machineconfig/jobs/installer/python_scripts/yazi.py +33 -17
- machineconfig/jobs/scripts/powershell_scripts/cmatrix.ps1 +52 -0
- machineconfig/jobs/scripts/powershell_scripts/mount_ssh.ps1 +1 -1
- machineconfig/jobs/scripts_dynamic/a.py +413 -10
- machineconfig/profile/create_links.py +77 -20
- machineconfig/profile/create_links_export.py +63 -58
- machineconfig/profile/mapper_data.toml +30 -0
- machineconfig/profile/mapper_dotfiles.toml +253 -0
- machineconfig/scripts/python/agents.py +70 -172
- machineconfig/scripts/python/ai/initai.py +3 -1
- machineconfig/scripts/python/ai/scripts/__init__.py +1 -0
- machineconfig/scripts/python/ai/scripts/lint_and_type_check.ps1 +2 -0
- machineconfig/scripts/python/ai/scripts/lint_and_type_check.sh +7 -5
- machineconfig/scripts/python/ai/solutions/claude/claude.py +1 -1
- machineconfig/scripts/python/ai/solutions/cline/cline.py +1 -1
- machineconfig/scripts/python/ai/solutions/copilot/github_copilot.py +1 -1
- machineconfig/scripts/python/ai/solutions/copilot/instructions/python/dev.instructions.md +29 -0
- machineconfig/scripts/python/ai/solutions/crush/crush.py +1 -1
- machineconfig/scripts/python/ai/solutions/cursor/cursors.py +1 -1
- machineconfig/scripts/python/ai/solutions/gemini/gemini.py +1 -1
- machineconfig/scripts/python/ai/solutions/gemini/settings.json +3 -0
- machineconfig/scripts/python/ai/{solutions → utils}/generic.py +2 -15
- machineconfig/scripts/python/ai/utils/vscode_tasks.py +6 -3
- machineconfig/scripts/python/cloud.py +58 -11
- machineconfig/scripts/python/croshell.py +4 -156
- machineconfig/scripts/python/devops.py +57 -40
- machineconfig/scripts/python/devops_navigator.py +17 -3
- machineconfig/scripts/python/fire_jobs.py +8 -207
- machineconfig/scripts/python/ftpx.py +5 -225
- machineconfig/scripts/python/graph/cli_graph.json +8743 -0
- machineconfig/scripts/python/{env_manager → helper_env}/path_manager_tui.py +2 -2
- machineconfig/scripts/python/{env_manager → helpers/helper_env}/env_manager_tui.py +1 -1
- machineconfig/scripts/python/helpers/helper_env/path_manager_tui.py +228 -0
- machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/agentic_frameworks/fire_crush.py +1 -1
- machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/agentic_frameworks/fire_cursor_agents.py +1 -1
- machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/agentic_frameworks/fire_gemini.py +1 -1
- machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/agentic_frameworks/fire_qwen.py +1 -1
- machineconfig/scripts/python/helpers/helpers_agents/agents_impl.py +168 -0
- machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/fire_agents_help_launch.py +5 -5
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/cloud_copy.py +6 -6
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/cloud_mount.py +10 -5
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/cloud_sync.py +3 -3
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/helpers2.py +1 -1
- machineconfig/scripts/python/helpers/helpers_croshell/croshell_impl.py +225 -0
- machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/scheduler.py +4 -4
- machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/start_slidev.py +7 -6
- machineconfig/scripts/python/helpers/helpers_devops/backup_config.py +149 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_backup_retrieve.py +267 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_config.py +98 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_config_dotfile.py +274 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_data.py +76 -0
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/cli_nw.py +52 -72
- machineconfig/scripts/python/helpers/helpers_devops/cli_repos.py +274 -0
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/cli_self.py +40 -23
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/cli_share_file.py +44 -30
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/cli_share_server.py +26 -43
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/cli_share_terminal.py +12 -6
- machineconfig/scripts/python/helpers/helpers_devops/cli_ssh.py +167 -0
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/devops_status.py +12 -6
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/devops_update_repos.py +1 -1
- machineconfig/scripts/python/{interactive.py → helpers/helpers_devops/interactive.py} +68 -52
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/run_script.py +75 -58
- machineconfig/scripts/python/helpers/helpers_devops/themes/choose_starship_theme.ps1 +41 -0
- machineconfig/scripts/python/helpers/helpers_devops/themes/choose_starship_theme.sh +48 -0
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/themes/choose_wezterm_theme.py +3 -3
- machineconfig/scripts/python/helpers/helpers_fire_command/fire_jobs_impl.py +233 -0
- machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/fire_jobs_route_helper.py +3 -3
- machineconfig/scripts/python/helpers/helpers_msearch/msearch_impl.py +248 -0
- machineconfig/scripts/python/{helpers_msearch → helpers/helpers_msearch}/scripts_linux/fzfg +4 -3
- machineconfig/scripts/python/helpers/helpers_msearch/scripts_linux/search_with_context.sh +48 -0
- machineconfig/scripts/python/{helpers_msearch → helpers/helpers_msearch}/scripts_windows/fzfg.ps1 +1 -1
- machineconfig/scripts/python/helpers/helpers_navigator/__init__.py +20 -0
- machineconfig/scripts/python/helpers/helpers_navigator/cli_graph_loader.py +234 -0
- machineconfig/scripts/python/{helpers_navigator → helpers/helpers_navigator}/command_builder.py +61 -13
- machineconfig/scripts/python/helpers/helpers_navigator/command_detail.py +153 -0
- machineconfig/scripts/python/helpers/helpers_navigator/command_tree.py +45 -0
- machineconfig/scripts/python/{helpers_navigator → helpers/helpers_navigator}/data_models.py +18 -11
- machineconfig/scripts/python/{helpers_navigator → helpers/helpers_navigator}/main_app.py +5 -5
- machineconfig/scripts/python/helpers/helpers_network/__init__.py +0 -0
- machineconfig/scripts/python/{helpers_network → helpers/helpers_network}/address.py +15 -17
- machineconfig/scripts/python/{helpers_network → helpers/helpers_network}/address_switch.py +1 -1
- machineconfig/scripts/python/helpers/helpers_network/ftpx_impl.py +276 -0
- machineconfig/scripts/python/{helpers_network → helpers/helpers_network}/mount_ssh.py +2 -2
- machineconfig/scripts/python/helpers/helpers_network/ssh_add_identity.py +73 -0
- machineconfig/scripts/python/helpers/helpers_network/ssh_add_ssh_key.py +175 -0
- machineconfig/scripts/python/helpers/helpers_network/ssh_debug_linux.py +319 -0
- machineconfig/scripts/python/helpers/helpers_network/ssh_debug_windows.py +275 -0
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/action.py +3 -3
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/action_helper.py +3 -3
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/cloud_repo_sync.py +117 -33
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/grource.py +3 -2
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/record.py +33 -13
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/repo_analyzer_2.py +63 -19
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/update.py +0 -6
- machineconfig/scripts/python/helpers/helpers_search/script_help.py +81 -0
- machineconfig/scripts/python/helpers/helpers_sessions/__init__.py +0 -0
- machineconfig/scripts/python/helpers/helpers_sessions/sessions_impl.py +186 -0
- machineconfig/scripts/python/{helpers_sessions → helpers/helpers_sessions}/sessions_multiprocess.py +1 -1
- machineconfig/scripts/python/helpers/helpers_terminal/__init__.py +0 -0
- machineconfig/scripts/python/helpers/helpers_terminal/terminal_impl.py +96 -0
- machineconfig/scripts/python/{helpers_utils → helpers/helpers_utils}/download.py +1 -1
- machineconfig/scripts/python/{helpers_utils → helpers/helpers_utils}/python.py +47 -26
- machineconfig/scripts/python/helpers/helpers_utils/specs.py +246 -0
- machineconfig/scripts/python/mcfg_entry.py +133 -48
- machineconfig/scripts/python/msearch.py +15 -61
- machineconfig/scripts/python/sessions.py +59 -194
- machineconfig/scripts/python/terminal.py +18 -96
- machineconfig/scripts/python/utils.py +101 -20
- machineconfig/settings/atuin/config.toml +294 -0
- machineconfig/settings/atuin/themes/catppuccin-mocha-mauve.toml +12 -0
- machineconfig/settings/linters/.ruff.toml +1 -0
- machineconfig/settings/mprocs/windows/mprocs.yaml +2 -2
- machineconfig/settings/shells/bash/init.sh +6 -3
- machineconfig/settings/shells/pwsh/init.ps1 +69 -1
- machineconfig/settings/shells/pwsh/search_pwsh_history.ps1 +99 -0
- machineconfig/settings/shells/wezterm/wezterm.lua +4 -1
- machineconfig/settings/shells/wt/settings.json +20 -7
- machineconfig/settings/shells/zsh/init.sh +25 -4
- machineconfig/settings/television/cable_unix/bash-history.toml +1 -1
- machineconfig/settings/television/cable_windows/pwsh-history.toml +1 -1
- machineconfig/settings/tv/config.toml +234 -0
- machineconfig/settings/tv/themes/catppuccin-mocha-sky.toml +22 -0
- machineconfig/settings/wsl/.wslconfig +5 -30
- machineconfig/settings/yazi/yazi_linux.toml +18 -8
- machineconfig/settings/zellij/layouts/st.kdl +2 -2
- machineconfig/settings/zellij/layouts/st2.kdl +1 -1
- machineconfig/setup_linux/web_shortcuts/interactive.sh +10 -10
- machineconfig/setup_linux/web_shortcuts/live_from_github.sh +3 -0
- machineconfig/setup_mac/__init__.py +0 -2
- machineconfig/setup_windows/__init__.py +0 -1
- machineconfig/setup_windows/web_shortcuts/interactive.ps1 +14 -13
- machineconfig/setup_windows/web_shortcuts/live_from_github.ps1 +4 -3
- machineconfig/setup_windows/web_shortcuts/quick_init.ps1 +3 -3
- machineconfig/type_hinting/sql/__init__.py +1 -0
- machineconfig/type_hinting/sql/base.py +216 -0
- machineconfig/type_hinting/sql/core_schema.py +64 -0
- machineconfig/type_hinting/sql/core_schema_typeddict.py +41 -0
- machineconfig/type_hinting/sql/typeddict_codegen.py +222 -0
- machineconfig/type_hinting/typedict/__init__.py +1 -0
- machineconfig/type_hinting/typedict/ast_utils.py +130 -0
- machineconfig/type_hinting/typedict/generator_helpers.py +319 -0
- machineconfig/type_hinting/typedict/generators.py +231 -0
- machineconfig/type_hinting/typedict/polars_schema.py +24 -0
- machineconfig/type_hinting/typedict/polars_schema_typeddict.py +63 -0
- machineconfig/utils/accessories.py +24 -0
- machineconfig/utils/code.py +41 -13
- machineconfig/utils/files/ascii_art.py +10 -14
- machineconfig/utils/files/headers.py +3 -5
- machineconfig/utils/files/read.py +8 -1
- machineconfig/utils/installer_utils/github_release_bulk.py +11 -91
- machineconfig/utils/installer_utils/github_release_scraper.py +99 -0
- machineconfig/utils/installer_utils/install_from_url.py +1 -1
- machineconfig/utils/installer_utils/installer_class.py +12 -4
- machineconfig/utils/installer_utils/installer_cli.py +1 -15
- machineconfig/utils/installer_utils/installer_helper.py +2 -2
- machineconfig/utils/installer_utils/installer_locator_utils.py +13 -13
- machineconfig/utils/installer_utils/installer_runner.py +4 -4
- machineconfig/utils/io.py +25 -8
- machineconfig/utils/meta.py +6 -4
- machineconfig/utils/options.py +49 -19
- machineconfig/utils/options_utils/__init__.py +0 -0
- machineconfig/utils/options_utils/options_tv_linux.py +211 -0
- machineconfig/utils/options_utils/options_tv_windows.py +88 -0
- machineconfig/utils/options_utils/tv_options.py +37 -0
- machineconfig/utils/path_extended.py +6 -6
- machineconfig/utils/scheduler.py +8 -2
- machineconfig/utils/schemas/fire_agents/fire_agents_input.py +1 -1
- machineconfig/utils/source_of_truth.py +6 -1
- machineconfig/utils/ssh.py +69 -18
- machineconfig/utils/ssh_utils/abc.py +1 -1
- machineconfig/utils/ssh_utils/copy_from_here.py +17 -12
- machineconfig/utils/ssh_utils/utils.py +21 -5
- machineconfig/utils/ssh_utils/wsl.py +107 -170
- machineconfig/utils/ssh_utils/wsl_helper.py +217 -0
- machineconfig/utils/upgrade_packages.py +4 -8
- {machineconfig-8.14.dist-info → machineconfig-8.50.dist-info}/METADATA +29 -22
- {machineconfig-8.14.dist-info → machineconfig-8.50.dist-info}/RECORD +251 -211
- machineconfig/jobs/installer/check_installations.py +0 -248
- machineconfig/profile/backup.toml +0 -49
- machineconfig/profile/mapper.toml +0 -263
- machineconfig/scripts/python/helpers_devops/cli_config.py +0 -105
- machineconfig/scripts/python/helpers_devops/cli_config_dotfile.py +0 -89
- machineconfig/scripts/python/helpers_devops/cli_data.py +0 -25
- machineconfig/scripts/python/helpers_devops/cli_repos.py +0 -208
- machineconfig/scripts/python/helpers_devops/devops_backup_retrieve.py +0 -80
- machineconfig/scripts/python/helpers_devops/themes/choose_starship_theme.bash +0 -3
- machineconfig/scripts/python/helpers_navigator/__init__.py +0 -20
- machineconfig/scripts/python/helpers_navigator/command_detail.py +0 -44
- machineconfig/scripts/python/helpers_navigator/command_tree.py +0 -620
- machineconfig/scripts/python/helpers_network/ssh_add_identity.py +0 -116
- machineconfig/scripts/python/helpers_network/ssh_add_ssh_key.py +0 -153
- machineconfig/scripts/python/helpers_network/ssh_debug_linux.py +0 -391
- machineconfig/scripts/python/helpers_network/ssh_debug_windows.py +0 -338
- machineconfig/scripts/python/helpers_repos/entrypoint.py +0 -77
- machineconfig/setup_mac/ssh/openssh_setup.sh +0 -114
- machineconfig/setup_windows/ssh/add-sshkey.ps1 +0 -29
- machineconfig/setup_windows/ssh/openssh-server.ps1 +0 -37
- machineconfig/utils/options_tv.py +0 -119
- machineconfig/utils/tst.py +0 -20
- /machineconfig/{scripts/python/helpers_agents → jobs/installer/checks}/__init__.py +0 -0
- /machineconfig/scripts/python/ai/{solutions/_shared.py → utils/shared.py} +0 -0
- /machineconfig/scripts/python/{helpers_agents/agentic_frameworks → graph}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_cloud → helpers}/__init__.py +0 -0
- /machineconfig/scripts/python/{env_manager → helpers/helper_env}/__init__.py +0 -0
- /machineconfig/scripts/python/{env_manager → helpers/helper_env}/path_manager_backend.py +0 -0
- /machineconfig/scripts/python/{helpers_croshell → helpers/helpers_agents}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_devops → helpers/helpers_agents/agentic_frameworks}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/agentic_frameworks/fire_crush.json +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/fire_agents_help_search.py +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/fire_agents_helper_types.py +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/fire_agents_load_balancer.py +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/privacy/configs/aichat/config.yaml +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/privacy/configs/aider/.aider.conf.yml +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/privacy/configs/copilot/config.yml +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/privacy/configs/crush/crush.json +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/privacy/configs/gemini/settings.json +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/privacy/privacy.py +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/templates/prompt.txt +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/templates/template.ps1 +0 -0
- /machineconfig/scripts/python/{helpers_agents → helpers/helpers_agents}/templates/template.sh +0 -0
- /machineconfig/scripts/python/{helpers_devops/themes → helpers/helpers_cloud}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/cloud_helpers.py +0 -0
- /machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/helpers5.py +0 -0
- /machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_croshell}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/crosh.py +0 -0
- /machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/pomodoro.py +0 -0
- /machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/viewer.py +0 -0
- /machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/viewer_template.py +0 -0
- /machineconfig/scripts/python/{helpers_network → helpers/helpers_devops}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_sessions → helpers/helpers_devops/themes}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/themes/choose_pwsh_theme.ps1 +0 -0
- /machineconfig/scripts/python/{helpers_devops/themes/choose_starship_theme.ps1 → helpers/helpers_fire_command/__init__.py} +0 -0
- /machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/cloud_manager.py +0 -0
- /machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/f.py +0 -0
- /machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/file_wrangler.py +0 -0
- /machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/fire_jobs_args_helper.py +0 -0
- /machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/fire_jobs_streamlit_helper.py +0 -0
- /machineconfig/scripts/python/{helpers_msearch → helpers/helpers_msearch}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_navigator → helpers/helpers_navigator}/search_bar.py +0 -0
- /machineconfig/scripts/python/{helpers_network → helpers/helpers_network}/mount_nfs.py +0 -0
- /machineconfig/scripts/python/{helpers_network → helpers/helpers_network}/mount_nw_drive.py +0 -0
- /machineconfig/scripts/python/{helpers_network → helpers/helpers_network}/onetimeshare.py +0 -0
- /machineconfig/scripts/python/{helpers_network → helpers/helpers_network}/wifi_conn.py +0 -0
- /machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/clone.py +0 -0
- /machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/repo_analyzer_1.py +0 -0
- /machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/sync.py +0 -0
- /machineconfig/scripts/python/helpers/{ast_search.py → helpers_search/ast_search.py} +0 -0
- /machineconfig/scripts/python/helpers/{qr_code.py → helpers_search/qr_code.py} +0 -0
- /machineconfig/scripts/python/helpers/{repo_rag.py → helpers_search/repo_rag.py} +0 -0
- /machineconfig/scripts/python/helpers/{symantic_search.py → helpers_search/symantic_search.py} +0 -0
- /machineconfig/scripts/python/{helpers_utils → helpers/helpers_utils}/pdf.py +0 -0
- {machineconfig-8.14.dist-info → machineconfig-8.50.dist-info}/WHEEL +0 -0
- {machineconfig-8.14.dist-info → machineconfig-8.50.dist-info}/entry_points.txt +0 -0
- {machineconfig-8.14.dist-info → machineconfig-8.50.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
"""Pure Python implementation for croshell command - no typer dependencies."""
|
|
2
|
+
|
|
3
|
+
from typing import Optional
|
|
4
|
+
from pathlib import Path
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
def croshell(
|
|
8
|
+
path: Optional[str],
|
|
9
|
+
project_path: Optional[str],
|
|
10
|
+
uv_with: Optional[str],
|
|
11
|
+
marimo: bool,
|
|
12
|
+
jupyter: bool,
|
|
13
|
+
vscode: bool,
|
|
14
|
+
visidata: bool,
|
|
15
|
+
python: bool,
|
|
16
|
+
profile: Optional[str],
|
|
17
|
+
) -> None:
|
|
18
|
+
"""Cross-shell command execution."""
|
|
19
|
+
interactivity = "-i"
|
|
20
|
+
interpreter = "python" if python else "ipython"
|
|
21
|
+
if uv_with is not None:
|
|
22
|
+
match interpreter:
|
|
23
|
+
case "ipython":
|
|
24
|
+
user_uv_with_line = f"--with {uv_with},ipython"
|
|
25
|
+
case "python":
|
|
26
|
+
user_uv_with_line = f"--with {uv_with}"
|
|
27
|
+
else:
|
|
28
|
+
match interpreter:
|
|
29
|
+
case "ipython":
|
|
30
|
+
user_uv_with_line = "--with ipython"
|
|
31
|
+
case "python":
|
|
32
|
+
user_uv_with_line = ""
|
|
33
|
+
|
|
34
|
+
if project_path is not None:
|
|
35
|
+
uv_project_line = f'--project {project_path}'
|
|
36
|
+
uv_python_line = ""
|
|
37
|
+
else:
|
|
38
|
+
uv_project_line = ""
|
|
39
|
+
uv_python_line = "--python 3.14"
|
|
40
|
+
|
|
41
|
+
from machineconfig.scripts.python.helpers.helpers_croshell.crosh import get_read_python_file_pycode, get_read_data_pycode
|
|
42
|
+
from machineconfig.utils.meta import lambda_to_python_script
|
|
43
|
+
from machineconfig.utils.accessories import randstr
|
|
44
|
+
from machineconfig.utils.ve import get_ve_path_and_ipython_profile
|
|
45
|
+
import json
|
|
46
|
+
from rich.console import Console
|
|
47
|
+
from rich.panel import Panel
|
|
48
|
+
console = Console()
|
|
49
|
+
|
|
50
|
+
ipython_profile: Optional[str] = profile
|
|
51
|
+
file_obj = Path.cwd()
|
|
52
|
+
if path is not None:
|
|
53
|
+
from machineconfig.utils.path_helper import get_choice_file
|
|
54
|
+
choice_file = get_choice_file(path=path, suffixes={".*"})
|
|
55
|
+
if project_path is None:
|
|
56
|
+
ve_path, _ = get_ve_path_and_ipython_profile(choice_file)
|
|
57
|
+
if ve_path is not None:
|
|
58
|
+
ve_path_obj = Path(ve_path)
|
|
59
|
+
uv_project_line = f'--project {ve_path_obj.parent}'
|
|
60
|
+
uv_python_line = ""
|
|
61
|
+
if choice_file.suffix == ".py":
|
|
62
|
+
program = choice_file.read_text(encoding="utf-8")
|
|
63
|
+
text = f"📄 Selected file: {choice_file.name}"
|
|
64
|
+
console.print(Panel(text, title="[bold blue]Info[/bold blue]"))
|
|
65
|
+
else:
|
|
66
|
+
program = lambda_to_python_script(
|
|
67
|
+
lambda: get_read_data_pycode(path=str(choice_file)),
|
|
68
|
+
in_global=True, import_module=False
|
|
69
|
+
)
|
|
70
|
+
text = f"📄 Reading data from: {file_obj.name}"
|
|
71
|
+
console.print(Panel(text, title="[bold blue]Info[/bold blue]"))
|
|
72
|
+
else:
|
|
73
|
+
program = ""
|
|
74
|
+
|
|
75
|
+
if Path.home().joinpath("code/machineconfig").exists() and uv_project_line == "":
|
|
76
|
+
uv_project_line = f'--project "{str(Path.home().joinpath("code/machineconfig"))}"'
|
|
77
|
+
|
|
78
|
+
preprogram = _build_preprogram()
|
|
79
|
+
|
|
80
|
+
pyfile = Path.home().joinpath(f"tmp_results/tmp_scripts/python/croshell/{randstr()}/script.py")
|
|
81
|
+
pyfile.parent.mkdir(parents=True, exist_ok=True)
|
|
82
|
+
title = "Reading Data"
|
|
83
|
+
def_code = lambda_to_python_script(
|
|
84
|
+
lambda: get_read_python_file_pycode(path=str(pyfile), title=title),
|
|
85
|
+
in_global=False, import_module=False
|
|
86
|
+
)
|
|
87
|
+
python_program = preprogram + "\n\n" + def_code + program
|
|
88
|
+
pyfile.write_text(python_program, encoding="utf-8")
|
|
89
|
+
ipython_profile = ipython_profile if ipython_profile is not None else "default"
|
|
90
|
+
|
|
91
|
+
nb_target = pyfile.with_suffix(".ipynb")
|
|
92
|
+
if jupyter:
|
|
93
|
+
try:
|
|
94
|
+
nb_path = pyfile.with_suffix(".ipynb")
|
|
95
|
+
nb_content = {
|
|
96
|
+
"cells": [
|
|
97
|
+
{
|
|
98
|
+
"cell_type": "code",
|
|
99
|
+
"metadata": {"language": "python"},
|
|
100
|
+
"source": [python_program],
|
|
101
|
+
"outputs": [],
|
|
102
|
+
"execution_count": None,
|
|
103
|
+
}
|
|
104
|
+
],
|
|
105
|
+
"metadata": {},
|
|
106
|
+
"nbformat": 4,
|
|
107
|
+
"nbformat_minor": 5,
|
|
108
|
+
}
|
|
109
|
+
nb_path.write_text(json.dumps(nb_content), encoding="utf-8")
|
|
110
|
+
nb_target = nb_path
|
|
111
|
+
except Exception:
|
|
112
|
+
pass
|
|
113
|
+
|
|
114
|
+
fire_line = _build_fire_line(
|
|
115
|
+
file_obj=file_obj,
|
|
116
|
+
pyfile=pyfile,
|
|
117
|
+
nb_target=nb_target,
|
|
118
|
+
visidata=visidata,
|
|
119
|
+
marimo=marimo,
|
|
120
|
+
jupyter=jupyter,
|
|
121
|
+
vscode=vscode,
|
|
122
|
+
interpreter=interpreter,
|
|
123
|
+
interactivity=interactivity,
|
|
124
|
+
ipython_profile=ipython_profile,
|
|
125
|
+
uv_python_line=uv_python_line,
|
|
126
|
+
uv_project_line=uv_project_line,
|
|
127
|
+
user_uv_with_line=user_uv_with_line,
|
|
128
|
+
uv_with=uv_with,
|
|
129
|
+
)
|
|
130
|
+
|
|
131
|
+
from machineconfig.utils.code import exit_then_run_shell_script
|
|
132
|
+
exit_then_run_shell_script(fire_line, strict=False)
|
|
133
|
+
|
|
134
|
+
|
|
135
|
+
def _build_preprogram() -> str:
|
|
136
|
+
"""Build the preprogram code for croshell."""
|
|
137
|
+
import inspect
|
|
138
|
+
import textwrap
|
|
139
|
+
from types import FunctionType
|
|
140
|
+
|
|
141
|
+
def get_body_simple_function_no_args(f: FunctionType) -> str:
|
|
142
|
+
return textwrap.dedent("\n".join(inspect.getsource(f).splitlines()[1:]))
|
|
143
|
+
|
|
144
|
+
preprogram = """
|
|
145
|
+
#%%
|
|
146
|
+
"""
|
|
147
|
+
|
|
148
|
+
def preprogram_func() -> None:
|
|
149
|
+
try:
|
|
150
|
+
from machineconfig.utils.files.headers import print_header, print_logo
|
|
151
|
+
print_header()
|
|
152
|
+
print_logo("Machineconfig")
|
|
153
|
+
from machineconfig.utils.path_extended import PathExtended
|
|
154
|
+
_ = PathExtended
|
|
155
|
+
except ImportError:
|
|
156
|
+
print("machineconfig is not installed in the current environment.")
|
|
157
|
+
pass
|
|
158
|
+
from pathlib import Path
|
|
159
|
+
_ = Path
|
|
160
|
+
|
|
161
|
+
preprogram += get_body_simple_function_no_args(preprogram_func)
|
|
162
|
+
return preprogram
|
|
163
|
+
|
|
164
|
+
|
|
165
|
+
def _build_fire_line(
|
|
166
|
+
file_obj: Path,
|
|
167
|
+
pyfile: Path,
|
|
168
|
+
nb_target: Path,
|
|
169
|
+
visidata: bool,
|
|
170
|
+
marimo: bool,
|
|
171
|
+
jupyter: bool,
|
|
172
|
+
vscode: bool,
|
|
173
|
+
interpreter: str,
|
|
174
|
+
interactivity: str,
|
|
175
|
+
ipython_profile: str,
|
|
176
|
+
uv_python_line: str,
|
|
177
|
+
uv_project_line: str,
|
|
178
|
+
user_uv_with_line: str,
|
|
179
|
+
uv_with: Optional[str],
|
|
180
|
+
) -> str:
|
|
181
|
+
"""Build the fire line command for croshell."""
|
|
182
|
+
if visidata:
|
|
183
|
+
if file_obj.suffix == ".json":
|
|
184
|
+
fire_line = f"uv run {uv_python_line} {user_uv_with_line} {uv_project_line} --with visidata vd {str(file_obj)}"
|
|
185
|
+
else:
|
|
186
|
+
fire_line = f"uv run {uv_python_line} {user_uv_with_line} {uv_project_line} --with visidata,pyarrow vd {str(file_obj)}"
|
|
187
|
+
elif marimo:
|
|
188
|
+
if Path.home().joinpath("code/machineconfig").exists():
|
|
189
|
+
requirements = f"""{user_uv_with_line} {uv_project_line} --with marimo,sqlglot """
|
|
190
|
+
else:
|
|
191
|
+
requirements = f"""{uv_python_line} {user_uv_with_line} {uv_project_line} --with "marimo,sqlglot,cowsay,machineconfig[plot]>=8.50" """
|
|
192
|
+
fire_line = f"""
|
|
193
|
+
cd {str(pyfile.parent)}
|
|
194
|
+
uv run {uv_python_line} --with "marimo" marimo convert {pyfile.name} -o marimo_nb.py
|
|
195
|
+
uv run {requirements} marimo edit --host 0.0.0.0 marimo_nb.py
|
|
196
|
+
"""
|
|
197
|
+
elif jupyter:
|
|
198
|
+
if Path.home().joinpath("code/machineconfig").exists():
|
|
199
|
+
requirements = f"""{user_uv_with_line} {uv_project_line} --with jupyterlab """
|
|
200
|
+
else:
|
|
201
|
+
requirements = f"""{user_uv_with_line} {uv_project_line} --with "cowsay,machineconfig[plot]>=8.50" """
|
|
202
|
+
fire_line = f"uv run {requirements} {uv_project_line} jupyter-lab {str(nb_target)}"
|
|
203
|
+
elif vscode:
|
|
204
|
+
user_uv_add = f"uv add {uv_with}" if uv_with is not None else ""
|
|
205
|
+
fire_line = f"""
|
|
206
|
+
cd {str(pyfile.parent)}
|
|
207
|
+
uv init {uv_python_line}
|
|
208
|
+
uv venv
|
|
209
|
+
uv add "cowsay,machineconfig[plot]>=8.50"
|
|
210
|
+
uv add {user_uv_add}
|
|
211
|
+
# code serve-web
|
|
212
|
+
code --new-window {str(pyfile)}
|
|
213
|
+
"""
|
|
214
|
+
else:
|
|
215
|
+
if interpreter == "ipython":
|
|
216
|
+
profile = f" --profile {ipython_profile} --no-banner"
|
|
217
|
+
else:
|
|
218
|
+
profile = ""
|
|
219
|
+
if Path.home().joinpath("code/machineconfig").exists():
|
|
220
|
+
ve_line = f"""{user_uv_with_line} {uv_project_line} """
|
|
221
|
+
else:
|
|
222
|
+
ve_line = f"""{uv_python_line} {user_uv_with_line} {uv_project_line} --with "cowsay,machineconfig[plot]>=8.50" """
|
|
223
|
+
fire_line = f"uv run {ve_line} {interpreter} {interactivity} {profile} {str(pyfile)}"
|
|
224
|
+
|
|
225
|
+
return fire_line
|
|
@@ -26,11 +26,11 @@
|
|
|
26
26
|
|
|
27
27
|
# print(f"\n✅ Running tasks in {root}\n")
|
|
28
28
|
|
|
29
|
-
#
|
|
30
|
-
#
|
|
31
|
-
#
|
|
29
|
+
# if args.report:
|
|
30
|
+
# print("📊 Generating report...")
|
|
31
|
+
# reports: list[Report] = [Report.from_path(read_task_from_dir(x).report_path) for x in PathExtended(root).glob("*")]
|
|
32
32
|
|
|
33
|
-
#
|
|
33
|
+
# Format as markdown table
|
|
34
34
|
# report_data = [r.__dict__ for r in reports]
|
|
35
35
|
# if report_data:
|
|
36
36
|
# # Get keys from first report
|
|
@@ -83,19 +83,20 @@ def main(
|
|
|
83
83
|
|
|
84
84
|
md_file = report_dir.joinpath("slides.md")
|
|
85
85
|
if not md_file.exists():
|
|
86
|
-
res = report_dir.
|
|
86
|
+
res = list(report_dir.glob("*.md"))
|
|
87
87
|
if len(res) == 1:
|
|
88
88
|
md_file = res[0]
|
|
89
89
|
else:
|
|
90
|
-
|
|
90
|
+
print(f"❌ Error: slides.md not found in {report_dir}")
|
|
91
|
+
raise typer.Exit(code=1)
|
|
91
92
|
|
|
92
93
|
print("📂 Copying files to Slidev repository...")
|
|
93
|
-
for item in report_dir.
|
|
94
|
-
item.copy(folder=SLIDEV_REPO, overwrite=True)
|
|
94
|
+
for item in report_dir.glob("*"):
|
|
95
|
+
PathExtended(item).copy(folder=SLIDEV_REPO, overwrite=True)
|
|
95
96
|
if md_file.name != "slides.md":
|
|
96
97
|
SLIDEV_REPO.joinpath(md_file.name).with_name(name="slides.md", inplace=True, overwrite=True)
|
|
97
98
|
|
|
98
|
-
import machineconfig.scripts.python.helpers_network.address as helper
|
|
99
|
+
import machineconfig.scripts.python.helpers.helpers_network.address as helper
|
|
99
100
|
res = helper.select_lan_ipv4(prefer_vpn=False)
|
|
100
101
|
if res is None:
|
|
101
102
|
print("❌ Error: Could not determine local LAN IPv4 address for presentation.")
|
|
@@ -107,7 +108,7 @@ def main(
|
|
|
107
108
|
print(f" - http://localhost:{port}")
|
|
108
109
|
print(f" - http://{local_ip_v4}:{port}\n")
|
|
109
110
|
|
|
110
|
-
program = "
|
|
111
|
+
program = "bun run dev slides.md -- --remote"
|
|
111
112
|
# PROGRAM_PATH.write_text(program, encoding="utf-8")
|
|
112
113
|
import subprocess
|
|
113
114
|
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
"""Backup configuration types, parsing, and reading utilities."""
|
|
2
|
+
|
|
3
|
+
from collections.abc import Mapping
|
|
4
|
+
from typing import TypedDict
|
|
5
|
+
from pathlib import Path
|
|
6
|
+
from rich.console import Console
|
|
7
|
+
from rich.panel import Panel
|
|
8
|
+
import tomllib
|
|
9
|
+
|
|
10
|
+
from machineconfig.utils.source_of_truth import LIBRARY_ROOT
|
|
11
|
+
from machineconfig.profile.create_links_export import REPO_LOOSE
|
|
12
|
+
|
|
13
|
+
LIBRARY_BACKUP_PATH = LIBRARY_ROOT.joinpath("profile/mapper_data.toml")
|
|
14
|
+
USER_BACKUP_PATH = Path.home().joinpath("dotfiles/machineconfig/mapper_data.toml")
|
|
15
|
+
DEFAULT_BACKUP_HEADER = "# User-defined backup configuration\n# Created by `devops data register`\n"
|
|
16
|
+
VALID_OS = {"any", "windows", "linux", "darwin"}
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
class BackupItem(TypedDict):
|
|
20
|
+
path_local: str
|
|
21
|
+
path_cloud: str | None
|
|
22
|
+
zip: bool
|
|
23
|
+
encrypt: bool
|
|
24
|
+
rel2home: bool
|
|
25
|
+
os: set[str]
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
BackupGroup = dict[str, BackupItem]
|
|
29
|
+
BackupConfig = dict[str, BackupGroup]
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
def normalize_os_name(value: str) -> str:
|
|
33
|
+
return value.strip().lower()
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
def _parse_os_field(os_field: object, item_name: str) -> set[str]:
|
|
37
|
+
if os_field is None:
|
|
38
|
+
raise ValueError(f"Backup entry '{item_name}' must define a non-empty 'os'.")
|
|
39
|
+
if isinstance(os_field, list):
|
|
40
|
+
raw_values = [str(item) for item in os_field]
|
|
41
|
+
elif isinstance(os_field, str):
|
|
42
|
+
raw_values = os_field.split(",")
|
|
43
|
+
else:
|
|
44
|
+
raise ValueError(f"Backup entry '{item_name}' has an invalid 'os' value: {os_field!r}.")
|
|
45
|
+
values: set[str] = set()
|
|
46
|
+
for raw in raw_values:
|
|
47
|
+
token = normalize_os_name(raw)
|
|
48
|
+
if not token:
|
|
49
|
+
continue
|
|
50
|
+
if token in {"any", "all", "*"}:
|
|
51
|
+
return {"any"}
|
|
52
|
+
if token not in VALID_OS:
|
|
53
|
+
raise ValueError(f"Backup entry '{item_name}' has an invalid 'os' value: {os_field!r}.")
|
|
54
|
+
values.add(token)
|
|
55
|
+
if not values:
|
|
56
|
+
raise ValueError(f"Backup entry '{item_name}' must define a non-empty 'os'.")
|
|
57
|
+
return values
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
def os_applies(os_values: set[str], system_name: str) -> bool:
|
|
61
|
+
return "any" in os_values or system_name in os_values
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
def _parse_bool(value: object, field: str, item_name: str) -> bool:
|
|
65
|
+
if isinstance(value, bool):
|
|
66
|
+
return value
|
|
67
|
+
raise ValueError(f"Backup entry '{item_name}' has an invalid '{field}' value.")
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
def _require_mapping(value: object, item_name: str) -> Mapping[str, object]:
|
|
71
|
+
if not isinstance(value, Mapping):
|
|
72
|
+
raise ValueError(f"Backup entry '{item_name}' must be a table.")
|
|
73
|
+
return value
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
def _require_str_field(raw: Mapping[str, object], field: str, item_name: str) -> str:
|
|
77
|
+
value = raw.get(field)
|
|
78
|
+
if not isinstance(value, str) or not value.strip():
|
|
79
|
+
raise ValueError(f"Backup entry '{item_name}' must define a non-empty '{field}'.")
|
|
80
|
+
return value.strip()
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
def _optional_str_field(raw: Mapping[str, object], field: str, item_name: str) -> str | None:
|
|
84
|
+
if field not in raw:
|
|
85
|
+
return None
|
|
86
|
+
value = raw.get(field)
|
|
87
|
+
if not isinstance(value, str):
|
|
88
|
+
raise ValueError(f"Backup entry '{item_name}' has a non-string '{field}'.")
|
|
89
|
+
token = value.strip()
|
|
90
|
+
if not token:
|
|
91
|
+
raise ValueError(f"Backup entry '{item_name}' has an empty '{field}'.")
|
|
92
|
+
return token
|
|
93
|
+
|
|
94
|
+
|
|
95
|
+
def _require_bool_field(raw: Mapping[str, object], field: str, item_name: str) -> bool:
|
|
96
|
+
if field not in raw:
|
|
97
|
+
raise ValueError(f"Backup entry '{item_name}' must define '{field}'.")
|
|
98
|
+
return _parse_bool(raw[field], field=field, item_name=item_name)
|
|
99
|
+
|
|
100
|
+
|
|
101
|
+
def _parse_backup_config(raw: Mapping[str, object]) -> BackupConfig:
|
|
102
|
+
config: BackupConfig = {}
|
|
103
|
+
for group_name, group_value in raw.items():
|
|
104
|
+
group = _require_mapping(group_value, group_name)
|
|
105
|
+
group_items: dict[str, BackupItem] = {}
|
|
106
|
+
for item_name, value in group.items():
|
|
107
|
+
item_key = f"{group_name}.{item_name}"
|
|
108
|
+
item = _require_mapping(value, item_key)
|
|
109
|
+
if "path" in item:
|
|
110
|
+
raise ValueError(f"Backup entry '{item_key}' uses 'path'; use 'path_local' instead.")
|
|
111
|
+
if "path_remote" in item:
|
|
112
|
+
raise ValueError(f"Backup entry '{item_key}' uses 'path_remote'; use 'path_cloud' instead.")
|
|
113
|
+
if "os_specific" in item:
|
|
114
|
+
raise ValueError(f"Backup entry '{item_key}' uses 'os_specific'; use 'os' only.")
|
|
115
|
+
group_items[item_name] = {
|
|
116
|
+
"path_local": _require_str_field(item, "path_local", item_key),
|
|
117
|
+
"path_cloud": _optional_str_field(item, "path_cloud", item_key),
|
|
118
|
+
"zip": _require_bool_field(item, "zip", item_key),
|
|
119
|
+
"encrypt": _require_bool_field(item, "encrypt", item_key),
|
|
120
|
+
"rel2home": _require_bool_field(item, "rel2home", item_key),
|
|
121
|
+
"os": _parse_os_field(item.get("os"), item_key),
|
|
122
|
+
}
|
|
123
|
+
if group_items:
|
|
124
|
+
config[group_name] = group_items
|
|
125
|
+
return config
|
|
126
|
+
|
|
127
|
+
|
|
128
|
+
def read_backup_config(repo: REPO_LOOSE) -> BackupConfig:
|
|
129
|
+
match repo:
|
|
130
|
+
case "library" | "l":
|
|
131
|
+
path = LIBRARY_BACKUP_PATH
|
|
132
|
+
raw_config: dict[str, object] = tomllib.loads(path.read_text(encoding="utf-8"))
|
|
133
|
+
bu_file = _parse_backup_config(raw_config)
|
|
134
|
+
case "user" | "u":
|
|
135
|
+
path = USER_BACKUP_PATH
|
|
136
|
+
raw_config = tomllib.loads(path.read_text(encoding="utf-8"))
|
|
137
|
+
bu_file = _parse_backup_config(raw_config)
|
|
138
|
+
case "all" | "a":
|
|
139
|
+
console = Console()
|
|
140
|
+
console.print(Panel(f"🧰 LOADING LIBRARY BACKUP CONFIGURATION\n📄 File: {LIBRARY_BACKUP_PATH}", title="[bold blue]Backup Configuration[/bold blue]", border_style="blue"))
|
|
141
|
+
raw_library: dict[str, object] = tomllib.loads(LIBRARY_BACKUP_PATH.read_text(encoding="utf-8"))
|
|
142
|
+
bu_library = _parse_backup_config(raw_library)
|
|
143
|
+
console.print(Panel(f"🧰 LOADING USER BACKUP CONFIGURATION\n📄 File: {USER_BACKUP_PATH}", title="[bold blue]Backup Configuration[/bold blue]", border_style="blue"))
|
|
144
|
+
raw_user: dict[str, object] = tomllib.loads(USER_BACKUP_PATH.read_text(encoding="utf-8"))
|
|
145
|
+
bu_user = _parse_backup_config(raw_user)
|
|
146
|
+
bu_file = {**bu_library, **bu_user}
|
|
147
|
+
case _:
|
|
148
|
+
raise ValueError(f"Invalid which_backup value: {repo!r}.")
|
|
149
|
+
return bu_file
|