Compare commits
1 Commits
main
..
0a4f7c6eef
| Author | SHA1 | Date | |
|---|---|---|---|
| 0a4f7c6eef |
@@ -4,6 +4,3 @@
|
|||||||
[submodule "assets/yazi-catppuccin"]
|
[submodule "assets/yazi-catppuccin"]
|
||||||
path = assets/yazi-catppuccin
|
path = assets/yazi-catppuccin
|
||||||
url = https://github.com/catppuccin/yazi.git
|
url = https://github.com/catppuccin/yazi.git
|
||||||
[submodule "config/ghostty/.config/ghostty/shaders"]
|
|
||||||
path = config/ghostty/.config/ghostty/shaders
|
|
||||||
url = https://github.com/0xhckr/ghostty-shaders.git
|
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ https://github.com/user-attachments/assets/2550607a-48ea-4662-98ba-d26722b26b1b
|
|||||||
- Bar: ~~Waybar~~ | **Quickshell**
|
- Bar: ~~Waybar~~ | **Quickshell**
|
||||||
- Shell: (bash & fish) | **Zsh**
|
- Shell: (bash & fish) | **Zsh**
|
||||||
- Prompt: Oh My Posh | **Starship**
|
- Prompt: Oh My Posh | **Starship**
|
||||||
- Terminal: **Kitty** | WezTerm | Ghostty
|
- Terminal: **Kitty** & (WezTerm | **Ghostty**)
|
||||||
- Power Menu: **Wlogout** & Quickshell
|
- Power Menu: **Wlogout** & Quickshell
|
||||||
- Colorscheme: **Catppuccin Mocha**
|
- Colorscheme: **Catppuccin Mocha**
|
||||||
- App Launcher: ~~Rofi~~ | ~~Fuzzel~~ | **vicinae**
|
- App Launcher: ~~Rofi~~ | ~~Fuzzel~~ | **vicinae**
|
||||||
@@ -100,7 +100,7 @@ This feature is only enabled in Niri. Swww also manages wallpapers of the Hyprla
|
|||||||
## Wallpaper & Colortheme
|
## Wallpaper & Colortheme
|
||||||
|
|
||||||
The most suitable primary color (or so-called flavor) will be chosen from the [Catppuccin Mocha](https://catppuccin.com/palette/) palette and applied to various apps automatically after changing wallpaper. And also:
|
The most suitable primary color (or so-called flavor) will be chosen from the [Catppuccin Mocha](https://catppuccin.com/palette/) palette and applied to various apps automatically after changing wallpaper. And also:
|
||||||
|
|
||||||
- [wallpaper-chooser](https://github.com/Uyanide/Wallpaper_Chooser) to select wallpaper, which implements an Image Carousel with Qt Widgets.
|
- [wallpaper-chooser](https://github.com/Uyanide/Wallpaper_Chooser) to select wallpaper, which implements an Image Carousel with Qt Widgets.
|
||||||
- [backgrounds collection](https://github.com/Uyanide/backgrounds) for personal use.
|
- [backgrounds collection](https://github.com/Uyanide/backgrounds) for personal use.
|
||||||
|
|
||||||
|
|||||||
@@ -66,6 +66,12 @@ PKGS = {
|
|||||||
"niri": NIRI_PKGS,
|
"niri": NIRI_PKGS,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SESSION_NAME = {
|
||||||
|
"hyprland": "Hyprland",
|
||||||
|
"niri": "niri",
|
||||||
|
"default": "default",
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
PKGS_PATH = Path(__file__).resolve().parent.resolve() / "config"
|
PKGS_PATH = Path(__file__).resolve().parent.resolve() / "config"
|
||||||
DEST_PATH = Path.home().expanduser()
|
DEST_PATH = Path.home().expanduser()
|
||||||
@@ -101,6 +107,12 @@ def unstow(pkg: str):
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def switch(session: str):
|
||||||
|
subprocess.run(
|
||||||
|
[str(Path("~/.local/scripts/config-switch").expanduser()), session], check=True
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
if not check_deps():
|
if not check_deps():
|
||||||
exit(1)
|
exit(1)
|
||||||
@@ -135,6 +147,17 @@ def main():
|
|||||||
if is_unstow:
|
if is_unstow:
|
||||||
return # No need to switch session if we're just unstowing
|
return # No need to switch session if we're just unstowing
|
||||||
|
|
||||||
|
if args.package in SESSION_NAME:
|
||||||
|
session = SESSION_NAME[args.package]
|
||||||
|
else:
|
||||||
|
session = SESSION_NAME["default"]
|
||||||
|
|
||||||
|
try:
|
||||||
|
switch(session)
|
||||||
|
_log("INFO", f"Switched to session profile '{session}'.")
|
||||||
|
except subprocess.CalledProcessError as e:
|
||||||
|
_log("ERROR", f"Failed to switch session profile '{session}': {e}")
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
main()
|
main()
|
||||||
|
|||||||
@@ -0,0 +1 @@
|
|||||||
|
shaders
|
||||||
@@ -0,0 +1,27 @@
|
|||||||
|
theme = Catppuccin Mocha
|
||||||
|
|
||||||
|
background-opacity = 0.75
|
||||||
|
background-blur = true
|
||||||
|
|
||||||
|
window-padding-x = 10
|
||||||
|
window-padding-y = 10
|
||||||
|
|
||||||
|
keybind = ctrl+shift+r=reload_config
|
||||||
|
|
||||||
|
keybind = ctrl+shift+h=write_screen_file:copy
|
||||||
|
keybind = ctrl+shift+j=text:ghostty-capture\n
|
||||||
|
keybind = ctrl+enter=unbind
|
||||||
|
|
||||||
|
command = exec /bin/zsh
|
||||||
|
|
||||||
|
confirm-close-surface = false
|
||||||
|
|
||||||
|
font-family = monospace
|
||||||
|
font-size = 12
|
||||||
|
|
||||||
|
cursor-style = bar
|
||||||
|
adjust-cursor-thickness = 3
|
||||||
|
|
||||||
|
custom-shader = cursor-shaders/cursor-smear.glsl
|
||||||
|
|
||||||
|
quit-after-last-window-closed = false
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
shaders
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
theme = Catppuccin Mocha
|
theme = Catppuccin Mocha
|
||||||
|
|
||||||
background-opacity = 0.9
|
background-opacity = 0.95
|
||||||
background-blur = true
|
background-blur = true
|
||||||
|
|
||||||
window-padding-x = 10
|
window-padding-x = 10
|
||||||
@@ -0,0 +1,120 @@
|
|||||||
|
// https://github.com/KroneCorylus/ghostty-shader-playground/blob/main/shaders/cursor_smear.glsl
|
||||||
|
|
||||||
|
float getSdfRectangle(in vec2 p, in vec2 xy, in vec2 b)
|
||||||
|
{
|
||||||
|
vec2 d = abs(p - xy) - b;
|
||||||
|
return length(max(d, 0.0)) + min(max(d.x, d.y), 0.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Based on Inigo Quilez's 2D distance functions article: https://iquilezles.org/articles/distfunctions2d/
|
||||||
|
// Potencially optimized by eliminating conditionals and loops to enhance performance and reduce branching
|
||||||
|
|
||||||
|
float seg(in vec2 p, in vec2 a, in vec2 b, inout float s, float d) {
|
||||||
|
vec2 e = b - a;
|
||||||
|
vec2 w = p - a;
|
||||||
|
vec2 proj = a + e * clamp(dot(w, e) / dot(e, e), 0.0, 1.0);
|
||||||
|
float segd = dot(p - proj, p - proj);
|
||||||
|
d = min(d, segd);
|
||||||
|
|
||||||
|
float c0 = step(0.0, p.y - a.y);
|
||||||
|
float c1 = 1.0 - step(0.0, p.y - b.y);
|
||||||
|
float c2 = 1.0 - step(0.0, e.x * w.y - e.y * w.x);
|
||||||
|
float allCond = c0 * c1 * c2;
|
||||||
|
float noneCond = (1.0 - c0) * (1.0 - c1) * (1.0 - c2);
|
||||||
|
float flip = mix(1.0, -1.0, step(0.5, allCond + noneCond));
|
||||||
|
s *= flip;
|
||||||
|
return d;
|
||||||
|
}
|
||||||
|
|
||||||
|
float getSdfParallelogram(in vec2 p, in vec2 v0, in vec2 v1, in vec2 v2, in vec2 v3) {
|
||||||
|
float s = 1.0;
|
||||||
|
float d = dot(p - v0, p - v0);
|
||||||
|
|
||||||
|
d = seg(p, v0, v3, s, d);
|
||||||
|
d = seg(p, v1, v0, s, d);
|
||||||
|
d = seg(p, v2, v1, s, d);
|
||||||
|
d = seg(p, v3, v2, s, d);
|
||||||
|
|
||||||
|
return s * sqrt(d);
|
||||||
|
}
|
||||||
|
|
||||||
|
vec2 normalize(vec2 value, float isPosition) {
|
||||||
|
return (value * 2.0 - (iResolution.xy * isPosition)) / iResolution.y;
|
||||||
|
}
|
||||||
|
|
||||||
|
float antialising(float distance) {
|
||||||
|
return 1. - smoothstep(0., normalize(vec2(2., 2.), 0.).x, distance);
|
||||||
|
}
|
||||||
|
|
||||||
|
float determineStartVertexFactor(vec2 a, vec2 b) {
|
||||||
|
// Conditions using step
|
||||||
|
float condition1 = step(b.x, a.x) * step(a.y, b.y); // a.x < b.x && a.y > b.y
|
||||||
|
float condition2 = step(a.x, b.x) * step(b.y, a.y); // a.x > b.x && a.y < b.y
|
||||||
|
|
||||||
|
// If neither condition is met, return 1 (else case)
|
||||||
|
return 1.0 - max(condition1, condition2);
|
||||||
|
}
|
||||||
|
|
||||||
|
vec2 getRectangleCenter(vec4 rectangle) {
|
||||||
|
return vec2(rectangle.x + (rectangle.z / 2.), rectangle.y - (rectangle.w / 2.));
|
||||||
|
}
|
||||||
|
float ease(float x) {
|
||||||
|
return pow(1.0 - x, 3.0);
|
||||||
|
}
|
||||||
|
vec4 saturate(vec4 color, float factor) {
|
||||||
|
float gray = dot(color, vec4(0.299, 0.587, 0.114, 0.)); // luminance
|
||||||
|
return mix(vec4(gray), color, factor);
|
||||||
|
}
|
||||||
|
|
||||||
|
vec4 TRAIL_COLOR = iCurrentCursorColor;
|
||||||
|
const float OPACITY = 0.6;
|
||||||
|
const float DURATION = 0.3; //IN SECONDS
|
||||||
|
|
||||||
|
void mainImage(out vec4 fragColor, in vec2 fragCoord)
|
||||||
|
{
|
||||||
|
|
||||||
|
#if !defined(WEB)
|
||||||
|
fragColor = texture(iChannel0, fragCoord.xy / iResolution.xy);
|
||||||
|
#endif
|
||||||
|
// Normalization for fragCoord to a space of -1 to 1;
|
||||||
|
vec2 vu = normalize(fragCoord, 1.);
|
||||||
|
vec2 offsetFactor = vec2(-.5, 0.5);
|
||||||
|
|
||||||
|
// Normalization for cursor position and size;
|
||||||
|
// cursor xy has the postion in a space of -1 to 1;
|
||||||
|
// zw has the width and height
|
||||||
|
vec4 currentCursor = vec4(normalize(iCurrentCursor.xy, 1.), normalize(iCurrentCursor.zw, 0.));
|
||||||
|
vec4 previousCursor = vec4(normalize(iPreviousCursor.xy, 1.), normalize(iPreviousCursor.zw, 0.));
|
||||||
|
|
||||||
|
// When drawing a parellelogram between cursors for the trail i need to determine where to start at the top-left or top-right vertex of the cursor
|
||||||
|
float vertexFactor = determineStartVertexFactor(currentCursor.xy, previousCursor.xy);
|
||||||
|
float invertedVertexFactor = 1.0 - vertexFactor;
|
||||||
|
|
||||||
|
// Set every vertex of my parellogram
|
||||||
|
vec2 v0 = vec2(currentCursor.x + currentCursor.z * vertexFactor, currentCursor.y - currentCursor.w);
|
||||||
|
vec2 v1 = vec2(currentCursor.x + currentCursor.z * invertedVertexFactor, currentCursor.y);
|
||||||
|
vec2 v2 = vec2(previousCursor.x + currentCursor.z * invertedVertexFactor, previousCursor.y);
|
||||||
|
vec2 v3 = vec2(previousCursor.x + currentCursor.z * vertexFactor, previousCursor.y - previousCursor.w);
|
||||||
|
|
||||||
|
float sdfCurrentCursor = getSdfRectangle(vu, currentCursor.xy - (currentCursor.zw * offsetFactor), currentCursor.zw * 0.5);
|
||||||
|
float sdfTrail = getSdfParallelogram(vu, v0, v1, v2, v3);
|
||||||
|
|
||||||
|
float progress = clamp((iTime - iTimeCursorChange) / DURATION, 0.0, 1.0);
|
||||||
|
float easedProgress = ease(progress);
|
||||||
|
// Distance between cursors determine the total length of the parallelogram;
|
||||||
|
vec2 centerCC = getRectangleCenter(currentCursor);
|
||||||
|
vec2 centerCP = getRectangleCenter(previousCursor);
|
||||||
|
float lineLength = distance(centerCC, centerCP);
|
||||||
|
|
||||||
|
vec4 newColor = vec4(fragColor);
|
||||||
|
|
||||||
|
vec4 trail = TRAIL_COLOR;
|
||||||
|
trail = saturate(trail, 2.5);
|
||||||
|
// Draw trail
|
||||||
|
newColor = mix(newColor, trail, antialising(sdfTrail));
|
||||||
|
// Draw current cursor
|
||||||
|
newColor = mix(newColor, trail, antialising(sdfCurrentCursor));
|
||||||
|
newColor = mix(newColor, fragColor, step(sdfCurrentCursor, 0.));
|
||||||
|
// newColor = mix(fragColor, newColor, OPACITY);
|
||||||
|
fragColor = mix(fragColor, newColor, step(sdfCurrentCursor, easedProgress * lineLength));
|
||||||
|
}
|
||||||
@@ -0,0 +1,48 @@
|
|||||||
|
allow_remote_control yes
|
||||||
|
listen_on unix:/tmp/kitty
|
||||||
|
shell_integration enabled
|
||||||
|
|
||||||
|
# kitty-scrollback.nvim Kitten alias
|
||||||
|
action_alias kitty_scrollback_nvim kitten $HOME/.local/share/nvim/lazy/kitty-scrollback.nvim/python/kitty_scrollback_nvim.py
|
||||||
|
# Browse scrollback buffer in nvim
|
||||||
|
map kitty_mod+h kitty_scrollback_nvim
|
||||||
|
# Browse output of the last shell command in nvim
|
||||||
|
map kitty_mod+g kitty_scrollback_nvim --config ksb_builtin_last_cmd_output
|
||||||
|
# Show clicked command output in nvim
|
||||||
|
mouse_map ctrl+shift+right press ungrabbed combine : mouse_select_command_output : kitty_scrollback_nvim --config ksb_builtin_last_visited_cmd_output
|
||||||
|
|
||||||
|
# disable the stupid notification
|
||||||
|
confirm_os_window_close 0
|
||||||
|
|
||||||
|
# set shell to zsh
|
||||||
|
shell /bin/zsh
|
||||||
|
|
||||||
|
# hide_window_decorations yes
|
||||||
|
window_padding_width 10
|
||||||
|
|
||||||
|
background_opacity 0.75
|
||||||
|
background_blur 16
|
||||||
|
|
||||||
|
font_family monospace
|
||||||
|
font_size 12
|
||||||
|
|
||||||
|
tab_bar_style powerline
|
||||||
|
tab_powerline_style round
|
||||||
|
tab_title_template {title}{' :{}:'.format(num_windows) if num_windows > 1 else ''}
|
||||||
|
|
||||||
|
map ctrl+up previous_window
|
||||||
|
map ctrl+down next_window
|
||||||
|
|
||||||
|
cursor_trail 1
|
||||||
|
cursor_shape beam
|
||||||
|
|
||||||
|
include Catppuccin-Mocha.conf
|
||||||
|
|
||||||
|
map ctrl+plus change_font_size all +1
|
||||||
|
map ctrl+kp_add change_font_size all +1
|
||||||
|
|
||||||
|
map ctrl+minus change_font_size all -1
|
||||||
|
map ctrl+kp_subtract change_font_size all -1
|
||||||
|
|
||||||
|
map ctrl+0 change_font_size all 0
|
||||||
|
map ctrl+kp_0 change_font_size all 0
|
||||||
@@ -0,0 +1,80 @@
|
|||||||
|
# vim:ft=kitty
|
||||||
|
|
||||||
|
## name: Catppuccin-Mocha
|
||||||
|
## author: Pocco81 (https://github.com/Pocco81)
|
||||||
|
## license: MIT
|
||||||
|
## upstream: https://github.com/catppuccin/kitty/blob/main/mocha.conf
|
||||||
|
## blurb: Soothing pastel theme for the high-spirited!
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# The basic colors
|
||||||
|
foreground #CDD6F4
|
||||||
|
background #1E1E2E
|
||||||
|
selection_foreground #1E1E2E
|
||||||
|
selection_background #F5E0DC
|
||||||
|
|
||||||
|
# Cursor colors
|
||||||
|
cursor #F5E0DC
|
||||||
|
cursor_text_color #1E1E2E
|
||||||
|
|
||||||
|
# URL underline color when hovering with mouse
|
||||||
|
url_color #F5E0DC
|
||||||
|
|
||||||
|
# Kitty window border colors
|
||||||
|
active_border_color #B4BEFE
|
||||||
|
inactive_border_color #6C7086
|
||||||
|
bell_border_color #F9E2AF
|
||||||
|
|
||||||
|
# OS Window titlebar colors
|
||||||
|
wayland_titlebar_color system
|
||||||
|
macos_titlebar_color system
|
||||||
|
|
||||||
|
# Tab bar colors
|
||||||
|
active_tab_foreground #11111B
|
||||||
|
active_tab_background #CBA6F7
|
||||||
|
inactive_tab_foreground #CDD6F4
|
||||||
|
inactive_tab_background #181825
|
||||||
|
tab_bar_background #11111B
|
||||||
|
|
||||||
|
# Colors for marks (marked text in the terminal)
|
||||||
|
mark1_foreground #1E1E2E
|
||||||
|
mark1_background #B4BEFE
|
||||||
|
mark2_foreground #1E1E2E
|
||||||
|
mark2_background #CBA6F7
|
||||||
|
mark3_foreground #1E1E2E
|
||||||
|
mark3_background #74C7EC
|
||||||
|
|
||||||
|
# The 16 terminal colors
|
||||||
|
|
||||||
|
# black
|
||||||
|
color0 #45475A
|
||||||
|
color8 #585B70
|
||||||
|
|
||||||
|
# red
|
||||||
|
color1 #F38BA8
|
||||||
|
color9 #F38BA8
|
||||||
|
|
||||||
|
# green
|
||||||
|
color2 #A6E3A1
|
||||||
|
color10 #A6E3A1
|
||||||
|
|
||||||
|
# yellow
|
||||||
|
color3 #F9E2AF
|
||||||
|
color11 #F9E2AF
|
||||||
|
|
||||||
|
# blue
|
||||||
|
color4 #89B4FA
|
||||||
|
color12 #89B4FA
|
||||||
|
|
||||||
|
# magenta
|
||||||
|
color5 #F5C2E7
|
||||||
|
color13 #F5C2E7
|
||||||
|
|
||||||
|
# cyan
|
||||||
|
color6 #94E2D5
|
||||||
|
color14 #94E2D5
|
||||||
|
|
||||||
|
# white
|
||||||
|
color7 #BAC2DE
|
||||||
|
color15 #A6ADC8
|
||||||
@@ -3,13 +3,13 @@ listen_on unix:/tmp/kitty
|
|||||||
shell_integration enabled
|
shell_integration enabled
|
||||||
|
|
||||||
# kitty-scrollback.nvim Kitten alias
|
# kitty-scrollback.nvim Kitten alias
|
||||||
# action_alias kitty_scrollback_nvim kitten $HOME/.local/share/nvim/lazy/kitty-scrollback.nvim/python/kitty_scrollback_nvim.py
|
action_alias kitty_scrollback_nvim kitten $HOME/.local/share/nvim/lazy/kitty-scrollback.nvim/python/kitty_scrollback_nvim.py
|
||||||
# Browse scrollback buffer in nvim
|
# Browse scrollback buffer in nvim
|
||||||
# map kitty_mod+h kitty_scrollback_nvim
|
map kitty_mod+h kitty_scrollback_nvim
|
||||||
# Browse output of the last shell command in nvim
|
# Browse output of the last shell command in nvim
|
||||||
# map kitty_mod+g kitty_scrollback_nvim --config ksb_builtin_last_cmd_output
|
map kitty_mod+g kitty_scrollback_nvim --config ksb_builtin_last_cmd_output
|
||||||
# Show clicked command output in nvim
|
# Show clicked command output in nvim
|
||||||
# mouse_map ctrl+shift+right press ungrabbed combine : mouse_select_command_output : kitty_scrollback_nvim --config ksb_builtin_last_visited_cmd_output
|
mouse_map ctrl+shift+right press ungrabbed combine : mouse_select_command_output : kitty_scrollback_nvim --config ksb_builtin_last_visited_cmd_output
|
||||||
|
|
||||||
# disable the stupid notification
|
# disable the stupid notification
|
||||||
confirm_os_window_close 0
|
confirm_os_window_close 0
|
||||||
@@ -20,7 +20,7 @@ shell /bin/zsh
|
|||||||
# hide_window_decorations yes
|
# hide_window_decorations yes
|
||||||
window_padding_width 10
|
window_padding_width 10
|
||||||
|
|
||||||
background_opacity 0.9
|
background_opacity 0.95
|
||||||
background_blur 16
|
background_blur 16
|
||||||
|
|
||||||
font_family monospace
|
font_family monospace
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
include kitty.conf
|
|
||||||
|
|
||||||
remember_window_size false
|
|
||||||
initial_window_width 960
|
|
||||||
initial_window_height 720
|
|
||||||
|
|
||||||
window_padding_width 5
|
|
||||||
@@ -14,9 +14,9 @@ binds {
|
|||||||
Mod+E repeat=false { spawn "dolphin" "--new-window"; }
|
Mod+E repeat=false { spawn "dolphin" "--new-window"; }
|
||||||
Mod+Shift+E repeat=false { spawn "nautilus" "--new-window"; }
|
Mod+Shift+E repeat=false { spawn "nautilus" "--new-window"; }
|
||||||
Mod+W repeat=false { spawn-sh "zen || zen-browser"; }
|
Mod+W repeat=false { spawn-sh "zen || zen-browser"; }
|
||||||
Mod+B repeat=false { spawn-sh "pkill -x -n btop || kitty-floating -e btop"; }
|
Mod+B repeat=false { spawn-sh "pkill -x -n btop || ghostty +new-window -e btop"; }
|
||||||
Mod+Shift+T repeat=false { spawn "kitty-floating"; }
|
Mod+Shift+T repeat=false { spawn "ghostty" "+new-window"; }
|
||||||
Mod+Shift+Return repeat=false { spawn "kitty-floating"; }
|
Mod+Shift+Return repeat=false { spawn "ghostty" "+new-window"; }
|
||||||
Mod+T repeat=false { spawn "kitty"; }
|
Mod+T repeat=false { spawn "kitty"; }
|
||||||
Mod+Return repeat=false { spawn "kitty"; }
|
Mod+Return repeat=false { spawn "kitty"; }
|
||||||
Mod+Shift+W repeat=false { spawn "wallreel"; }
|
Mod+Shift+W repeat=false { spawn "wallreel"; }
|
||||||
@@ -45,9 +45,9 @@ binds {
|
|||||||
Mod+D repeat=false { spawn "vicinae" "vicinae://launch/system/run?toggle=true"; }
|
Mod+D repeat=false { spawn "vicinae" "vicinae://launch/system/run?toggle=true"; }
|
||||||
|
|
||||||
// Actions
|
// Actions
|
||||||
Print repeat=false { screenshot-screen show-pointer=false; }
|
Print repeat=false { screenshot-screen; }
|
||||||
Mod+Shift+S repeat=false { screenshot show-pointer=false; }
|
Mod+Shift+S repeat=false { screenshot; }
|
||||||
Mod+Ctrl+Shift+S repeat=false { screenshot-window show-pointer=false; }
|
Mod+Ctrl+Shift+S repeat=false { screenshot-window; }
|
||||||
Mod+Shift+C repeat=false { spawn "hyprpicker" "-a"; }
|
Mod+Shift+C repeat=false { spawn "hyprpicker" "-a"; }
|
||||||
|
|
||||||
// Media
|
// Media
|
||||||
@@ -163,7 +163,7 @@ binds {
|
|||||||
|
|
||||||
// Session
|
// Session
|
||||||
Mod+K allow-inhibiting=false repeat=false { quit; }
|
Mod+K allow-inhibiting=false repeat=false { quit; }
|
||||||
Mod+Shift+P allow-inhibiting=false repeat=false { spawn-sh "loginctl lock-session; niri msg action power-off-monitors"; }
|
Mod+Shift+P allow-inhibiting=false repeat=false { spawn-sh "hyprlock & niri msg action power-off-monitors"; }
|
||||||
Mod+L allow-inhibiting=false repeat=false { spawn "loginctl" "lock-session"; }
|
Mod+L allow-inhibiting=false repeat=false { spawn "loginctl" "lock-session"; }
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
// Switch configs
|
||||||
|
spawn-at-startup "config-switch" "niri"
|
||||||
|
|
||||||
// Core
|
// Core
|
||||||
spawn-at-startup "nm-applet"
|
spawn-at-startup "nm-applet"
|
||||||
spawn-at-startup "gnome-keyring-daemon" "--start" "--components=secrets"
|
spawn-at-startup "gnome-keyring-daemon" "--start" "--components=secrets"
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
screenshot-path "~/Pictures/Screenshots/niri_screenshot_%Y-%m-%d_%H-%M-%S.png"
|
screenshot-path "~/Pictures/Screenshots/niri_screenshot_%Y-%m-%d_%H-%M-%S.png"
|
||||||
|
|
||||||
debug {
|
debug {
|
||||||
render-drm-device "/dev/dri/renderD129"
|
render-drm-device "/dev/dri/renderD128"
|
||||||
honor-xdg-activation-with-invalid-serial
|
honor-xdg-activation-with-invalid-serial
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1 @@
|
|||||||
environment {
|
|
||||||
__NV_PRIME_RENDER_OFFLOAD "1"
|
|
||||||
__VK_LAYER_NV_optimus "NVIDIA_only"
|
|
||||||
__GLX_VENDOR_LIBRARY_NAME "nvidia"
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -20,7 +20,6 @@ window-rule {
|
|||||||
window-rule {
|
window-rule {
|
||||||
match app-id="org.wezfurlong.wezterm"
|
match app-id="org.wezfurlong.wezterm"
|
||||||
match app-id="com.mitchellh.ghostty"
|
match app-id="com.mitchellh.ghostty"
|
||||||
match app-id="kitty-floating"
|
|
||||||
open-floating true
|
open-floating true
|
||||||
default-column-width { proportion 0.5; }
|
default-column-width { proportion 0.5; }
|
||||||
}
|
}
|
||||||
@@ -62,16 +61,9 @@ window-rule {
|
|||||||
open-floating true
|
open-floating true
|
||||||
}
|
}
|
||||||
|
|
||||||
// QQ
|
|
||||||
window-rule {
|
|
||||||
match app-id="QQ" title="资料卡"
|
|
||||||
match app-id="QQ" title="天气"
|
|
||||||
open-focused false
|
|
||||||
}
|
|
||||||
|
|
||||||
// Block from recording
|
// Block from recording
|
||||||
window-rule {
|
window-rule {
|
||||||
match app-id="org.mozilla.Thunderbird"
|
match app-id="thunderbird"
|
||||||
|
|
||||||
block-out-from "screen-capture"
|
block-out-from "screen-capture"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -82,20 +82,10 @@ layer-rule {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
layer-rule {
|
cursor {
|
||||||
match layer="top"
|
xcursor-theme "Bibata-Modern-Ice"
|
||||||
match layer="overlay"
|
xcursor-size 24
|
||||||
|
hide-when-typing
|
||||||
background-effect {
|
|
||||||
xray false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
window-rule {
|
|
||||||
match is-floating=true
|
|
||||||
background-effect {
|
|
||||||
xray false
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// I love rounded corners
|
// I love rounded corners
|
||||||
@@ -104,12 +94,6 @@ window-rule {
|
|||||||
clip-to-geometry true
|
clip-to-geometry true
|
||||||
}
|
}
|
||||||
|
|
||||||
cursor {
|
|
||||||
xcursor-theme "Bibata-Modern-Ice"
|
|
||||||
xcursor-size 24
|
|
||||||
hide-when-typing
|
|
||||||
}
|
|
||||||
|
|
||||||
recent-windows {
|
recent-windows {
|
||||||
highlight {
|
highlight {
|
||||||
active-color "#89b4fa"
|
active-color "#89b4fa"
|
||||||
|
|||||||
@@ -12,9 +12,8 @@ gtk-enable-input-feedback-sounds=0
|
|||||||
gtk-font-name=Sarasa UI SC, 10
|
gtk-font-name=Sarasa UI SC, 10
|
||||||
gtk-icon-theme-name=Papirus
|
gtk-icon-theme-name=Papirus
|
||||||
gtk-menu-images=true
|
gtk-menu-images=true
|
||||||
gtk-modules=colorreload-gtk-module:appmenu-gtk-module
|
gtk-modules=colorreload-gtk-module
|
||||||
gtk-primary-button-warps-slider=true
|
gtk-primary-button-warps-slider=true
|
||||||
gtk-shell-shows-menubar=1
|
|
||||||
gtk-sound-theme-name=ocean
|
gtk-sound-theme-name=ocean
|
||||||
gtk-theme-name=catppuccin-mocha-blue-standard+default
|
gtk-theme-name=catppuccin-mocha-blue-standard+default
|
||||||
gtk-toolbar-icon-size=GTK_ICON_SIZE_LARGE_TOOLBAR
|
gtk-toolbar-icon-size=GTK_ICON_SIZE_LARGE_TOOLBAR
|
||||||
|
|||||||
@@ -11,23 +11,15 @@ Item {
|
|||||||
property color fillColor: Colors.mRed
|
property color fillColor: Colors.mRed
|
||||||
property color _actualColor: Colors.mRed
|
property color _actualColor: Colors.mRed
|
||||||
property bool _expand: mouseArea.containsMouse
|
property bool _expand: mouseArea.containsMouse
|
||||||
property string displayText: Niri.castOutputs.length > 0 ? Niri.castOutputs.join(", ") : "Casting"
|
|
||||||
|
|
||||||
visible: Niri.isCasting
|
visible: RecordService.isRecording
|
||||||
implicitHeight: Math.max(symbolIcon.implicitHeight, textLabel.implicitHeight)
|
implicitHeight: Math.max(symbolIcon.implicitHeight, textLabel.implicitHeight)
|
||||||
implicitWidth: height + expander.implicitWidth
|
implicitWidth: height + expander.implicitWidth
|
||||||
|
|
||||||
Connections {
|
|
||||||
target: Niri
|
|
||||||
onCastOutputsListChanged: {
|
|
||||||
root.displayText = Niri.castOutputs.length > 0 ? Niri.castOutputs.join(", ") : "Casting";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
SequentialAnimation {
|
SequentialAnimation {
|
||||||
id: blinkAnimation
|
id: blinkAnimation
|
||||||
|
|
||||||
running: root.visible
|
running: RecordService.isRecording
|
||||||
loops: Animation.Infinite
|
loops: Animation.Infinite
|
||||||
|
|
||||||
ColorAnimation {
|
ColorAnimation {
|
||||||
@@ -78,7 +70,7 @@ Item {
|
|||||||
anchors.verticalCenter: parent.verticalCenter
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
anchors.left: parent.left
|
anchors.left: parent.left
|
||||||
anchors.leftMargin: 5
|
anchors.leftMargin: 5
|
||||||
text: root.displayText
|
text: RecordService.recordingDisplay || "Recording"
|
||||||
color: root.fillColor
|
color: root.fillColor
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -100,6 +92,12 @@ Item {
|
|||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
cursorShape: Qt.PointingHandCursor
|
cursorShape: Qt.PointingHandCursor
|
||||||
hoverEnabled: true
|
hoverEnabled: true
|
||||||
|
acceptedButtons: Qt.LeftButton | Qt.RightButton | Qt.MiddleButton
|
||||||
|
onClicked: (mouse) => {
|
||||||
|
if (mouse.button === Qt.LeftButton)
|
||||||
|
RecordService.startOrStop();
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Behavior on _actualColor {
|
Behavior on _actualColor {
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ Singleton {
|
|||||||
id: process
|
id: process
|
||||||
|
|
||||||
running: false
|
running: false
|
||||||
command: ["kitty-floating", "-e", "btop"]
|
command: ["ghostty", "+new-window", "-e", "btop"]
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -35,16 +35,11 @@ Singleton {
|
|||||||
})
|
})
|
||||||
property var workspaceCache: ({
|
property var workspaceCache: ({
|
||||||
})
|
})
|
||||||
property var castCache: ({
|
|
||||||
})
|
|
||||||
property var castOutputs: []
|
|
||||||
property bool isCasting: false
|
|
||||||
|
|
||||||
signal workspaceChanged()
|
signal workspaceChanged()
|
||||||
signal activeWindowChanged()
|
signal activeWindowChanged()
|
||||||
signal windowListChanged()
|
signal windowListChanged()
|
||||||
signal outputsChanged()
|
signal outputsChanged()
|
||||||
signal castOutputsListChanged()
|
|
||||||
|
|
||||||
function initialize() {
|
function initialize() {
|
||||||
niriEventStream.connected = true;
|
niriEventStream.connected = true;
|
||||||
@@ -439,79 +434,6 @@ Singleton {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function _syncCasts() {
|
|
||||||
isCasting = Object.keys(castCache).length > 0;
|
|
||||||
castOutputs = [];
|
|
||||||
for (const castId in castCache) {
|
|
||||||
const cast = castCache[castId];
|
|
||||||
if (cast.output) {
|
|
||||||
if (!castOutputs.includes(cast.output))
|
|
||||||
castOutputs.push(cast.output);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
castOutputsListChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
function _handleCastsChanged(eventData) {
|
|
||||||
try {
|
|
||||||
const casts = eventData.casts || [];
|
|
||||||
castCache = {
|
|
||||||
};
|
|
||||||
castOutputs = [];
|
|
||||||
for (const cast of casts) {
|
|
||||||
const castData = {
|
|
||||||
"id": cast.stream_id,
|
|
||||||
"stream_id": cast.stream_id,
|
|
||||||
"session_id": cast.session_id,
|
|
||||||
"kind": cast.kind,
|
|
||||||
"output": cast.target?.Output?.name,
|
|
||||||
"pid": cast.pid
|
|
||||||
};
|
|
||||||
castCache[castData.id] = castData;
|
|
||||||
}
|
|
||||||
_syncCasts();
|
|
||||||
} catch (e) {
|
|
||||||
Logger.e("NiriService", "Error handling CastsChanged:", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function _handleCastStopped(eventData) {
|
|
||||||
try {
|
|
||||||
const castId = eventData.stream_id;
|
|
||||||
delete castCache[castId];
|
|
||||||
_syncCasts();
|
|
||||||
} catch (e) {
|
|
||||||
Logger.e("NiriService", "Error handling CastStopped:", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function _handleCastStartedOrChanged(eventData) {
|
|
||||||
try {
|
|
||||||
const cast = eventData.cast;
|
|
||||||
if (!cast)
|
|
||||||
return ;
|
|
||||||
if (cast.is_active === true) {
|
|
||||||
// If the cast is active, we can treat it as a new or updated cast
|
|
||||||
const castData = {
|
|
||||||
"id": cast.stream_id,
|
|
||||||
"stream_id": cast.stream_id,
|
|
||||||
"session_id": cast.session_id,
|
|
||||||
"kind": cast.kind,
|
|
||||||
"output": cast.target?.Output?.name,
|
|
||||||
"pid": cast.pid
|
|
||||||
};
|
|
||||||
castCache[castData.id] = castData;
|
|
||||||
} else {
|
|
||||||
// If the cast is not active, we should remove it from the cache
|
|
||||||
const castId = cast.stream_id;
|
|
||||||
delete castCache[castId];
|
|
||||||
}
|
|
||||||
_syncCasts();
|
|
||||||
} catch (e) {
|
|
||||||
Logger.e("NiriService", "Error handling CastStartedOrChanged:", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function switchToWorkspace(workspace) {
|
function switchToWorkspace(workspace) {
|
||||||
try {
|
try {
|
||||||
Quickshell.execDetached(["niri", "msg", "action", "focus-workspace", workspace.idx.toString()]);
|
Quickshell.execDetached(["niri", "msg", "action", "focus-workspace", workspace.idx.toString()]);
|
||||||
@@ -656,12 +578,6 @@ Singleton {
|
|||||||
_queryDisplayScales();
|
_queryDisplayScales();
|
||||||
else if (event.ScreenshotCaptured)
|
else if (event.ScreenshotCaptured)
|
||||||
_handleScreenshotCaptured(event.ScreenshotCaptured);
|
_handleScreenshotCaptured(event.ScreenshotCaptured);
|
||||||
else if (event.CastsChanged)
|
|
||||||
_handleCastsChanged(event.CastsChanged);
|
|
||||||
else if (event.CastStopped)
|
|
||||||
_handleCastStopped(event.CastStopped);
|
|
||||||
else if (event.CastStartedOrChanged)
|
|
||||||
_handleCastStartedOrChanged(event.CastStartedOrChanged);
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
Logger.e("NiriService", "Error parsing event stream:", e, data);
|
Logger.e("NiriService", "Error parsing event stream:", e, data);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -39,7 +39,7 @@ Singleton {
|
|||||||
|
|
||||||
function openNote(path) {
|
function openNote(path) {
|
||||||
recentNotePath = path;
|
recentNotePath = path;
|
||||||
Quickshell.execDetached(["kitty-floating", "-e", "helix", path]);
|
Quickshell.execDetached(["ghostty", "+new-window", "-e", "helix", path]);
|
||||||
}
|
}
|
||||||
|
|
||||||
function openRecent() {
|
function openRecent() {
|
||||||
|
|||||||
@@ -40,9 +40,13 @@ CONFIG_DIR = Path("~/.config").expanduser()
|
|||||||
|
|
||||||
# An application may have multiple scripts (e.g. due to config-switch)
|
# An application may have multiple scripts (e.g. due to config-switch)
|
||||||
SCRIPTS = {
|
SCRIPTS = {
|
||||||
|
"eww": [CONFIG_DIR / "eww" / "apply-color"],
|
||||||
"fastfetch": [CONFIG_DIR / "fastfetch" / "apply-color"],
|
"fastfetch": [CONFIG_DIR / "fastfetch" / "apply-color"],
|
||||||
|
"fuzzel": [CONFIG_DIR / "fuzzel" / "apply-color"],
|
||||||
|
"hypr": [CONFIG_DIR / "hypr" / "apply-color"],
|
||||||
"kvantum": [CONFIG_DIR / "Kvantum" / "apply-color"],
|
"kvantum": [CONFIG_DIR / "Kvantum" / "apply-color"],
|
||||||
"nwg-look": [CONFIG_DIR / "nwg-look" / "apply-color"],
|
"nwg-look": [CONFIG_DIR / "nwg-look" / "apply-color"],
|
||||||
|
"mako": [CONFIG_DIR / "mako" / "apply-color"],
|
||||||
"niri": [CONFIG_DIR / "niri" / "apply-color"],
|
"niri": [CONFIG_DIR / "niri" / "apply-color"],
|
||||||
"oh-my-posh": [
|
"oh-my-posh": [
|
||||||
CONFIG_DIR / "fish" / "apply-color-omp"
|
CONFIG_DIR / "fish" / "apply-color-omp"
|
||||||
@@ -51,7 +55,12 @@ SCRIPTS = {
|
|||||||
CONFIG_DIR / "fish" / "apply-color-starship"
|
CONFIG_DIR / "fish" / "apply-color-starship"
|
||||||
], # borrowing fish's directory
|
], # borrowing fish's directory
|
||||||
"quickshell": [CONFIG_DIR / "quickshell" / "apply-color"],
|
"quickshell": [CONFIG_DIR / "quickshell" / "apply-color"],
|
||||||
"wlogout": [CONFIG_DIR / "wlogout" / "apply-color"],
|
"rofi": [CONFIG_DIR / "rofi" / "apply-color"],
|
||||||
|
"waybar": [CONFIG_DIR / "waybar" / "apply-color"],
|
||||||
|
"wlogout": [
|
||||||
|
CONFIG_DIR / ".alt" / "wlogout-default" / "apply-color",
|
||||||
|
CONFIG_DIR / ".alt" / "wlogout-niri" / "apply-color",
|
||||||
|
],
|
||||||
"yazi": [CONFIG_DIR / "yazi" / "apply-color"],
|
"yazi": [CONFIG_DIR / "yazi" / "apply-color"],
|
||||||
}
|
}
|
||||||
# or simply `find [-L] <CONFIG_DIR> -type f -name 'apply-color*'` to get all available scripts,
|
# or simply `find [-L] <CONFIG_DIR> -type f -name 'apply-color*'` to get all available scripts,
|
||||||
|
|||||||
@@ -1,3 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
kitty --app-id kitty-floating --config "$HOME/.config/kitty/floating.conf" "$@"
|
|
||||||
@@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
# Constants
|
# Constants
|
||||||
niri_config_file="$HOME/.config/niri/config/misc.kdl"
|
niri_config_file="$HOME/.config/niri/config/misc.kdl"
|
||||||
prefer_order=(nvidia intel)
|
prefer_order=(intel nvidia)
|
||||||
|
|
||||||
# Get vendor and path of each GPU
|
# Get vendor and path of each GPU
|
||||||
default_card_path="$(find /dev/dri/card* 2>/dev/null | head -n 1)"
|
default_card_path="$(find /dev/dri/card* 2>/dev/null | head -n 1)"
|
||||||
|
|||||||
@@ -46,5 +46,4 @@ fi
|
|||||||
|
|
||||||
if (( $+commands[bat] )); then
|
if (( $+commands[bat] )); then
|
||||||
export BAT_THEME="Catppuccin Mocha"
|
export BAT_THEME="Catppuccin Mocha"
|
||||||
export BAT_STYLE="default,-numbers"
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -180,20 +180,17 @@ if (( $+commands[git] )); then
|
|||||||
print -r -- "$repo"
|
print -r -- "$repo"
|
||||||
}
|
}
|
||||||
|
|
||||||
gcl() {
|
gc() {
|
||||||
local repo
|
local repo
|
||||||
repo=$(uy_git_repo_from_clipboard) || return 1
|
repo=$(uy_git_repo_from_clipboard) || return 1
|
||||||
git clone "$repo"
|
git clone "$repo"
|
||||||
}
|
}
|
||||||
|
|
||||||
pingo() {
|
pingo() {
|
||||||
builtin cd "$HOME/Repositories/Uni" || return 1
|
cd "$HOME/Repositories/Uni" || return 1
|
||||||
local repo
|
local repo
|
||||||
repo=$(uy_git_repo_from_clipboard) || return 1
|
repo=$(uy_git_repo_from_clipboard) || return 1
|
||||||
local dir_name="${repo:t:r}"
|
local dir_name="${repo:t:r}"
|
||||||
local course="${${dir_name%%[^[:lower:]]*}:u}"
|
|
||||||
mkdir -p "$course"
|
|
||||||
builtin cd "$course" || return 1
|
|
||||||
if [[ ! -d "$dir_name" ]]; then
|
if [[ ! -d "$dir_name" ]]; then
|
||||||
git clone "$repo" || return 1
|
git clone "$repo" || return 1
|
||||||
fi
|
fi
|
||||||
@@ -204,7 +201,7 @@ if (( $+commands[git] )); then
|
|||||||
disown
|
disown
|
||||||
else
|
else
|
||||||
echo "Opening method missing or invalid"
|
echo "Opening method missing or invalid"
|
||||||
builtin cd "$dir_name"
|
cd "$dir_name"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -45,7 +45,6 @@ fi
|
|||||||
|
|
||||||
[[ -f "$HOME/.cargo/env" ]] && source "$HOME/.cargo/env"
|
[[ -f "$HOME/.cargo/env" ]] && source "$HOME/.cargo/env"
|
||||||
(( $+commands[opam] )) && eval "$(opam env)"
|
(( $+commands[opam] )) && eval "$(opam env)"
|
||||||
prepend_path "$HOME/.cargo/bin"
|
|
||||||
prepend_path "$HOME/go/bin"
|
prepend_path "$HOME/go/bin"
|
||||||
prepend_path "$HOME/.local/bin"
|
prepend_path "$HOME/.local/bin"
|
||||||
prepend_path "$HOME/.local/scripts"
|
prepend_path "$HOME/.local/scripts"
|
||||||
|
|||||||
@@ -0,0 +1,24 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
[ -f "$HOME/.local/snippets/apply-color-helper" ] || {
|
||||||
|
echo "Missing helper script: $HOME/.local/snippets/apply-color-helper"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
. "$HOME/.local/snippets/apply-color-helper"
|
||||||
|
|
||||||
|
for file in "$path"/icons/*.svg; do
|
||||||
|
[ -f "$file" ] || continue
|
||||||
|
sed -i -E "s/(fill=\"#)([0-9A-Fa-f]{6})(\")/\1${colorHex}\3/" "$file" || {
|
||||||
|
log_error "Failed to edit ${file}"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
done
|
||||||
|
|
||||||
|
file="$path"/style.css
|
||||||
|
|
||||||
|
sed -i -E "s/(border-color:\s*#)([0-9A-Fa-f]{6})(;)/\1${colorHex}\3/" "$file" || {
|
||||||
|
log_error "Failed to edit ${file}"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
log_success "wlogout"
|
||||||
|
Before Width: | Height: | Size: 969 B After Width: | Height: | Size: 969 B |
|
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
|
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
|
Before Width: | Height: | Size: 877 B After Width: | Height: | Size: 877 B |
|
Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.8 KiB |
|
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
@@ -0,0 +1,36 @@
|
|||||||
|
{
|
||||||
|
"label": "lock",
|
||||||
|
"action": "loginctl lock-session",
|
||||||
|
"text": "Lock",
|
||||||
|
"keybind": "l"
|
||||||
|
}
|
||||||
|
{
|
||||||
|
"label": "hibernate",
|
||||||
|
"action": "systemctl hibernate",
|
||||||
|
"text": "Hibernate",
|
||||||
|
"keybind": "h"
|
||||||
|
}
|
||||||
|
{
|
||||||
|
"label": "logout",
|
||||||
|
"action": "hyprctl dispatch exit",
|
||||||
|
"text": "Logout",
|
||||||
|
"keybind": "e"
|
||||||
|
}
|
||||||
|
{
|
||||||
|
"label": "shutdown",
|
||||||
|
"action": "systemctl poweroff",
|
||||||
|
"text": "Shutdown",
|
||||||
|
"keybind": "s"
|
||||||
|
}
|
||||||
|
{
|
||||||
|
"label": "suspend",
|
||||||
|
"action": "sleep 0.1 && systemctl suspend",
|
||||||
|
"text": "Suspend",
|
||||||
|
"keybind": "u"
|
||||||
|
}
|
||||||
|
{
|
||||||
|
"label": "reboot",
|
||||||
|
"action": "systemctl reboot",
|
||||||
|
"text": "Reboot",
|
||||||
|
"keybind": "r"
|
||||||
|
}
|
||||||
@@ -0,0 +1,120 @@
|
|||||||
|
* {
|
||||||
|
background-image: none;
|
||||||
|
font-size: 24px;
|
||||||
|
font-family: 'Sour Gummy Light';
|
||||||
|
}
|
||||||
|
|
||||||
|
window {
|
||||||
|
background-color: rgba(30, 30, 46, 0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
button {
|
||||||
|
color: #cdd6f4;
|
||||||
|
border-radius: 0;
|
||||||
|
outline-style: none;
|
||||||
|
background-color: alpha(#1e1e2e, 0.8);
|
||||||
|
border: none;
|
||||||
|
border-width: 0px;
|
||||||
|
border-radius: 0px;
|
||||||
|
border-color: #89b4fa;
|
||||||
|
box-shadow: none;
|
||||||
|
text-shadow: none;
|
||||||
|
text-decoration-color: #cdd6f4;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-position: center;
|
||||||
|
background-size: 20%;
|
||||||
|
animation: gradient_f 20s ease-in infinite;
|
||||||
|
}
|
||||||
|
|
||||||
|
button:focus,
|
||||||
|
button:active,
|
||||||
|
button:hover {
|
||||||
|
background-size: 20%;
|
||||||
|
background-color: alpha(#1e1e2e, 0.7);
|
||||||
|
animation: gradient_f 20s ease-in infinite;
|
||||||
|
transition: all 0.3s cubic-bezier(0.55, 0, 0.28, 1.682);
|
||||||
|
}
|
||||||
|
|
||||||
|
#lock {
|
||||||
|
background-image: image(url('./icons/lock.svg'));
|
||||||
|
border-radius: 32px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#logout {
|
||||||
|
background-image: image(url('./icons/logout.svg'));
|
||||||
|
}
|
||||||
|
|
||||||
|
#suspend {
|
||||||
|
background-image: image(url('./icons/suspend.svg'));
|
||||||
|
border-radius: 0 32px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#hibernate {
|
||||||
|
background-image: image(url('./icons/hibernate.svg'));
|
||||||
|
border-radius: 0 0 0 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#shutdown {
|
||||||
|
background-image: image(url('./icons/shutdown.svg'));
|
||||||
|
}
|
||||||
|
|
||||||
|
#reboot {
|
||||||
|
background-image: image(url('./icons/reboot.svg'));
|
||||||
|
border-radius: 0 0 32px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#lock:hover {
|
||||||
|
border-radius: 30px 0 0 0;
|
||||||
|
margin: -30px 0 0 -30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#logout:hover {
|
||||||
|
margin: -30px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#suspend:hover {
|
||||||
|
border-radius: 0 30px 0 0;
|
||||||
|
margin: -30px -30px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#hibernate:hover {
|
||||||
|
border-radius: 0 0 0 30px;
|
||||||
|
margin: 0 0 -30 -30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#shutdown:hover {
|
||||||
|
margin: 0 0 -30px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#reboot:hover {
|
||||||
|
border-radius: 0 0 30px 0;
|
||||||
|
margin: 0 -30px -30px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#lock:focus {
|
||||||
|
border-radius: 60px 0 0 0;
|
||||||
|
margin: -60px 0 0 -60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#logout:focus {
|
||||||
|
margin: -60px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#suspend:focus {
|
||||||
|
border-radius: 0 60px 0 0;
|
||||||
|
margin: -60px -60px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#hibernate:focus {
|
||||||
|
border-radius: 0 0 0 60px;
|
||||||
|
margin: 0 0 -60 -60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#shutdown:focus {
|
||||||
|
margin: 0 0 -60px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#reboot:focus {
|
||||||
|
border-radius: 0 0 60px 0;
|
||||||
|
margin: 0 -60px -60px 0;
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Svg Vector Icons : http://www.onlinewebfonts.com/icon -->
|
||||||
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
||||||
|
<svg fill="#89b4fa" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 1000 1000" enable-background="new 0 0 1000 1000" xml:space="preserve">
|
||||||
|
<metadata> Svg Vector Icons : http://www.onlinewebfonts.com/icon </metadata>
|
||||||
|
<g><g><path d="M500,10C229.4,10,10,229.4,10,500s219.4,490,490,490s490-219.4,490-490S770.6,10,500,10z M500,885.1c-212.7,0-385.1-172.4-385.1-385.1S287.3,114.9,500,114.9S885.1,287.3,885.1,500S712.7,885.1,500,885.1z M576.5,308.7v382.4c0,42.2-34.2,76.5-76.5,76.5c-42.3,0-76.5-34.2-76.5-76.5V308.7c0-42.2,34.2-76.5,76.5-76.5C542.2,232.3,576.5,266.5,576.5,308.7z"/></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g></g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 969 B |
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Svg Vector Icons : http://www.onlinewebfonts.com/icon -->
|
||||||
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
||||||
|
<svg fill="#89b4fa" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 1000 1000" enable-background="new 0 0 1000 1000" xml:space="preserve">
|
||||||
|
<metadata> Svg Vector Icons : http://www.onlinewebfonts.com/icon </metadata>
|
||||||
|
<g><g><path d="M321.8,455.5h356.4V321.8c0-49.2-17.4-91.2-52.2-126c-34.8-34.8-76.8-52.2-126-52.2c-49.2,0-91.2,17.4-126,52.2c-34.8,34.8-52.2,76.8-52.2,126L321.8,455.5L321.8,455.5z M900.9,522.3v400.9c0,18.6-6.5,34.3-19.5,47.3c-13,13-28.8,19.5-47.3,19.5H165.9c-18.6,0-34.3-6.5-47.3-19.5s-19.5-28.8-19.5-47.3V522.3c0-18.6,6.5-34.3,19.5-47.3c13-13,28.8-19.5,47.3-19.5h22.3V321.8c0-85.4,30.6-158.7,91.9-219.9C341.3,40.6,414.6,10,500,10c85.4,0,158.7,30.6,219.9,91.9c61.3,61.3,91.9,134.6,91.9,219.9v133.6h22.3c18.6,0,34.3,6.5,47.3,19.5C894.4,487.9,900.9,503.7,900.9,522.3L900.9,522.3z"/></g></g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.1 KiB |
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Svg Vector Icons : http://www.onlinewebfonts.com/icon -->
|
||||||
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
||||||
|
<svg fill="#89b4fa" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 1000 1000" enable-background="new 0 0 1000 1000" xml:space="preserve">
|
||||||
|
<metadata> Svg Vector Icons : http://www.onlinewebfonts.com/icon </metadata>
|
||||||
|
<g><path d="M622.5,990H50.8C26.3,990,10,973.7,10,949.2V50.8C10,26.3,26.3,10,50.8,10h571.7c24.5,0,40.8,16.3,40.8,40.8v285.8c0,24.5-16.3,40.8-40.8,40.8s-40.8-16.3-40.8-40.8v-245h-490v816.7h490v-245c0-24.5,16.3-40.8,40.8-40.8s40.8,16.3,40.8,40.8v285.8C663.3,973.7,647,990,622.5,990z"/><path d="M949.2,540.8H336.7c-24.5,0-40.8-16.3-40.8-40.8c0-24.5,16.3-40.8,40.8-40.8h612.5c24.5,0,40.8,16.3,40.8,40.8C990,524.5,973.7,540.8,949.2,540.8z"/><path d="M949.2,540.8c-12.3,0-20.4-4.1-28.6-12.3L757.3,365.3c-16.3-16.3-16.3-40.8,0-57.2c16.3-16.3,40.8-16.3,57.2,0l163.3,163.3c16.3,16.3,16.3,40.8,0,57.2C969.6,536.8,961.4,540.8,949.2,540.8z"/><path d="M785.8,704.2c-12.3,0-20.4-4.1-28.6-12.3c-16.3-16.3-16.3-40.8,0-57.2l163.3-163.3c16.3-16.3,40.8-16.3,57.2,0c16.3,16.3,16.3,40.8,0,57.2L814.4,691.9C806.3,700.1,798.1,704.2,785.8,704.2z"/></g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.3 KiB |
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Svg Vector Icons : http://www.onlinewebfonts.com/icon -->
|
||||||
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
||||||
|
<svg fill="#89b4fa" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 1000 1000" enable-background="new 0 0 1000 1000" xml:space="preserve">
|
||||||
|
<metadata> Svg Vector Icons : http://www.onlinewebfonts.com/icon </metadata>
|
||||||
|
<g><path d="M134.6,285.6C64.9,420.7,60.1,590,137.1,723.4L42,668.5l-32,55.4c93.1,52.1,133.6,75.9,184,106.2c28.5-51.5,52.8-94.4,107.4-186.1L246,612l-53.4,92.5C65.4,502.7,167.2,200.3,398.8,126.2C638,29.3,929,223.5,931.5,481.5c19.6,236.7-208.9,443.6-439.3,416.2l-29.5,51c277.7,54.4,556.5-201.7,524.7-483.1C976.1,170.8,637.1-41.2,367.1,77.5C262.8,114.2,183.1,191.5,134.6,285.6z"/></g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 877 B |
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Svg Vector Icons : http://www.onlinewebfonts.com/icon -->
|
||||||
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
||||||
|
<svg fill="#89b4fa" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 1000 1000" enable-background="new 0 0 1000 1000" xml:space="preserve">
|
||||||
|
<metadata> Svg Vector Icons : http://www.onlinewebfonts.com/icon </metadata>
|
||||||
|
<g><path d="M764,152.1c30.9,22,58.3,46.8,82.4,74.6c24,27.8,44.6,57.8,61.8,90.1c17.2,32.3,30.2,66.4,39.1,102.4c8.9,36,13.4,72.6,13.4,109.6c0,63.8-12.2,123.7-36.5,179.6c-24.4,55.9-57.3,104.7-98.8,146.2c-41.5,41.5-90.2,74.5-146.2,98.8C623.2,977.8,563.3,990,499.5,990c-63.1,0-122.7-12.2-178.6-36.5c-55.9-24.4-104.8-57.3-146.7-98.8c-41.9-41.5-74.8-90.2-98.8-146.2c-24-55.9-36-115.8-36-179.6c0-36.4,4.3-72.1,12.9-107.1c8.6-35,20.8-68.3,36.5-99.9c15.8-31.6,35.3-61.1,58.7-88.5c23.3-27.5,49.4-52.2,78.2-74.1c15.1-11,31.4-15.1,48.9-12.4c17.5,2.7,31.7,11.3,42.7,25.7c11,14.4,15.1,30.5,12.4,48.4c-2.7,17.8-11.3,32.3-25.7,43.2c-43.2,31.6-76.4,70.3-99.3,116.3c-23,46-34.5,95.4-34.5,148.2c0,45.3,8.6,88,25.7,128.2c17.2,40.1,40.7,75.1,70.5,105c29.9,29.9,64.9,53.5,105,71c40.1,17.5,82.9,26.3,128.2,26.3c45.3,0,88-8.7,128.2-26.3c40.1-17.5,75.1-41.2,105-71s53.5-64.9,71-105c17.5-40.1,26.3-82.9,26.3-128.2c0-53.5-12.4-104.1-37.1-151.8c-24.7-47.7-59.4-87-104-117.9c-15.1-10.3-24.2-24.4-27.3-42.2c-3.1-17.8,0.5-34.3,10.8-49.4c10.3-14.4,24.4-23.2,42.2-26.2C732.5,138.2,748.9,141.8,764,152.1L764,152.1z M499.5,531.9c-17.8,0-33.1-6.3-45.8-19c-12.7-12.7-19-28-19-45.8V75.9c0-17.8,6.3-33.3,19-46.3c12.7-13,28-19.6,45.8-19.6c18.5,0,34.1,6.5,46.8,19.6c12.7,13,19,28.5,19,46.3v391.2c0,17.8-6.3,33.1-19,45.8C533.6,525.6,518,531.9,499.5,531.9L499.5,531.9z"/></g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.8 KiB |
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Svg Vector Icons : http://www.onlinewebfonts.com/icon -->
|
||||||
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
||||||
|
<svg fill="#89b4fa" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 1000 1000" enable-background="new 0 0 1000 1000" xml:space="preserve">
|
||||||
|
<metadata> Svg Vector Icons : http://www.onlinewebfonts.com/icon </metadata>
|
||||||
|
<g><path d="M500,990c-66.1,0-130.3-13-190.7-38.5c-58.4-24.7-110.8-60-155.7-105s-80.3-97.4-105-155.7C23,630.3,10,566.1,10,500c0-66.1,13-130.3,38.5-190.7c24.7-58.4,60-110.8,105-155.7c45-45,97.4-80.3,155.7-105C369.7,23,433.9,10,500,10c66.1,0,130.3,13,190.7,38.5c58.4,24.7,110.8,60,155.7,105c45,45,80.3,97.4,105,155.7C977,369.7,990,433.9,990,500c0,66.1-13,130.3-38.5,190.7c-24.7,58.4-60,110.8-105,155.7s-97.4,80.3-155.7,105C630.3,977,566.1,990,500,990z M500,79.6c-112.3,0-217.9,43.7-297.3,123.1C123.3,282.1,79.6,387.7,79.6,500s43.7,217.9,123.1,297.3c79.4,79.4,185,123.1,297.3,123.1c112.3,0,217.9-43.7,297.3-123.1c79.4-79.4,123.1-185,123.1-297.3s-43.7-217.9-123.1-297.3C717.9,123.3,612.3,79.6,500,79.6z"/><path d="M322.5,290.6h108v412h-108V290.6z"/><path d="M561.6,290.6h107.9v412H561.6V290.6z"/></g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.3 KiB |
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"label": "lock",
|
"label": "lock",
|
||||||
"action": "loginctl lock-session",
|
"action": "hyprlock &",
|
||||||
"text": "Lock",
|
"text": "Lock",
|
||||||
"keybind": "l"
|
"keybind": "l"
|
||||||
}
|
}
|
||||||
@@ -24,7 +24,7 @@
|
|||||||
}
|
}
|
||||||
{
|
{
|
||||||
"label": "suspend",
|
"label": "suspend",
|
||||||
"action": "systemctl suspend",
|
"action": "sleep 0.1 && systemctl suspend",
|
||||||
"text": "Suspend",
|
"text": "Suspend",
|
||||||
"keybind": "u"
|
"keybind": "u"
|
||||||
}
|
}
|
||||||
@@ -33,4 +33,4 @@
|
|||||||
"action": "systemctl reboot",
|
"action": "systemctl reboot",
|
||||||
"text": "Reboot",
|
"text": "Reboot",
|
||||||
"keybind": "r"
|
"keybind": "r"
|
||||||
}
|
}
|
||||||
@@ -92,4 +92,4 @@
|
|||||||
:monitor 0
|
:monitor 0
|
||||||
:geometry (geometry :x 1108 :y -45)
|
:geometry (geometry :x 1108 :y -45)
|
||||||
(lyrics-single)
|
(lyrics-single)
|
||||||
)
|
)
|
||||||
@@ -1,43 +0,0 @@
|
|||||||
> 嗯, 用户想问的似乎是如何使用
|
|
||||||
>
|
|
||||||
> - `qemu-user-static`
|
|
||||||
> - `qemu-user-static-binfmt`
|
|
||||||
>
|
|
||||||
> 通过
|
|
||||||
>
|
|
||||||
> ```bash
|
|
||||||
> sudo systemd-nspawn -M {{ rootfs-name }}
|
|
||||||
> ```
|
|
||||||
>
|
|
||||||
> 运行从
|
|
||||||
>
|
|
||||||
> ```bash
|
|
||||||
> wget https://os.archlinuxarm.org/os/ArchLinuxARM-aarch64-latest.tar.gz
|
|
||||||
> ```
|
|
||||||
>
|
|
||||||
> 下载且通过
|
|
||||||
>
|
|
||||||
> ```bash
|
|
||||||
> sudo mkdir -p /var/lib/machines/{{ rootfs-name }} && \
|
|
||||||
> sudo bsdtar -xpf ArchLinuxARM-aarch64-latest.tar.gz -C /var/lib/machines/{{ rootfs-name }}
|
|
||||||
> ```
|
|
||||||
>
|
|
||||||
> 解压的 aarch64 架构的 archlinux rootfs. 但要不要提醒用户应该取消注释 `cat /etc/pacman.conf` 中的
|
|
||||||
>
|
|
||||||
> ```conf
|
|
||||||
> [options]
|
|
||||||
> #DisableSandboxFilesystem
|
|
||||||
> #DisableSandboxSyscalls
|
|
||||||
> ```
|
|
||||||
>
|
|
||||||
> 以禁用在 systemd-nspawn 中默认不可用的下载沙盒, 并且应该避免运行需要 setuid 的程序 (如 sudo), 因为 `/proc/sys/fs/binfmt_misc/qemu-aarch64` 中的 `flags` 缺失 `C` (Credentials) 标志, 导致可执行文件的 `s` 权限位被忽视? 不过如果真的需要 setuid 的话, 也可以通过
|
|
||||||
>
|
|
||||||
> ```bash
|
|
||||||
> sudo cp /usr/lib/binfmt.d/qemu-aarch64-static.conf /etc/binfmt.d/
|
|
||||||
> ```
|
|
||||||
>
|
|
||||||
> 复制一份并在末尾加上 C, 要不要一并告诉用户?
|
|
||||||
>
|
|
||||||
> 算了, 反正用户什么也不懂, 即使问题解决也只会原地消失, 一句感谢也不说.
|
|
||||||
|
|
||||||
_Baked for 27s._
|
|
||||||
@@ -1,76 +0,0 @@
|
|||||||
## 问题
|
|
||||||
|
|
||||||
### VapourSynth 破坏性更新
|
|
||||||
|
|
||||||
> Tue May 5 09:08:30 CEST 2026
|
|
||||||
|
|
||||||
- `extra/vapoursynth` 包更新至 75 版本后 (此问题其实是 R74 引入的, 但他们似乎跳过了 R74 直接在近几天更新至 R75), vsscript 库文件符号链接关系如下:
|
|
||||||
- `/usr/lib/libvapoursynth-script.so` -> `python3.14/site-packages/vapoursynth/libvsscript.so`
|
|
||||||
- `/usr/lib/libvapoursynth-script.so.0` -> `python3.14/site-packages/vapoursynth/libvsscript.so`
|
|
||||||
|
|
||||||
这导致 ldconfig 根据 SONAME 字段建立的缓存条目变化, 例如从 `libvapoursynth-script.so.0 (libc,x86-64) => /usr/lib/libvapoursynth-script.so.0` 变为 `libvsscript.so (libc6,x86-64) => /usr/lib/libvsscript.so`, 可能会使其他未能重新链接的程序找不到对应库.
|
|
||||||
|
|
||||||
但该问题影响范围比较有限, 因为动态库并不完全根据 ldconfig 缓存条目加载 —— 如果文件名完全匹配也能正确加载, 毕竟 `/usr/lib/libvapoursynth-script.so.0` 仍然存在.
|
|
||||||
|
|
||||||
- 同时, 插件目录也从 `/usr/lib/vapoursynth/` 改为 `/usr/lib/python3.14/site-packages/vapoursynth/plugins/`, 很多包未能及时更新插件安装路径, 导致 vapoursynth 插件丢失.
|
|
||||||
|
|
||||||
extra 仓库中的 vapoursynth-plugin-\* 包均已改为类似如下动态查找插件安装路径的方式:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
install -Dm 755 libxxx.so -t "${pkgdir}"/$(python -c 'import vapoursynth;print(vapoursynth.get_plugin_dir())')/
|
|
||||||
```
|
|
||||||
|
|
||||||
所以不会出问题. 主要影响范围是打包者或上游硬编码插件安装路径为 `/usr/lib/vapoursynth` 的包, 其中包括少数 extra 仓库的包如 `extra/ffms2` 和众多 AUR 包.
|
|
||||||
|
|
||||||
- vapoursynth 不再在编译器 link libpython, 而必须在加载 libvsscript.so 时选择 python. 选哪个 python 由 `$HOME/.config/vapoursynth/vapoursynth.toml` 维护的映射关系决定, 格式类似:
|
|
||||||
|
|
||||||
```toml
|
|
||||||
"/usr/lib/python3.14/site-packages/vapoursynth/libvsscript.so" = ["/usr/bin/python","/usr/lib/libpython3.14.so.1.0"]
|
|
||||||
```
|
|
||||||
|
|
||||||
可以运行 `vapoursynth config` 自动更新.
|
|
||||||
|
|
||||||
然而, 上文提到过新的 libvsscript.so 的 ldconfig 条目是 `libvsscript.so (libc6,x86-64) => /usr/lib/libvsscript.so`, 而 `vapoursynth config` 只会在 `vapoursynth.toml` 写入 `/usr/lib/python3.14/site-packages/vapoursynth/libvsscript.so` 的条目. 此时, 如果加载 libvsscript.so, 会从 ldconfig 拿到 `/usr/lib/libvsscript.so`,而 vapoursynth 在拿到此路径后不解 symlink, 查 `vapoursynth.toml` 时和任何条目都对不上, 导致加载失败. 报错类似:
|
|
||||||
|
|
||||||
```
|
|
||||||
Python executable and library path couldn't be determined despite automatic configuration. Run `vapoursynth config` to set it for this Python installation and then try again.
|
|
||||||
```
|
|
||||||
|
|
||||||
临时修复方式为在 `$HOME/.config/vapoursynth/vapoursynth.toml` 里手动加上针对 `/usr/lib/libvsscript.so` 符号链接的条目:
|
|
||||||
|
|
||||||
```toml
|
|
||||||
"/usr/lib/libvsscript.so" = ["/usr/bin/python","/usr/lib/libpython3.14.so.1.0"]
|
|
||||||
```
|
|
||||||
|
|
||||||
如果运行 vapoursynth 此次更新前构建并链接的程序, 可能同样需要为 `/usr/lib/libvapoursynth-script.so.0` 准备对应条目:
|
|
||||||
|
|
||||||
```toml
|
|
||||||
"/usr/lib/libvapoursynth-script.so.0" = ["/usr/bin/python","/usr/lib/libpython3.14.so.1.0"]
|
|
||||||
```
|
|
||||||
|
|
||||||
影响范围为所有动态链接 vapoursynth 的二进制文件.
|
|
||||||
|
|
||||||
### CUDA 13.2 不兼容 GCC 16.1
|
|
||||||
|
|
||||||
> Mon May 4 15:39:17 CEST 2026
|
|
||||||
|
|
||||||
nvcc 和 gcc 兼容问题的历史重演. 随 GCC 16.1 发布, 以前用 GCC 15.2 能够编译的 CUDA 包会报一堆错误, 影响范围非常大.
|
|
||||||
|
|
||||||
解决方法为装 gcc15 等旧版本工具链, 并修改编译流程使 nvcc 使用指定编译器. 例如对于部分 Makefile:
|
|
||||||
|
|
||||||
```makefile
|
|
||||||
CUDA_CCBIN ?=
|
|
||||||
cudaccbin = $(if $(CUDA_CCBIN),-ccbin $(CUDA_CCBIN),)
|
|
||||||
|
|
||||||
...
|
|
||||||
|
|
||||||
nvcc $(cudaccbin) ...
|
|
||||||
```
|
|
||||||
|
|
||||||
但这样会带来一个问题: `gcc15` 是 AUR 包, 需要编译. 而这并不会是一个很愉快的过程. 除去超大的仓库体积, 超长时间的编译测试和超高的资源占用外, 过程中还可能会因为各种问题失败, 修复问题后可能还需要从头再来, 成本过高.
|
|
||||||
|
|
||||||
但好在 cachyos 有打包 `gcc14` 二进制包, 因此再降一个版本即可绕过编译过程. 但 AUR 上的众多打包者应该还是会选择 `gcc15`, 因此在有仓库打包 `gcc15` 二进制包或 NVIDIA 更新 CUDA 支持 GCC 16 之前, 几乎所有涉及 CUDA 的包仍然需要手动修改 PKGBUILD 构建.
|
|
||||||
|
|
||||||
另外还有几个可选方案:
|
|
||||||
|
|
||||||
- 可以用 clang++ 代替 nvcc, 但支持程度似乎有限 (`clang++: warning: CUDA version is newer than the latest partially supported version 12.9 [-Wunknown-cuda-version]`), 且对于部分已经在使用 nvcc 构建的项目可能需要较大幅度地修改编译参数和流程, 实用价值不高.
|
|
||||||
@@ -0,0 +1,75 @@
|
|||||||
|
things I have installed:
|
||||||
|
|
||||||
|
full KDE Plasma 6 setup
|
||||||
|
which can provide:
|
||||||
|
SDDM theme # Breeze is enough
|
||||||
|
kcalc/kalc # calculator(s), what's the difference?
|
||||||
|
kcolorchooser # or hyprpicker
|
||||||
|
pipewire & friends
|
||||||
|
...
|
||||||
|
|
||||||
|
# hypr*
|
||||||
|
hyprland
|
||||||
|
hypridle
|
||||||
|
hyprlock
|
||||||
|
hyprshot
|
||||||
|
hyprpicker
|
||||||
|
plugin hyprexpo # workspaces overview
|
||||||
|
plugin hyprorganize # https://github.com/Uyanide/hyprplug
|
||||||
|
|
||||||
|
# xdg-desktop-portal*
|
||||||
|
xdg-desktop-portal
|
||||||
|
xdg-desktop-portal-hyprland # not working with my Intel iGPU, but fine with NVIDIA dGPU
|
||||||
|
xdg-desktop-portal-gtk # for file picker
|
||||||
|
xdg-desktop-portal-gnome # why not?
|
||||||
|
|
||||||
|
# terminal emulator(s)
|
||||||
|
kitty # normal terminal
|
||||||
|
ghostty # floating terminal, for btop for example
|
||||||
|
|
||||||
|
# under surface
|
||||||
|
swww # wallpaper daemon
|
||||||
|
mako # notification daemon
|
||||||
|
gnome-keyring # --password-store=gnome-libsecret
|
||||||
|
wl-clipboard
|
||||||
|
cliphist # clipboard history
|
||||||
|
slurp # region selector
|
||||||
|
wf-recorder # screen recorder
|
||||||
|
brightnessctl
|
||||||
|
playerctl
|
||||||
|
pamixer
|
||||||
|
zoxide # better cd
|
||||||
|
eza # better ls
|
||||||
|
bat # better cat
|
||||||
|
|
||||||
|
# GUI
|
||||||
|
waybar
|
||||||
|
eww
|
||||||
|
wlogout
|
||||||
|
rofi(-wayland)
|
||||||
|
mpv
|
||||||
|
network-manager-applet # nm-applet
|
||||||
|
blueman # bluetooth GUI & applet
|
||||||
|
pwvucontrol
|
||||||
|
gnome-text-editor # or kwrite, notepad replacement
|
||||||
|
btop # system monitor
|
||||||
|
activate-linux # :/
|
||||||
|
polkit-gnome # polkit authentication agent
|
||||||
|
gradia # screenshots editor
|
||||||
|
|
||||||
|
# fonts & themes
|
||||||
|
maplemono-nf-cn / ttf-maplemono-nf-cn-unhinted (archlinuxcn)
|
||||||
|
Sour Gummy
|
||||||
|
ttf-meslo-nerd
|
||||||
|
ttf-jetbrains-mono-nerd
|
||||||
|
spicetify # spotify tweaks
|
||||||
|
spicetify-maketplace # spotify themes
|
||||||
|
nwg-look # theme of GTK apps
|
||||||
|
catppuccin-gtk-theme-mocha # theme of GTK apps
|
||||||
|
kvantum
|
||||||
|
|
||||||
|
# utils
|
||||||
|
bc
|
||||||
|
jq
|
||||||
|
python-colorthief
|
||||||
|
python-watchdog
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
things I have installed:
|
||||||
|
|
||||||
|
in addition to everything in `./hyprland-ricing.txt`:
|
||||||
|
|
||||||
|
xwayland-satellite
|
||||||
|
wlsunset
|
||||||
|
wezterm # replaces ghostty
|
||||||
@@ -7,6 +7,49 @@ grab
|
|||||||
| bash -s -- "$0"
|
| bash -s -- "$0"
|
||||||
exit $?
|
exit $?
|
||||||
|
|
||||||
|
> [!NOTE]
|
||||||
|
> The gibberish above is **NOT** meant to be copy-pasted into the terminal. It is a script that updates the [Full list](#full-list) section below, and should be run as:
|
||||||
|
>
|
||||||
|
> ```bash
|
||||||
|
> bash /path/to/dotfiles/memo/packages.md
|
||||||
|
> ```
|
||||||
|
|
||||||
|
## Notes
|
||||||
|
|
||||||
|
| | |
|
||||||
|
| --------- | ---------------------------- |
|
||||||
|
| alass | Subtitle sync; used in mpv |
|
||||||
|
| axel | CLI download accelerator |
|
||||||
|
| figlet | Draw large letters |
|
||||||
|
| foliate | GTK eBook reader |
|
||||||
|
| gearlever | AppImage manager |
|
||||||
|
| gping | Ping with better looking TUI |
|
||||||
|
| jp2a | JPEG to ASCII |
|
||||||
|
| nethogs | Network top |
|
||||||
|
| picard | Music tagger (MusicBrainz) |
|
||||||
|
| toilet | Better FIGlet |
|
||||||
|
| wev | Debug wayland events |
|
||||||
|
| yad | Fork of zenity |
|
||||||
|
| zenity | Display dialog boxes via cli |
|
||||||
|
|
||||||
|
## Some useful commands
|
||||||
|
|
||||||
|
Show packages sorted by size, with a preview of their info:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
expac -H M '%m\t%n' \
|
||||||
|
| sort -hr \
|
||||||
|
| fzf --delimiter='\t' --with-nth=1,2 --multi \
|
||||||
|
--preview 'yay -Qi {2}' \
|
||||||
|
--preview-window='right,70%,wrap'
|
||||||
|
```
|
||||||
|
|
||||||
|
Update the list below:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
bash /path/to/dotfiles/memo/packages.md
|
||||||
|
```
|
||||||
|
|
||||||
<!-- update-full-list:start
|
<!-- update-full-list:start
|
||||||
|
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
@@ -51,49 +94,6 @@ echo "Updated Full list in: $script_path"
|
|||||||
|
|
||||||
update-full-list:end -->
|
update-full-list:end -->
|
||||||
|
|
||||||
> [!NOTE]
|
|
||||||
> The gibberish above is **NOT** meant to be copy-pasted into the terminal. It is a script that updates the [Full list](#full-list) section below, and should be run as:
|
|
||||||
>
|
|
||||||
> ```bash
|
|
||||||
> bash /path/to/dotfiles/memo/packages.md
|
|
||||||
> ```
|
|
||||||
|
|
||||||
## Notes
|
|
||||||
|
|
||||||
| | |
|
|
||||||
| --------- | ---------------------------- |
|
|
||||||
| alass | Subtitle sync; used in mpv |
|
|
||||||
| axel | CLI download accelerator |
|
|
||||||
| figlet | Draw large letters |
|
|
||||||
| foliate | GTK eBook reader |
|
|
||||||
| gearlever | AppImage manager |
|
|
||||||
| gping | Ping with better looking TUI |
|
|
||||||
| jp2a | JPEG to ASCII |
|
|
||||||
| nethogs | Network top |
|
|
||||||
| picard | Music tagger (MusicBrainz) |
|
|
||||||
| toilet | Better FIGlet |
|
|
||||||
| wev | Debug wayland events |
|
|
||||||
| yad | Fork of zenity |
|
|
||||||
| zenity | Display dialog boxes via cli |
|
|
||||||
|
|
||||||
## Some useful commands
|
|
||||||
|
|
||||||
Show packages sorted by size, with a preview of their info:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
expac -H M '%m\t%n' \
|
|
||||||
| sort -hr \
|
|
||||||
| fzf --delimiter='\t' --with-nth=1,2 --multi \
|
|
||||||
--preview 'yay -Qi {2}' \
|
|
||||||
--preview-window='right,70%,wrap'
|
|
||||||
```
|
|
||||||
|
|
||||||
Update the list below:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
bash /path/to/dotfiles/memo/packages.md
|
|
||||||
```
|
|
||||||
|
|
||||||
## Full list
|
## Full list
|
||||||
|
|
||||||
```
|
```
|
||||||
@@ -106,10 +106,8 @@ archiso
|
|||||||
archlinux-contrib
|
archlinux-contrib
|
||||||
archlinuxcn-keyring
|
archlinuxcn-keyring
|
||||||
ark
|
ark
|
||||||
av1an
|
|
||||||
awww
|
awww
|
||||||
axel
|
axel
|
||||||
azure-cli
|
|
||||||
base
|
base
|
||||||
base-devel
|
base-devel
|
||||||
bash-completion
|
bash-completion
|
||||||
@@ -140,13 +138,11 @@ chafa
|
|||||||
chaotic-keyring
|
chaotic-keyring
|
||||||
chaotic-mirrorlist
|
chaotic-mirrorlist
|
||||||
chromium
|
chromium
|
||||||
chwd
|
|
||||||
claude-code
|
claude-code
|
||||||
cloc
|
cloc
|
||||||
cmake
|
cmake
|
||||||
cmatrix-git
|
cmatrix-git
|
||||||
composer
|
composer
|
||||||
compsize
|
|
||||||
corectrl
|
corectrl
|
||||||
cowfortune
|
cowfortune
|
||||||
cpu-x
|
cpu-x
|
||||||
@@ -185,9 +181,7 @@ fcitx5-qt
|
|||||||
fd
|
fd
|
||||||
fdkaac
|
fdkaac
|
||||||
ffmpeg-full
|
ffmpeg-full
|
||||||
ffms2
|
|
||||||
ffnvcodec-headers
|
ffnvcodec-headers
|
||||||
ffvship
|
|
||||||
figlet
|
figlet
|
||||||
filelight
|
filelight
|
||||||
fish
|
fish
|
||||||
@@ -203,7 +197,6 @@ frei0r-plugins
|
|||||||
fuzzel
|
fuzzel
|
||||||
fzf
|
fzf
|
||||||
gamemode
|
gamemode
|
||||||
gcc14
|
|
||||||
gdb
|
gdb
|
||||||
gdu
|
gdu
|
||||||
gearlever
|
gearlever
|
||||||
@@ -281,11 +274,10 @@ lib32-nvidia-utils
|
|||||||
lib32-opencl-nvidia
|
lib32-opencl-nvidia
|
||||||
lib32-vulkan-icd-loader
|
lib32-vulkan-icd-loader
|
||||||
lib32-vulkan-intel
|
lib32-vulkan-intel
|
||||||
libc++
|
|
||||||
libdbusmenu-lxqt
|
libdbusmenu-lxqt
|
||||||
|
libggml-git
|
||||||
libguestfs
|
libguestfs
|
||||||
libreoffice-still-zh-cn
|
libreoffice-still-zh-cn
|
||||||
libspng
|
|
||||||
libva-intel-driver
|
libva-intel-driver
|
||||||
libva-nvidia-driver
|
libva-nvidia-driver
|
||||||
libva-utils
|
libva-utils
|
||||||
@@ -297,7 +289,8 @@ linux-cachyos-headers
|
|||||||
linux-firmware
|
linux-firmware
|
||||||
linux-lts
|
linux-lts
|
||||||
linux-lts-headers
|
linux-lts-headers
|
||||||
linuxqq
|
linuxqq-nt
|
||||||
|
llama-cpp-git
|
||||||
llmfit-bin
|
llmfit-bin
|
||||||
localsend
|
localsend
|
||||||
lolcat
|
lolcat
|
||||||
@@ -311,7 +304,7 @@ man-pages
|
|||||||
mangohud
|
mangohud
|
||||||
matugen
|
matugen
|
||||||
meson
|
meson
|
||||||
mkvtoolnix-cli
|
mission-center
|
||||||
modprobed-db
|
modprobed-db
|
||||||
moonlight-qt
|
moonlight-qt
|
||||||
moreutils
|
moreutils
|
||||||
@@ -321,7 +314,6 @@ mpd-mpris
|
|||||||
mpv-full
|
mpv-full
|
||||||
mpv-mpris
|
mpv-mpris
|
||||||
msedit
|
msedit
|
||||||
namcap
|
|
||||||
nasm
|
nasm
|
||||||
nautilus
|
nautilus
|
||||||
nautilus-share
|
nautilus-share
|
||||||
@@ -340,9 +332,7 @@ nvidia-prime
|
|||||||
nvidia-settings
|
nvidia-settings
|
||||||
nvidia-utils
|
nvidia-utils
|
||||||
nvme-cli
|
nvme-cli
|
||||||
nvtop
|
|
||||||
nwg-look
|
nwg-look
|
||||||
oavif
|
|
||||||
obs-studio
|
obs-studio
|
||||||
obsidian
|
obsidian
|
||||||
okular
|
okular
|
||||||
@@ -391,8 +381,6 @@ python-yaml
|
|||||||
qbittorrent-enhanced
|
qbittorrent-enhanced
|
||||||
qdiskinfo
|
qdiskinfo
|
||||||
qemu-full
|
qemu-full
|
||||||
qemu-user-static
|
|
||||||
qemu-user-static-binfmt
|
|
||||||
qt5-graphicaleffects
|
qt5-graphicaleffects
|
||||||
qt5-quickcontrols
|
qt5-quickcontrols
|
||||||
qt5-quickcontrols2
|
qt5-quickcontrols2
|
||||||
@@ -419,7 +407,6 @@ quickshell-git
|
|||||||
qutebrowser
|
qutebrowser
|
||||||
rclone
|
rclone
|
||||||
reflector
|
reflector
|
||||||
resources
|
|
||||||
riscv64-linux-gnu-binutils
|
riscv64-linux-gnu-binutils
|
||||||
riscv64-linux-gnu-gcc
|
riscv64-linux-gnu-gcc
|
||||||
rsync
|
rsync
|
||||||
@@ -499,7 +486,6 @@ unrar
|
|||||||
usbip
|
usbip
|
||||||
uv
|
uv
|
||||||
valgrind
|
valgrind
|
||||||
vapoursynth-plugin-vship-cuda-git
|
|
||||||
ventoy-bin
|
ventoy-bin
|
||||||
vesktop-bin
|
vesktop-bin
|
||||||
vicinae
|
vicinae
|
||||||
@@ -582,7 +568,6 @@ yt-dlp
|
|||||||
zellij
|
zellij
|
||||||
zen-browser-bin
|
zen-browser-bin
|
||||||
zenity
|
zenity
|
||||||
zig
|
|
||||||
zoxide
|
zoxide
|
||||||
zram-generator
|
zram-generator
|
||||||
zsh
|
zsh
|
||||||
|
|||||||