1
0
Fork 0
mirror of https://codeberg.org/Mo8it/dotfiles.git synced 2024-12-04 23:40:32 +00:00

Compare commits

..

6 commits

Author SHA1 Message Date
c21b092d8d Update dprint md plugin 2024-08-08 13:42:09 +02:00
7618016ef7 Remove inlyne 2024-08-08 13:41:42 +02:00
8ca149ee44 Add todo alias 2024-08-08 13:36:55 +02:00
37da2ab864 Add fnm 2024-08-08 13:36:45 +02:00
c408b116ed Remove scripts 2024-08-08 13:36:32 +02:00
eb44bdf56d Remove zola alias 2024-06-25 18:36:32 +02:00
6 changed files with 4 additions and 303 deletions

View file

@ -11,7 +11,7 @@
],
"plugins": [
"https://plugins.dprint.dev/json-0.19.3.wasm",
"https://plugins.dprint.dev/markdown-0.17.1.wasm",
"https://plugins.dprint.dev/markdown-0.17.2.wasm",
"https://plugins.dprint.dev/toml-0.6.2.wasm"
]
}

View file

@ -10,6 +10,8 @@ if status is-interactive
zoxide init fish | source
## Starship
starship init fish | source
## fnm
fnm env --shell fish | source
# Abbreviations
## Replacements
@ -40,9 +42,9 @@ if status is-interactive
alias ll "ls -l"
alias cat bat
alias gu gitui
alias zola "flatpak run org.getzola.zola"
alias julia "JULIA_NUM_THREADS=16 ~/.juliaup/bin/julia"
alias tb "toolbox run fish"
alias todo "hx ~/todo.md"
# Private config
set -l private_config ~/.config/fish/private_config.fish

View file

@ -1,6 +0,0 @@
theme = "Dark"
scale = 1.5
[font-options]
regular-font = "Cantarell"
monospace-font = "Cantarell"

View file

@ -1,131 +0,0 @@
#!/usr/bin/env python3
import json
import re
import subprocess
from os import environ
from pathlib import Path
def run(command, **kwargs):
return subprocess.run(command, shell=True, check=True, **kwargs)
def cap_run(command, **kwargs):
return run(
command, stdout=subprocess.PIPE, stderr=subprocess.DEVNULL, text=True, **kwargs
).stdout.strip()
def rpm_ostree_packages(output_dir):
out = cap_run("rpm-ostree status --json")
json_out = json.loads(out)
deployments = json_out["deployments"]
booted_deployment = deployments[0]
if not booted_deployment["booted"]:
for depl in deployments:
if depl["booted"]:
booted_deployment = depl
break
removals = booted_deployment["requested-base-removals"]
additions = booted_deployment["requested-packages"]
file = output_dir / "rpm-ostree.sh"
with file.open("w") as f:
f.write("rpm-ostree override remove")
for removal in removals:
f.write(" " + removal)
f.write("\nrpm-ostree install")
for addition in additions:
f.write(" " + addition)
def flatpak_packages(output_dir):
out = cap_run("flatpak list --app --columns=application")
apps = out.split()
file = output_dir / "flatpak.sh"
with file.open("w") as f:
f.write("flatpak install")
for app in apps:
f.write(" " + app)
def cargo_packages(output_dir):
out = cap_run("cargo install --list")
pattern = r"(.+) .+:.*"
crates = re.findall(pattern, out)
file = output_dir / "cargo.sh"
with file.open("w") as f:
f.write("cargo install")
for crate in crates:
f.write(" " + crate)
def npm_packages(output_dir):
out = cap_run("npm list --json --location=global")
json_out = json.loads(out)
deps = json_out["dependencies"].keys()
deps = [dep for dep in deps if dep != "npm"]
file = output_dir / "npm.sh"
with file.open("w") as f:
f.write("npm config set prefix '~/.npm-global'\n")
f.write("npm install --location=global npm\n")
f.write("~/.npm-global/bin/npm install --location=global")
for dep in deps:
f.write(" " + dep)
def pipx_packages(output_dir):
out = cap_run("pipx list --json")
json_out = json.loads(out)
venvs = json_out["venvs"]
packages = []
injections = {}
for ind, venv_key in enumerate(venvs.keys()):
metadata = venvs[venv_key]["metadata"]
package = metadata["main_package"]["package_or_url"]
packages.append(package)
package_injections = metadata["injected_packages"].keys()
if len(package_injections) > 0:
injections[package] = package_injections
file = output_dir / "pipx.sh"
with file.open("w") as f:
for package in packages:
f.write(f"pipx install {package}\n")
f.write("\n")
for package in injections.keys():
for injection in injections[package]:
f.write(f"pipx inject {package} {injection}\n")
def main():
output_dir = Path(f"{environ['HOME']}/bk/installed_packages_info")
output_dir.mkdir(parents=True, exist_ok=True)
rpm_ostree_packages(output_dir)
flatpak_packages(output_dir)
pipx_packages(output_dir)
cargo_packages(output_dir)
# npm_packages(output_dir)
if __name__ == "__main__":
main()

View file

@ -1,157 +0,0 @@
#!/usr/bin/env python3
import json
import subprocess
from getpass import getpass
from os import environ
from pathlib import Path
CONFIG_PATH = Path.home() / ".config/restic_bk/"
def run(command: str, **kwargs):
return subprocess.run(command, shell=True, **kwargs)
def decorated_print(str: str):
print(f"\n<<-<>==={str}===<>->>\n")
def write_home_visible_includes():
home_visible_content = set(
run("fd -d 1 '.*' ~", check=True, stdout=subprocess.PIPE, text=True)
.stdout.strip()
.split()
)
home_visible_excludes = []
with open(CONFIG_PATH / "home_visible_excludes.txt") as f:
for line in f:
home_visible_excludes.append(line.strip())
home_visible_includes = home_visible_content.difference(home_visible_excludes)
with open(CONFIG_PATH / "home_visible_includes.txt", "w") as f:
for line in home_visible_includes:
f.write(line + "\n")
def mounted_backup_drive():
mounted_drives_path = Path("/run/media") / environ["USER"]
if not mounted_drives_path.is_dir():
raise Exception("No drives mounted!")
known_backup_drives = []
with open(CONFIG_PATH / "known_backup_drives.txt") as f:
for line in f:
known_backup_drives.append(line.strip())
mounted_backup_drives = []
for path in mounted_drives_path.iterdir():
if path.is_dir():
drive_name = path.parts[-1]
if drive_name in known_backup_drives:
mounted_backup_drives.append(drive_name)
if len(mounted_backup_drives) == 0:
raise Exception("No known backup drives found!")
ind = 0
if len(mounted_backup_drives) > 1:
decorated_print("Found multiple known backup drives")
for i, drive in enumerate(mounted_backup_drives):
print(f"{i}: {drive}")
ind = int(input("Enter index: "))
return mounted_drives_path / mounted_backup_drives[ind]
def get_parent_snapshot(env):
snapshots_json = run(
"restic snapshots -q --latest 1 --json",
env=env,
check=True,
stdout=subprocess.PIPE,
text=True,
).stdout.strip()
return json.loads(snapshots_json)[-1]["id"]
def pre_backup():
password = getpass("Restic repo password: ")
write_home_visible_includes()
repo = mounted_backup_drive() / "restic"
init_repo = False
if not repo.is_dir():
decorated_print(f"No repo found at {repo} !!")
ans = input("Initialize repo? [Y/n]: ")
if ans.strip().lower() not in ("", "y"):
raise Exception("No repo to work with!")
else:
init_repo = True
with open(CONFIG_PATH / "pre_backup_scripts.txt") as f:
for line in f:
line = line.strip()
decorated_print(f"Running {line}")
run(f"python {line}", stderr=subprocess.DEVNULL)
run("restic self-update", stderr=subprocess.DEVNULL)
env = environ.copy()
env["RESTIC_REPOSITORY"] = repo
env["RESTIC_PASSWORD"] = password
env["RESTIC_COMPRESSION"] = "auto"
if init_repo:
run("restic init", env=env, check=True)
parent_snapshot = None
else:
parent_snapshot = get_parent_snapshot(env)
decorated_print(f"Parent snapshot: {parent_snapshot}")
return env, parent_snapshot
def backup(env, parent_snapshot):
home_visible_includes = CONFIG_PATH / "home_visible_includes.txt"
includes = CONFIG_PATH / "includes.txt"
excludes = CONFIG_PATH / "excludes.txt"
if parent_snapshot is not None:
parent_arg = "--parent " + parent_snapshot
else:
parent_arg = ""
run(
f"restic backup -v {parent_arg} --files-from {home_visible_includes} --files-from {includes} --exclude-file {excludes}",
env=env,
check=True,
)
def post_backup(env):
run("restic check", env=env, check=True)
run("restic snapshots --compact", env=env)
def main():
env, parent_snapshot = pre_backup()
backup(env, parent_snapshot)
post_backup(env)
decorated_print("DONE")
if __name__ == "__main__":
main()

View file

@ -1,7 +0,0 @@
#!/usr/bin/fish
if test (gsettings get org.gnome.desktop.peripherals.touchpad send-events) = "'enabled'"
gsettings set org.gnome.desktop.peripherals.touchpad send-events disabled
else
gsettings set org.gnome.desktop.peripherals.touchpad send-events enabled
end