internal: refactor for packaging

Package using python-build, python-installer and hatch
This commit is contained in:
2 * r + 2 * t
2025-06-11 00:41:05 +10:00
parent 63d9381734
commit f663e6f690
42 changed files with 525 additions and 8 deletions
+11
View File
@@ -0,0 +1,11 @@
from argparse import Namespace
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
pass
+11
View File
@@ -0,0 +1,11 @@
from argparse import Namespace
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
pass
+11
View File
@@ -0,0 +1,11 @@
from argparse import Namespace
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
pass
+11
View File
@@ -0,0 +1,11 @@
from argparse import Namespace
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
pass
+11
View File
@@ -0,0 +1,11 @@
from argparse import Namespace
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
pass
+11
View File
@@ -0,0 +1,11 @@
from argparse import Namespace
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
pass
+41
View File
@@ -0,0 +1,41 @@
import subprocess
from argparse import Namespace
from caelestia import data
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
if self.args.show:
# Print the ipc
self.print_ipc()
elif self.args.log:
# Print the log
self.print_log()
elif self.args.message:
# Send a message
self.message(*self.args.message)
else:
# Start the shell
self.shell()
def shell(self, *args: list[str]) -> str:
return subprocess.check_output(["qs", "-p", data.c_data_dir / "shell", *args], text=True)
def print_ipc(self) -> None:
print(self.shell("ipc", "show"), end="")
def print_log(self) -> None:
log = self.shell("log")
# FIXME: remove when logging rules are added/warning is removed
for line in log.splitlines():
if "QProcess: Destroyed while process" not in line:
print(line)
def message(self, *args: list[str]) -> None:
print(self.shell("ipc", "call", *args), end="")
+82
View File
@@ -0,0 +1,82 @@
from argparse import Namespace
from caelestia.utils import hypr
class Command:
args: Namespace
clients: list[dict[str, any]] = None
app2unit: str = None
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
getattr(self, self.args.workspace)()
def get_clients(self) -> list[dict[str, any]]:
if self.clients is None:
self.clients = hypr.message("clients")
return self.clients
def get_app2unit(self) -> str:
if self.app2unit is None:
import shutil
self.app2unit = shutil.which("app2unit")
return self.app2unit
def move_client(self, selector: callable, workspace: str) -> None:
for client in self.get_clients():
if selector(client):
hypr.dispatch("movetoworkspacesilent", f"special:{workspace},address:{client['address']}")
def spawn_client(self, selector: callable, spawn: list[str]) -> bool:
exists = any(selector(client) for client in self.get_clients())
if not exists:
import subprocess
subprocess.Popen([self.get_app2unit(), "--", *spawn], start_new_session=True)
return not exists
def spawn_or_move(self, selector: callable, spawn: list[str], workspace: str) -> None:
if not self.spawn_client(selector, spawn):
self.move_client(selector, workspace)
def communication(self) -> None:
self.spawn_or_move(lambda c: c["class"] == "discord", ["discord"], "communication")
self.move_client(lambda c: c["class"] == "whatsapp", "communication")
def music(self) -> None:
self.spawn_or_move(
lambda c: c["class"] == "Spotify" or c["initialTitle"] == "Spotify" or c["initialTitle"] == "Spotify Free",
["spicetify", "watch", "-s"],
"music",
)
self.move_client(lambda c: c["class"] == "feishin", "music")
def sysmon(self) -> None:
self.spawn_client(
lambda c: c["class"] == "btop" and c["title"] == "btop" and c["workspace"]["name"] == "special:sysmon",
["foot", "-a", "btop", "-T", "btop", "--", "btop"],
"sysmon",
)
def todo(self) -> None:
self.spawn_or_move(lambda c: c["class"] == "Todoist", ["todoist"], "todo")
def specialws(self) -> None:
workspaces = hypr.message("workspaces")
on_special_ws = any(ws["name"] == "special:special" for ws in workspaces)
toggle_ws = "special"
if not on_special_ws:
active_ws = hypr.message("activewindow")["workspace"]["name"]
if active_ws.startswith("special:"):
toggle_ws = active_ws[8:]
hypr.dispatch("togglespecialworkspace", toggle_ws)
+11
View File
@@ -0,0 +1,11 @@
from argparse import Namespace
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
pass
+11
View File
@@ -0,0 +1,11 @@
from argparse import Namespace
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
pass
+18
View File
@@ -0,0 +1,18 @@
from argparse import Namespace
from caelestia.utils import hypr
class Command:
args: Namespace
def __init__(self, args: Namespace) -> None:
self.args = args
def run(self) -> None:
active_ws = hypr.message("activeworkspace")["id"]
if self.args.group:
hypr.dispatch(self.args.dispatcher, (self.args.workspace - 1) * 10 + active_ws % 10)
else:
hypr.dispatch(self.args.dispatcher, int((active_ws - 1) / 10) * 10 + self.args.workspace)