mirror of
https://github.com/dw-0/kiauh.git
synced 2025-12-25 16:53:36 +05:00
refactor: replace os.path with Pathlib
- use config paths as type Paths instead of strings. - tweak some menu visuals. Signed-off-by: Dominik Willner <th33xitus@gmail.com>
This commit is contained in:
@@ -7,6 +7,7 @@
|
|||||||
# This file may be distributed under the terms of the GNU GPLv3 license #
|
# This file may be distributed under the terms of the GNU GPLv3 license #
|
||||||
# ======================================================================= #
|
# ======================================================================= #
|
||||||
import re
|
import re
|
||||||
|
from pathlib import Path
|
||||||
from subprocess import (
|
from subprocess import (
|
||||||
DEVNULL,
|
DEVNULL,
|
||||||
PIPE,
|
PIPE,
|
||||||
@@ -173,7 +174,7 @@ def start_flash_process(flash_options: FlashOptions) -> None:
|
|||||||
Logger.print_error("See the console output above!", end="\n\n")
|
Logger.print_error("See the console output above!", end="\n\n")
|
||||||
|
|
||||||
|
|
||||||
def run_make_clean(kconfig = '.config') -> None:
|
def run_make_clean(kconfig=Path(KLIPPER_DIR.joinpath(".config"))) -> None:
|
||||||
try:
|
try:
|
||||||
run(
|
run(
|
||||||
f"make KCONFIG_CONFIG={kconfig} clean",
|
f"make KCONFIG_CONFIG={kconfig} clean",
|
||||||
@@ -186,7 +187,7 @@ def run_make_clean(kconfig = '.config') -> None:
|
|||||||
raise
|
raise
|
||||||
|
|
||||||
|
|
||||||
def run_make_menuconfig(kconfig = '.config') -> None:
|
def run_make_menuconfig(kconfig=Path(KLIPPER_DIR.joinpath(".config"))) -> None:
|
||||||
try:
|
try:
|
||||||
run(
|
run(
|
||||||
f"make PYTHON=python3 KCONFIG_CONFIG={kconfig} menuconfig",
|
f"make PYTHON=python3 KCONFIG_CONFIG={kconfig} menuconfig",
|
||||||
@@ -199,7 +200,7 @@ def run_make_menuconfig(kconfig = '.config') -> None:
|
|||||||
raise
|
raise
|
||||||
|
|
||||||
|
|
||||||
def run_make(kconfig = '.config') -> None:
|
def run_make(kconfig=Path(KLIPPER_DIR.joinpath(".config"))) -> None:
|
||||||
try:
|
try:
|
||||||
run(
|
run(
|
||||||
f"make PYTHON=python3 KCONFIG_CONFIG={kconfig}",
|
f"make PYTHON=python3 KCONFIG_CONFIG={kconfig}",
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
import textwrap
|
import textwrap
|
||||||
from os import listdir, mkdir, path
|
from pathlib import Path
|
||||||
from shutil import copyfile
|
from shutil import copyfile
|
||||||
from typing import List, Set, Type
|
from typing import List, Set, Type
|
||||||
|
|
||||||
@@ -42,9 +42,10 @@ class KlipperKConfigMenu(BaseMenu):
|
|||||||
self.previous_menu: Type[BaseMenu] | None = previous_menu
|
self.previous_menu: Type[BaseMenu] | None = previous_menu
|
||||||
self.flash_options = FlashOptions()
|
self.flash_options = FlashOptions()
|
||||||
self.kconfigs_dirname = KLIPPER_KCONFIGS_DIR
|
self.kconfigs_dirname = KLIPPER_KCONFIGS_DIR
|
||||||
self.kconfig_default = path.join(KLIPPER_DIR, ".config")
|
self.kconfig_default = KLIPPER_DIR.joinpath(".config")
|
||||||
|
self.configs: List[Path] = []
|
||||||
self.kconfig = (
|
self.kconfig = (
|
||||||
self.kconfig_default if not path.isdir(self.kconfigs_dirname) else None
|
self.kconfig_default if not Path(self.kconfigs_dirname).is_dir() else None
|
||||||
)
|
)
|
||||||
|
|
||||||
def run(self) -> None:
|
def run(self) -> None:
|
||||||
@@ -61,21 +62,20 @@ class KlipperKConfigMenu(BaseMenu):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def set_options(self) -> None:
|
def set_options(self) -> None:
|
||||||
if not path.isdir(self.kconfigs_dirname):
|
if not Path(self.kconfigs_dirname).is_dir():
|
||||||
return
|
return
|
||||||
|
|
||||||
self.input_label_txt = "Select config or action to continue (default=n)"
|
self.input_label_txt = "Select config or action to continue (default=N)"
|
||||||
self.default_option = Option(
|
self.default_option = Option(
|
||||||
method=self.select_config, opt_data=self.kconfig_default
|
method=self.select_config, opt_data=self.kconfig_default
|
||||||
)
|
)
|
||||||
|
|
||||||
self.configs = []
|
|
||||||
option_index = 1
|
option_index = 1
|
||||||
for kconfig in listdir(self.kconfigs_dirname):
|
for kconfig in Path(self.kconfigs_dirname).iterdir():
|
||||||
if not kconfig.endswith(".config"):
|
if not kconfig.name.endswith(".config"):
|
||||||
continue
|
continue
|
||||||
kconfig_path = path.join(self.kconfigs_dirname, kconfig)
|
kconfig_path = self.kconfigs_dirname.joinpath(kconfig)
|
||||||
if path.isfile(kconfig_path):
|
if Path(kconfig_path).is_file():
|
||||||
self.configs += [kconfig]
|
self.configs += [kconfig]
|
||||||
self.options[str(option_index)] = Option(
|
self.options[str(option_index)] = Option(
|
||||||
method=self.select_config, opt_data=kconfig_path
|
method=self.select_config, opt_data=kconfig_path
|
||||||
@@ -86,26 +86,29 @@ class KlipperKConfigMenu(BaseMenu):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def print_menu(self) -> None:
|
def print_menu(self) -> None:
|
||||||
|
cfg_found_str = Color.apply(
|
||||||
|
"Previously saved firmware configs found!", Color.GREEN
|
||||||
|
)
|
||||||
menu = textwrap.dedent(
|
menu = textwrap.dedent(
|
||||||
"""
|
f"""
|
||||||
╟───────────────────────────────────────────────────────╢
|
╟───────────────────────────────────────────────────────╢
|
||||||
║ Found previously saved firmware configs ║
|
║ {cfg_found_str:^62} ║
|
||||||
║ ║
|
|
||||||
║ You can select existing firmware config or create a ║
|
|
||||||
║ new one. ║
|
|
||||||
║ ║
|
║ ║
|
||||||
|
║ Select an existing config or create a new one. ║
|
||||||
|
╟───────────────────────────────────────────────────────╢
|
||||||
|
║ Available firmware configs: ║
|
||||||
"""
|
"""
|
||||||
)[1:]
|
)[1:]
|
||||||
|
|
||||||
start_index = 1
|
start_index = 1
|
||||||
for i, s in enumerate(self.configs):
|
for i, s in enumerate(self.configs):
|
||||||
line = f"{start_index + i}) {s}"
|
line = f"{start_index + i}) {s.name}"
|
||||||
menu += f"║ {line:<54}║\n"
|
menu += f"║ {line:<54}║\n"
|
||||||
|
|
||||||
new_config = Color.apply("n) New firmware config", Color.YELLOW)
|
new_config = Color.apply("N) Create new firmware config", Color.GREEN)
|
||||||
menu += f"║ {new_config:<63}║\n"
|
|
||||||
|
|
||||||
menu += "║ ║\n"
|
menu += "║ ║\n"
|
||||||
|
menu += f"║ {new_config:<62} ║\n"
|
||||||
|
|
||||||
menu += "╟───────────────────────────────────────────────────────╢\n"
|
menu += "╟───────────────────────────────────────────────────────╢\n"
|
||||||
|
|
||||||
print(menu, end="")
|
print(menu, end="")
|
||||||
@@ -114,7 +117,7 @@ class KlipperKConfigMenu(BaseMenu):
|
|||||||
selection: str | None = kwargs.get("opt_data", None)
|
selection: str | None = kwargs.get("opt_data", None)
|
||||||
if selection is None:
|
if selection is None:
|
||||||
raise Exception("opt_data is None")
|
raise Exception("opt_data is None")
|
||||||
if not path.isfile(selection) and selection != self.kconfig_default:
|
if not Path(selection).is_file() and selection != self.kconfig_default:
|
||||||
raise Exception("opt_data does not exists")
|
raise Exception("opt_data does not exists")
|
||||||
self.kconfig = selection
|
self.kconfig = selection
|
||||||
|
|
||||||
@@ -133,7 +136,7 @@ class KlipperBuildFirmwareMenu(BaseMenu):
|
|||||||
self.missing_deps: List[str] = check_package_install(self.deps)
|
self.missing_deps: List[str] = check_package_install(self.deps)
|
||||||
self.flash_options = FlashOptions()
|
self.flash_options = FlashOptions()
|
||||||
self.kconfigs_dirname = KLIPPER_KCONFIGS_DIR
|
self.kconfigs_dirname = KLIPPER_KCONFIGS_DIR
|
||||||
self.kconfig_default = path.join(KLIPPER_DIR, ".config")
|
self.kconfig_default = KLIPPER_DIR.joinpath(".config")
|
||||||
self.kconfig = self.flash_options.selected_kconfig
|
self.kconfig = self.flash_options.selected_kconfig
|
||||||
|
|
||||||
def set_previous_menu(self, previous_menu: Type[BaseMenu] | None) -> None:
|
def set_previous_menu(self, previous_menu: Type[BaseMenu] | None) -> None:
|
||||||
@@ -243,19 +246,19 @@ class KlipperBuildFirmwareMenu(BaseMenu):
|
|||||||
"Enter the new firmware config name",
|
"Enter the new firmware config name",
|
||||||
regex=r"^[a-z0-9]+([a-z0-9-]*[a-z0-9])?$",
|
regex=r"^[a-z0-9]+([a-z0-9-]*[a-z0-9])?$",
|
||||||
)
|
)
|
||||||
filename = path.join(self.kconfigs_dirname, f"{input_name}.config")
|
filename = self.kconfigs_dirname.joinpath(f"{input_name}.config")
|
||||||
|
|
||||||
if path.isfile(filename):
|
if Path(filename).is_file():
|
||||||
if get_confirm(
|
if get_confirm(
|
||||||
f"Firmware config {input_name} already exists, overwrite?",
|
f"Firmware config {input_name} already exists, overwrite?",
|
||||||
default_choice=False,
|
default_choice=False,
|
||||||
):
|
):
|
||||||
break
|
break
|
||||||
|
|
||||||
if path.isdir(filename):
|
if Path(filename).is_dir():
|
||||||
Logger.print_error(f"Path {filename} exists and it's a directory")
|
Logger.print_error(f"Path {filename} exists and it's a directory")
|
||||||
|
|
||||||
if not path.exists(filename):
|
if not Path(filename).exists():
|
||||||
break
|
break
|
||||||
|
|
||||||
if not get_confirm(
|
if not get_confirm(
|
||||||
@@ -264,8 +267,8 @@ class KlipperBuildFirmwareMenu(BaseMenu):
|
|||||||
Logger.print_info("Aborted saving firmware config ...")
|
Logger.print_info("Aborted saving firmware config ...")
|
||||||
return
|
return
|
||||||
|
|
||||||
if not path.exists(self.kconfigs_dirname):
|
if not Path(self.kconfigs_dirname).exists():
|
||||||
mkdir(self.kconfigs_dirname)
|
Path(self.kconfigs_dirname).mkdir()
|
||||||
|
|
||||||
copyfile(self.kconfig_default, filename)
|
copyfile(self.kconfig_default, filename)
|
||||||
|
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ from __future__ import annotations
|
|||||||
|
|
||||||
import textwrap
|
import textwrap
|
||||||
import time
|
import time
|
||||||
from os.path import basename
|
from pathlib import Path
|
||||||
from typing import Type
|
from typing import Type
|
||||||
|
|
||||||
from components.klipper_firmware.firmware_utils import (
|
from components.klipper_firmware.firmware_utils import (
|
||||||
@@ -421,7 +421,7 @@ class KlipperFlashOverviewMenu(BaseMenu):
|
|||||||
mcu = self.flash_options.selected_mcu.split("/")[-1]
|
mcu = self.flash_options.selected_mcu.split("/")[-1]
|
||||||
board = self.flash_options.selected_board
|
board = self.flash_options.selected_board
|
||||||
baudrate = self.flash_options.selected_baudrate
|
baudrate = self.flash_options.selected_baudrate
|
||||||
kconfig = basename(self.flash_options.selected_kconfig)
|
kconfig = Path(self.flash_options.selected_kconfig).name
|
||||||
color = Color.CYAN
|
color = Color.CYAN
|
||||||
subheader = f"[{Color.apply('Overview', color)}]"
|
subheader = f"[{Color.apply('Overview', color)}]"
|
||||||
menu = textwrap.dedent(
|
menu = textwrap.dedent(
|
||||||
|
|||||||
Reference in New Issue
Block a user