Compare commits
48 Commits
17d803c517
...
macbook
| Author | SHA1 | Date | |
|---|---|---|---|
| 77d3404812 | |||
| be35b62a87 | |||
| a598dcd1fc | |||
| 95d80c31d5 | |||
| 51515037b3 | |||
| 0a6a42e0b7 | |||
| 1820a8eff5 | |||
| e43d39b957 | |||
| f83ad4c21e | |||
| 0659773daf | |||
| 6f574b81e0 | |||
| 88f0c9b0b9 | |||
| 153d829677 | |||
| d0ccffc8d0 | |||
| 78a32b5616 | |||
| 0ab0236ba2 | |||
| 61df95387e | |||
| 002092af34 | |||
| 452fa88d70 | |||
| c36d9b3464 | |||
| 616e2b2b6e | |||
| a7c52f39a0 | |||
| 727bc542a1 | |||
| 1d5d0e7a6f | |||
| 01adfc34b7 | |||
| 82e36f6f75 | |||
| 389a8c1dd2 | |||
| bf3225a165 | |||
| 39d1956216 | |||
| 853c0f5b5d | |||
| 09c6c9023b | |||
| a80bb51283 | |||
| 5b2d9c71e7 | |||
| 0fd17f71a1 | |||
| d4166aa883 | |||
| 462b538f78 | |||
| e41f4ad02a | |||
| 6c9ab3fa19 | |||
| def29c9e18 | |||
| a574204578 | |||
| b3c3640a54 | |||
| 145bbd1996 | |||
| 386d50d7ce | |||
| 0d1b98f65e | |||
| 3812064349 | |||
| 645e292b0d | |||
| bcfc8fe296 | |||
| f175673459 |
76
.config/aerospace/aerospace.toml
Normal file
76
.config/aerospace/aerospace.toml
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
# i3 doesn't have "normalizations" feature that why we disable them here.
|
||||||
|
# But the feature is very helpful.
|
||||||
|
# Normalizations eliminate all sorts of weird tree configurations that don't make sense.
|
||||||
|
# Give normalizations a chance and enable them back.
|
||||||
|
enable-normalization-flatten-containers = true
|
||||||
|
enable-normalization-opposite-orientation-for-nested-containers = true
|
||||||
|
automatically-unhide-macos-hidden-apps = true
|
||||||
|
|
||||||
|
# Mouse follows focus when focused monitor changes
|
||||||
|
on-focused-monitor-changed = ['move-mouse monitor-lazy-center']
|
||||||
|
|
||||||
|
start-at-login = true
|
||||||
|
|
||||||
|
[gaps]
|
||||||
|
inner.horizontal = 10
|
||||||
|
inner.vertical = 10
|
||||||
|
outer.left = 5
|
||||||
|
outer.bottom = 5
|
||||||
|
outer.top = 5
|
||||||
|
outer.right = 5
|
||||||
|
|
||||||
|
|
||||||
|
[mode.main.binding]
|
||||||
|
alt-enter = 'exec-and-forget alacritty msg create-window || alacritty'
|
||||||
|
|
||||||
|
alt-b = 'exec-and-forget /Applications/LibreWolf.app/Contents/MacOS/librewolf'
|
||||||
|
|
||||||
|
# i3 wraps focus by default
|
||||||
|
alt-h = 'focus left'
|
||||||
|
alt-j = 'focus down'
|
||||||
|
alt-k = 'focus up'
|
||||||
|
alt-l = 'focus right'
|
||||||
|
|
||||||
|
# alt-shift-j = 'move left'
|
||||||
|
# alt-shift-k = 'move down'
|
||||||
|
# alt-shift-l = 'move up'
|
||||||
|
# alt-shift-semicolon = 'move right'
|
||||||
|
|
||||||
|
# Consider using 'join-with' command as a 'split' replacement if you want to enable
|
||||||
|
# normalizations
|
||||||
|
# alt-h = 'split horizontal'
|
||||||
|
# alt-v = 'split vertical'
|
||||||
|
|
||||||
|
alt-f = 'fullscreen'
|
||||||
|
|
||||||
|
alt-shift-q = 'exec-and-forget current_workspace="$(aerospace list-workspaces --focused)"; aerospace close; aerospace workspace "$current_workspace"'
|
||||||
|
|
||||||
|
alt-shift-space = 'layout floating tiling' # 'floating toggle' in i3
|
||||||
|
|
||||||
|
alt-1 = 'workspace 1'
|
||||||
|
alt-2 = 'workspace 2'
|
||||||
|
alt-3 = 'workspace 3'
|
||||||
|
alt-4 = 'workspace 4'
|
||||||
|
alt-5 = 'workspace 5'
|
||||||
|
alt-6 = 'workspace 6'
|
||||||
|
alt-7 = 'workspace 7'
|
||||||
|
alt-8 = 'workspace 8'
|
||||||
|
alt-9 = 'workspace 9'
|
||||||
|
alt-0 = 'workspace 10'
|
||||||
|
|
||||||
|
alt-shift-1 = 'move-node-to-workspace 1'
|
||||||
|
alt-shift-2 = 'move-node-to-workspace 2'
|
||||||
|
alt-shift-3 = 'move-node-to-workspace 3'
|
||||||
|
alt-shift-4 = 'move-node-to-workspace 4'
|
||||||
|
alt-shift-5 = 'move-node-to-workspace 5'
|
||||||
|
alt-shift-6 = 'move-node-to-workspace 6'
|
||||||
|
alt-shift-7 = 'move-node-to-workspace 7'
|
||||||
|
alt-shift-8 = 'move-node-to-workspace 8'
|
||||||
|
alt-shift-9 = 'move-node-to-workspace 9'
|
||||||
|
alt-shift-0 = 'move-node-to-workspace 10'
|
||||||
|
|
||||||
|
|
||||||
|
alt-shift-r = 'reload-config'
|
||||||
|
|
||||||
|
alt-y = 'resize width -50'
|
||||||
|
alt-o = 'resize width +50'
|
||||||
@ -2,22 +2,22 @@
|
|||||||
TERM = "xterm-256color"
|
TERM = "xterm-256color"
|
||||||
|
|
||||||
[font]
|
[font]
|
||||||
size = 12.0
|
size = 14
|
||||||
|
|
||||||
[font.normal]
|
[font.normal]
|
||||||
family = "Input Nerd Font"
|
family = "Hack Nerd Font Mono"
|
||||||
style = "Regular"
|
style = "Regular"
|
||||||
|
|
||||||
[font.bold]
|
[font.bold]
|
||||||
family = "Input Nerd Font"
|
family = "Hack Nerd Font Mono"
|
||||||
style = "Bold"
|
style = "Bold"
|
||||||
|
|
||||||
[font.bold_italic]
|
[font.bold_italic]
|
||||||
family = "Input Nerd Font"
|
family = "Hack Nerd Font Mono"
|
||||||
style = "Bold Italic"
|
style = "Bold Italic"
|
||||||
|
|
||||||
[font.italic]
|
[font.italic]
|
||||||
family = "Input Nerd Font"
|
family = "Hack Nerd Font Mono"
|
||||||
style = "Italic"
|
style = "Italic"
|
||||||
|
|
||||||
[font.offset]
|
[font.offset]
|
||||||
@ -29,7 +29,7 @@ x = 0
|
|||||||
y = 2
|
y = 2
|
||||||
|
|
||||||
[window.padding]
|
[window.padding]
|
||||||
x = 30
|
x = 20
|
||||||
y = 10
|
y = 10
|
||||||
|
|
||||||
[window]
|
[window]
|
||||||
|
|||||||
@ -1,34 +0,0 @@
|
|||||||
# From the famous Cobalt2 sublime theme
|
|
||||||
# Source : https://github.com/wesbos/cobalt2/tree/master/Cobalt2
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x122637'
|
|
||||||
foreground: '0xffffff'
|
|
||||||
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: '0x122637'
|
|
||||||
cursor: '0xf0cb09'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xff0000'
|
|
||||||
green: '0x37dd21'
|
|
||||||
yellow: '0xfee409'
|
|
||||||
blue: '0x1460d2'
|
|
||||||
magenta: '0xff005d'
|
|
||||||
cyan: '0x00bbbb'
|
|
||||||
white: '0xbbbbbb'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x545454'
|
|
||||||
red: '0xf40d17'
|
|
||||||
green: '0x3bcf1d'
|
|
||||||
yellow: '0xecc809'
|
|
||||||
blue: '0x5555ff'
|
|
||||||
magenta: '0xff55ff'
|
|
||||||
cyan: '0x6ae3f9'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,48 +0,0 @@
|
|||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x2c2c2c'
|
|
||||||
foreground: '0xd6d6d6'
|
|
||||||
|
|
||||||
dim_foreground: '0xdbdbdb'
|
|
||||||
bright_foreground: '0xd9d9d9'
|
|
||||||
dim_background: '0x202020' # not sure
|
|
||||||
bright_background: '0x3a3a3a' # not sure
|
|
||||||
|
|
||||||
# Cursor colors
|
|
||||||
cursor:
|
|
||||||
text: '0x2c2c2c'
|
|
||||||
cursor: '0xd9d9d9'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x1c1c1c'
|
|
||||||
red: '0xbc5653'
|
|
||||||
green: '0x909d63'
|
|
||||||
yellow: '0xebc17a'
|
|
||||||
blue: '0x7eaac7'
|
|
||||||
magenta: '0xaa6292'
|
|
||||||
cyan: '0x86d3ce'
|
|
||||||
white: '0xcacaca'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x636363'
|
|
||||||
red: '0xbc5653'
|
|
||||||
green: '0x909d63'
|
|
||||||
yellow: '0xebc17a'
|
|
||||||
blue: '0x7eaac7'
|
|
||||||
magenta: '0xaa6292'
|
|
||||||
cyan: '0x86d3ce'
|
|
||||||
white: '0xf7f7f7'
|
|
||||||
|
|
||||||
# Dim colors
|
|
||||||
dim:
|
|
||||||
black: '0x232323'
|
|
||||||
red: '0x74423f'
|
|
||||||
green: '0x5e6547'
|
|
||||||
yellow: '0x8b7653'
|
|
||||||
blue: '0x556b79'
|
|
||||||
magenta: '0x6e4962'
|
|
||||||
cyan: '0x5c8482'
|
|
||||||
white: '0x828282'
|
|
||||||
@ -1,32 +0,0 @@
|
|||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x292C3E'
|
|
||||||
foreground: '0xEBEBEB'
|
|
||||||
|
|
||||||
# Cursor colors
|
|
||||||
cursor:
|
|
||||||
text: '0xFF261E'
|
|
||||||
cursor: '0xFF261E'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x0d0d0d'
|
|
||||||
red: '0xFF301B'
|
|
||||||
green: '0xA0E521'
|
|
||||||
yellow: '0xFFC620'
|
|
||||||
blue: '0x1BA6FA'
|
|
||||||
magenta: '0x8763B8'
|
|
||||||
cyan: '0x21DEEF'
|
|
||||||
white: '0xEBEBEB'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x6D7070'
|
|
||||||
red: '0xFF4352'
|
|
||||||
green: '0xB8E466'
|
|
||||||
yellow: '0xFFD750'
|
|
||||||
blue: '0x1BA6FA'
|
|
||||||
magenta: '0xA578EA'
|
|
||||||
cyan: '0x73FBF1'
|
|
||||||
white: '0xFEFEF8'
|
|
||||||
@ -1,24 +0,0 @@
|
|||||||
colors:
|
|
||||||
primary:
|
|
||||||
background: '0xf8f8f8'
|
|
||||||
foreground: '0x2a2b33'
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xde3d35'
|
|
||||||
green: '0x3e953a'
|
|
||||||
yellow: '0xd2b67b'
|
|
||||||
blue: '0x2f5af3'
|
|
||||||
magenta: '0xa00095'
|
|
||||||
cyan: '0x3e953a'
|
|
||||||
white: '0xbbbbbb'
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xde3d35'
|
|
||||||
green: '0x3e953a'
|
|
||||||
yellow: '0xd2b67b'
|
|
||||||
blue: '0x2f5af3'
|
|
||||||
magenta: '0xa00095'
|
|
||||||
cyan: '0x3e953a'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Ayu Dark)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x0A0E14'
|
|
||||||
foreground: '0xB3B1AD'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x01060E'
|
|
||||||
red: '0xEA6C73'
|
|
||||||
green: '0x91B362'
|
|
||||||
yellow: '0xF9AF4F'
|
|
||||||
blue: '0x53BDFA'
|
|
||||||
magenta: '0xFAE994'
|
|
||||||
cyan: '0x90E1C6'
|
|
||||||
white: '0xC7C7C7'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x686868'
|
|
||||||
red: '0xF07178'
|
|
||||||
green: '0xC2D94C'
|
|
||||||
yellow: '0xFFB454'
|
|
||||||
blue: '0x59C2FF'
|
|
||||||
magenta: '0xFFEE99'
|
|
||||||
cyan: '0x95E6CB'
|
|
||||||
white: '0xFFFFFF'
|
|
||||||
@ -1,33 +0,0 @@
|
|||||||
# Colors (Base16 Default Dark)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x181818'
|
|
||||||
foreground: '0xd8d8d8'
|
|
||||||
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: '0xd8d8d8'
|
|
||||||
cursor: '0xd8d8d8'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x181818'
|
|
||||||
red: '0xab4642'
|
|
||||||
green: '0xa1b56c'
|
|
||||||
yellow: '0xf7ca88'
|
|
||||||
blue: '0x7cafc2'
|
|
||||||
magenta: '0xba8baf'
|
|
||||||
cyan: '0x86c1b9'
|
|
||||||
white: '0xd8d8d8'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x585858'
|
|
||||||
red: '0xab4642'
|
|
||||||
green: '0xa1b56c'
|
|
||||||
yellow: '0xf7ca88'
|
|
||||||
blue: '0x7cafc2'
|
|
||||||
magenta: '0xba8baf'
|
|
||||||
cyan: '0x86c1b9'
|
|
||||||
white: '0xf8f8f8'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Blood Moon)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x10100E'
|
|
||||||
foreground: '0xC6C6C4'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x10100E'
|
|
||||||
red: '0xC40233'
|
|
||||||
green: '0x009F6B'
|
|
||||||
yellow: '0xFFD700'
|
|
||||||
blue: '0x0087BD'
|
|
||||||
magenta: '0x9A4EAE'
|
|
||||||
cyan: '0x20B2AA'
|
|
||||||
white: '0xC6C6C4'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x696969'
|
|
||||||
red: '0xFF2400'
|
|
||||||
green: '0x03C03C'
|
|
||||||
yellow: '0xFDFF00'
|
|
||||||
blue: '0x007FFF'
|
|
||||||
magenta: '0xFF1493'
|
|
||||||
cyan: '0x00CCCC'
|
|
||||||
white: '0xFFFAFA'
|
|
||||||
@ -1,44 +0,0 @@
|
|||||||
# KDE Breeze (Ported from Konsole)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x232627'
|
|
||||||
foreground: '0xfcfcfc'
|
|
||||||
|
|
||||||
dim_foreground: '0xeff0f1'
|
|
||||||
bright_foreground: '0xffffff'
|
|
||||||
dim_background: '0x31363b'
|
|
||||||
bright_background: '0x000000'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x232627'
|
|
||||||
red: '0xed1515'
|
|
||||||
green: '0x11d116'
|
|
||||||
yellow: '0xf67400'
|
|
||||||
blue: '0x1d99f3'
|
|
||||||
magenta: '0x9b59b6'
|
|
||||||
cyan: '0x1abc9c'
|
|
||||||
white: '0xfcfcfc'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x7f8c8d'
|
|
||||||
red: '0xc0392b'
|
|
||||||
green: '0x1cdc9a'
|
|
||||||
yellow: '0xfdbc4b'
|
|
||||||
blue: '0x3daee9'
|
|
||||||
magenta: '0x8e44ad'
|
|
||||||
cyan: '0x16a085'
|
|
||||||
white: '0xffffff'
|
|
||||||
|
|
||||||
# Dim colors
|
|
||||||
dim:
|
|
||||||
black: '0x31363b'
|
|
||||||
red: '0x783228'
|
|
||||||
green: '0x17a262'
|
|
||||||
yellow: '0xb65619'
|
|
||||||
blue: '0x1b668f'
|
|
||||||
magenta: '0x614a73'
|
|
||||||
cyan: '0x186c60'
|
|
||||||
white: '0x63686d'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Campbell (Windows 10 default)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x0c0c0c'
|
|
||||||
foreground: '0xcccccc'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x0c0c0c'
|
|
||||||
red: '0xc50f1f'
|
|
||||||
green: '0x13a10e'
|
|
||||||
yellow: '0xc19c00'
|
|
||||||
blue: '0x0037da'
|
|
||||||
magenta: '0x881798'
|
|
||||||
cyan: '0x3a96dd'
|
|
||||||
white: '0xcccccc'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x767676'
|
|
||||||
red: '0xe74856'
|
|
||||||
green: '0x16c60c'
|
|
||||||
yellow: '0xf9f1a5'
|
|
||||||
blue: '0x3b78ff'
|
|
||||||
magenta: '0xb4009e'
|
|
||||||
cyan: '0x61d6d6'
|
|
||||||
white: '0xf2f2f2'
|
|
||||||
@ -1,31 +0,0 @@
|
|||||||
# Colors (Challenger Deep)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1e1c31'
|
|
||||||
foreground: '0xcbe1e7'
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: '0xff271d'
|
|
||||||
cursor: '0xfbfcfc'
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x141228'
|
|
||||||
red: '0xff5458'
|
|
||||||
green: '0x62d196'
|
|
||||||
yellow: '0xffb378'
|
|
||||||
blue: '0x65b2ff'
|
|
||||||
magenta: '0x906cff'
|
|
||||||
cyan: '0x63f2f1'
|
|
||||||
white: '0xa6b3cc'
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x565575'
|
|
||||||
red: '0xff8080'
|
|
||||||
green: '0x95ffa4'
|
|
||||||
yellow: '0xffe9aa'
|
|
||||||
blue: '0x91ddff'
|
|
||||||
magenta: '0xc991e1'
|
|
||||||
cyan: '0xaaffe4'
|
|
||||||
white: '0xcbe3e7'
|
|
||||||
|
|
||||||
@ -1,34 +0,0 @@
|
|||||||
# Cyber Punk Neon
|
|
||||||
# Source: https://github.com/Roboron3042/Cyberpunk-Neon
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: "0x000b1e"
|
|
||||||
foreground: "0x0abdc6"
|
|
||||||
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: "0x000b1e"
|
|
||||||
cursor: "0x0abdc6"
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: "0x123e7c"
|
|
||||||
red: "0xff0000"
|
|
||||||
green: "0xd300c4"
|
|
||||||
yellow: "0xf57800"
|
|
||||||
blue: "0x123e7c"
|
|
||||||
magenta: "0x711c91"
|
|
||||||
cyan: "0x0abdc6"
|
|
||||||
white: "0xd7d7d5"
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: "0x1c61c2"
|
|
||||||
red: "0xff0000"
|
|
||||||
green: "0xd300c4"
|
|
||||||
yellow: "0xf57800"
|
|
||||||
blue: "0x00ff00"
|
|
||||||
magenta: "0x711c91"
|
|
||||||
cyan: "0x0abdc6"
|
|
||||||
white: "0xd7d7d5"
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Dracula)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x282a36'
|
|
||||||
foreground: '0xf8f8f2'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xff5555'
|
|
||||||
green: '0x50fa7b'
|
|
||||||
yellow: '0xf1fa8c'
|
|
||||||
blue: '0xcaa9fa'
|
|
||||||
magenta: '0xff79c6'
|
|
||||||
cyan: '0x8be9fd'
|
|
||||||
white: '0xbfbfbf'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x282a35'
|
|
||||||
red: '0xff6e67'
|
|
||||||
green: '0x5af78e'
|
|
||||||
yellow: '0xf4f99d'
|
|
||||||
blue: '0xcaa9fa'
|
|
||||||
magenta: '0xff92d0'
|
|
||||||
cyan: '0x9aedfe'
|
|
||||||
white: '0xe6e6e6'
|
|
||||||
@ -1,29 +0,0 @@
|
|||||||
|
|
||||||
# Colors (Konsole's Dark Pastels)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x2C2C2C'
|
|
||||||
foreground: '0xDCDCCC'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x3F3F3F'
|
|
||||||
red: '0x705050'
|
|
||||||
green: '0x60B48A'
|
|
||||||
yellow: '0xDFAF8F'
|
|
||||||
blue: '0x9AB8D7'
|
|
||||||
magenta: '0xDC8CC3'
|
|
||||||
cyan: '0x8CD0D3'
|
|
||||||
white: '0xDCDCCC'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x709080'
|
|
||||||
red: '0xDCA3A3'
|
|
||||||
green: '0x72D5A3'
|
|
||||||
yellow: '0xF0DFAF'
|
|
||||||
blue: '0x94BFF3'
|
|
||||||
magenta: '0xEC93D3'
|
|
||||||
cyan: '0x93E0E3'
|
|
||||||
white: '0xFFFFFF'
|
|
||||||
@ -1,17 +0,0 @@
|
|||||||
# Colors (Doom One)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x282c34'
|
|
||||||
foreground: '0xbbc2cf'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x282c34'
|
|
||||||
red: '0xff6c6b'
|
|
||||||
green: '0x98be65'
|
|
||||||
yellow: '0xecbe7b'
|
|
||||||
blue: '0x51afef'
|
|
||||||
magenta: '0xc678dd'
|
|
||||||
cyan: '0x46d9ff'
|
|
||||||
white: '0xbbc2cf'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Dracula)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x282a36'
|
|
||||||
foreground: '0xf8f8f2'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xff5555'
|
|
||||||
green: '0x50fa7b'
|
|
||||||
yellow: '0xf1fa8c'
|
|
||||||
blue: '0xbd93f9'
|
|
||||||
magenta: '0xff79c6'
|
|
||||||
cyan: '0x8be9fd'
|
|
||||||
white: '0xbbbbbb'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x555555'
|
|
||||||
red: '0xff5555'
|
|
||||||
green: '0x50fa7b'
|
|
||||||
yellow: '0xf1fa8c'
|
|
||||||
blue: '0xcaa9fa'
|
|
||||||
magenta: '0xff79c6'
|
|
||||||
cyan: '0x8be9fd'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,34 +0,0 @@
|
|||||||
# falcon colorscheme for alacritty
|
|
||||||
# by fenetikm, https://github.com/fenetikm/falcon
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x020221'
|
|
||||||
foreground: '0xb4b4b9'
|
|
||||||
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: '0x020221'
|
|
||||||
cursor: '0xffe8c0'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000004'
|
|
||||||
red: '0xff3600'
|
|
||||||
green: '0x718e3f'
|
|
||||||
yellow: '0xffc552'
|
|
||||||
blue: '0x635196'
|
|
||||||
magenta: '0xff761a'
|
|
||||||
cyan: '0x34bfa4'
|
|
||||||
white: '0xb4b4b9'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x020221'
|
|
||||||
red: '0xff8e78'
|
|
||||||
green: '0xb1bf75'
|
|
||||||
yellow: '0xffd392'
|
|
||||||
blue: '0x99a4bc'
|
|
||||||
magenta: '0xffb07b'
|
|
||||||
cyan: '0x8bccbf'
|
|
||||||
white: '0xf8f8ff'
|
|
||||||
@ -1,25 +0,0 @@
|
|||||||
colors:
|
|
||||||
primary:
|
|
||||||
background: '0x272a34'
|
|
||||||
foreground: '0xFFFFFF'
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x1F2229'
|
|
||||||
red: '0xEC0101'
|
|
||||||
green: '0x47D4B9'
|
|
||||||
yellow: '0xFF8A18'
|
|
||||||
blue: '0x277FFF'
|
|
||||||
magenta: '0xD71655'
|
|
||||||
cyan: '0x05A1F7'
|
|
||||||
white: '0xFFFFFF'
|
|
||||||
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0x1F2229'
|
|
||||||
red: '0xD41919'
|
|
||||||
green: '0x5EBDAB'
|
|
||||||
yellow: '0xFEA44C'
|
|
||||||
blue: '0x367bf0'
|
|
||||||
magenta: '0xBF2E5D'
|
|
||||||
cyan: '0x49AEE6'
|
|
||||||
white: '0xFFFFFF'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Gotham)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x0a0f14'
|
|
||||||
foreground: '0x98d1ce'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x0a0f14'
|
|
||||||
red: '0xc33027'
|
|
||||||
green: '0x26a98b'
|
|
||||||
yellow: '0xedb54b'
|
|
||||||
blue: '0x195465'
|
|
||||||
magenta: '0x4e5165'
|
|
||||||
cyan: '0x33859d'
|
|
||||||
white: '0x98d1ce'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x10151b'
|
|
||||||
red: '0xd26939'
|
|
||||||
green: '0x081f2d'
|
|
||||||
yellow: '0x245361'
|
|
||||||
blue: '0x093748'
|
|
||||||
magenta: '0x888ba5'
|
|
||||||
cyan: '0x599caa'
|
|
||||||
white: '0xd3ebe9'
|
|
||||||
@ -1,30 +0,0 @@
|
|||||||
# Colors (Gruvbox dark)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
# hard contrast: background = '0x1d2021'
|
|
||||||
background: '0x282828'
|
|
||||||
# soft contrast: background = '0x32302f'
|
|
||||||
foreground: '0xebdbb2'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x282828'
|
|
||||||
red: '0xcc241d'
|
|
||||||
green: '0x98971a'
|
|
||||||
yellow: '0xd79921'
|
|
||||||
blue: '0x458588'
|
|
||||||
magenta: '0xb16286'
|
|
||||||
cyan: '0x689d6a'
|
|
||||||
white: '0xa89984'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x928374'
|
|
||||||
red: '0xfb4934'
|
|
||||||
green: '0xb8bb26'
|
|
||||||
yellow: '0xfabd2f'
|
|
||||||
blue: '0x83a598'
|
|
||||||
magenta: '0xd3869b'
|
|
||||||
cyan: '0x8ec07c'
|
|
||||||
white: '0xebdbb2'
|
|
||||||
@ -1,30 +0,0 @@
|
|||||||
# Colors (Gruvbox light)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
# hard contrast: background = '0xf9f5d7'
|
|
||||||
background: '0xfbf1c7'
|
|
||||||
# soft contrast: background = '0xf2e5bc'
|
|
||||||
foreground: '0x3c3836'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0xfbf1c7'
|
|
||||||
red: '0xcc241d'
|
|
||||||
green: '0x98971a'
|
|
||||||
yellow: '0xd79921'
|
|
||||||
blue: '0x458588'
|
|
||||||
magenta: '0xb16286'
|
|
||||||
cyan: '0x689d6a'
|
|
||||||
white: '0x7c6f64'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x928374'
|
|
||||||
red: '0x9d0006'
|
|
||||||
green: '0x79740e'
|
|
||||||
yellow: '0xb57614'
|
|
||||||
blue: '0x076678'
|
|
||||||
magenta: '0x8f3f71'
|
|
||||||
cyan: '0x427b58'
|
|
||||||
white: '0x3c3836'
|
|
||||||
@ -1,26 +0,0 @@
|
|||||||
# Colors (Gruvbox Material Dark Medium)
|
|
||||||
colors:
|
|
||||||
primary:
|
|
||||||
background: '0x282828'
|
|
||||||
foreground: '0xdfbf8e'
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x665c54'
|
|
||||||
red: '0xea6962'
|
|
||||||
green: '0xa9b665'
|
|
||||||
yellow: '0xe78a4e'
|
|
||||||
blue: '0x7daea3'
|
|
||||||
magenta: '0xd3869b'
|
|
||||||
cyan: '0x89b482'
|
|
||||||
white: '0xdfbf8e'
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0x928374'
|
|
||||||
red: '0xea6962'
|
|
||||||
green: '0xa9b665'
|
|
||||||
yellow: '0xe3a84e'
|
|
||||||
blue: '0x7daea3'
|
|
||||||
magenta: '0xd3869b'
|
|
||||||
cyan: '0x89b482'
|
|
||||||
white: '0xdfbf8e'
|
|
||||||
|
|
||||||
@ -1,33 +0,0 @@
|
|||||||
# Colors (High Contrast)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x444444'
|
|
||||||
foreground: '0xdddddd'
|
|
||||||
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: '0xaaaaaa'
|
|
||||||
cursor: '0xffffff'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xff0000'
|
|
||||||
green: '0x00ff00'
|
|
||||||
yellow: '0xffff00'
|
|
||||||
blue: '0x0000ff'
|
|
||||||
magenta: '0xff00ff'
|
|
||||||
cyan: '0x00ffff'
|
|
||||||
white: '0xffffff'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xff0000'
|
|
||||||
green: '0x00ff00'
|
|
||||||
yellow: '0xffff00'
|
|
||||||
blue: '0x0000ff'
|
|
||||||
magenta: '0xff00ff'
|
|
||||||
cyan: '0x00ffff'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Horizon Dark)
|
|
||||||
colors:
|
|
||||||
# Primary colors
|
|
||||||
primary:
|
|
||||||
background: '0x1c1e26'
|
|
||||||
foreground: '0xe0e0e0'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x16161c'
|
|
||||||
red: '0xe95678'
|
|
||||||
green: '0x29d398'
|
|
||||||
yellow: '0xfab795'
|
|
||||||
blue: '0x26bbd9'
|
|
||||||
magenta: '0xee64ac'
|
|
||||||
cyan: '0x59e1e3'
|
|
||||||
white: '0xd5d8da'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x5b5858'
|
|
||||||
red: '0xec6a88'
|
|
||||||
green: '0x3fdaa4'
|
|
||||||
yellow: '0xfbc3a7'
|
|
||||||
blue: '0x3fc4de'
|
|
||||||
magenta: '0xf075b5'
|
|
||||||
cyan: '0x6be4e6'
|
|
||||||
white: '0xd5d8da'
|
|
||||||
@ -1,31 +0,0 @@
|
|||||||
# Colors (Hyper)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x000000'
|
|
||||||
foreground: '0xffffff'
|
|
||||||
cursor:
|
|
||||||
text: '0xF81CE5'
|
|
||||||
cursor: '0xffffff'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xfe0100'
|
|
||||||
green: '0x33ff00'
|
|
||||||
yellow: '0xfeff00'
|
|
||||||
blue: '0x0066ff'
|
|
||||||
magenta: '0xcc00ff'
|
|
||||||
cyan: '0x00ffff'
|
|
||||||
white: '0xd0d0d0'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x808080'
|
|
||||||
red: '0xfe0100'
|
|
||||||
green: '0x33ff00'
|
|
||||||
yellow: '0xfeff00'
|
|
||||||
blue: '0x0066ff'
|
|
||||||
magenta: '0xcc00ff'
|
|
||||||
cyan: '0x00ffff'
|
|
||||||
white: '0xFFFFFF'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (iTerm 2 default theme)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x101421'
|
|
||||||
foreground: '0xfffbf6'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x2e2e2e'
|
|
||||||
red: '0xeb4129'
|
|
||||||
green: '0xabe047'
|
|
||||||
yellow: '0xf6c744'
|
|
||||||
blue: '0x47a0f3'
|
|
||||||
magenta: '0x7b5cb0'
|
|
||||||
cyan: '0x64dbed'
|
|
||||||
white: '0xe5e9f0'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x565656'
|
|
||||||
red: '0xec5357'
|
|
||||||
green: '0xc0e17d'
|
|
||||||
yellow: '0xf9da6a'
|
|
||||||
blue: '0x49a4f8'
|
|
||||||
magenta: '0xa47de9'
|
|
||||||
cyan: '0x99faf2'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,34 +0,0 @@
|
|||||||
# Colors (Kanagawa Dragon)
|
|
||||||
# Source: https://github.com/rebelot/kanagawa.nvim
|
|
||||||
colors:
|
|
||||||
primary:
|
|
||||||
background: '0x181616'
|
|
||||||
foreground: '0xc5c9c5'
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x0d0c0c'
|
|
||||||
blue: '0x8ba4b0'
|
|
||||||
cyan: '0x8ea4a2'
|
|
||||||
green: '0x8a9a7b'
|
|
||||||
magenta: '0xa292a3'
|
|
||||||
red: '0xc4746e'
|
|
||||||
white: '0xC8C093'
|
|
||||||
yellow: '0xc4b28a'
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0xa6a69c'
|
|
||||||
blue: '0x7FB4CA'
|
|
||||||
cyan: '0x7AA89F'
|
|
||||||
green: '0x87a987'
|
|
||||||
magenta: '0x938AA9'
|
|
||||||
red: '0xE46876'
|
|
||||||
white: '0xc5c9c5'
|
|
||||||
yellow: '0xE6C384'
|
|
||||||
|
|
||||||
selection:
|
|
||||||
background: '0x2d4f67'
|
|
||||||
foreground: '0xc8c093'
|
|
||||||
|
|
||||||
indexed_colors:
|
|
||||||
- { index: 16, color: '0xffa066' }
|
|
||||||
- { index: 17, color: '0xff5d62' }
|
|
||||||
@ -1,34 +0,0 @@
|
|||||||
# Colors (Kanagawa Wave)
|
|
||||||
# Source: https://github.com/rebelot/kanagawa.nvim
|
|
||||||
colors:
|
|
||||||
primary:
|
|
||||||
background: '0x1f1f28'
|
|
||||||
foreground: '0xdcd7ba'
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x090618'
|
|
||||||
red: '0xc34043'
|
|
||||||
green: '0x76946a'
|
|
||||||
yellow: '0xc0a36e'
|
|
||||||
blue: '0x7e9cd8'
|
|
||||||
magenta: '0x957fb8'
|
|
||||||
cyan: '0x6a9589'
|
|
||||||
white: '0xc8c093'
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0x727169'
|
|
||||||
red: '0xe82424'
|
|
||||||
green: '0x98bb6c'
|
|
||||||
yellow: '0xe6c384'
|
|
||||||
blue: '0x7fb4ca'
|
|
||||||
magenta: '0x938aa9'
|
|
||||||
cyan: '0x7aa89f'
|
|
||||||
white: '0xdcd7ba'
|
|
||||||
|
|
||||||
selection:
|
|
||||||
background: '0x2d4f67'
|
|
||||||
foreground: '0xc8c093'
|
|
||||||
|
|
||||||
indexed_colors:
|
|
||||||
- { index: 16, color: '0xffa066' }
|
|
||||||
- { index: 17, color: '0xff5d62' }
|
|
||||||
@ -1,51 +0,0 @@
|
|||||||
# Color theme ported from Konsole: Linux colors
|
|
||||||
colors:
|
|
||||||
primary:
|
|
||||||
foreground: '0xe3e3e3'
|
|
||||||
bright_foreground: '0xffffff'
|
|
||||||
dim_foreground: '0xe3e3e3'
|
|
||||||
background: '0x1f1f1f'
|
|
||||||
bright_background: '0x686868' # not sure
|
|
||||||
dim_background: '0x1f1f1f' # not sure
|
|
||||||
|
|
||||||
cursor:
|
|
||||||
text: '0x191622'
|
|
||||||
cursor: '0xf8f8f2'
|
|
||||||
|
|
||||||
search:
|
|
||||||
matches:
|
|
||||||
foreground: '0xb2b2b2'
|
|
||||||
background: '0xb26818'
|
|
||||||
focused_match:
|
|
||||||
foreground: CellBackground
|
|
||||||
background: CellForeground
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xb21818'
|
|
||||||
green: '0x18b218'
|
|
||||||
yellow: '0xb26818'
|
|
||||||
blue: '0x1818b2'
|
|
||||||
magenta: '0xb218b2'
|
|
||||||
cyan: '0x18b2b2'
|
|
||||||
white: '0xb2b2b2'
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0x686868'
|
|
||||||
red: '0xff5454'
|
|
||||||
green: '0x54ff54'
|
|
||||||
yellow: '0xffff54'
|
|
||||||
blue: '0x5454ff'
|
|
||||||
magenta: '0xff54ff'
|
|
||||||
cyan: '0x54ffff'
|
|
||||||
white: '0xffffff'
|
|
||||||
|
|
||||||
dim:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xb21818'
|
|
||||||
green: '0x18b218'
|
|
||||||
yellow: '0xb26818'
|
|
||||||
blue: '0x1818b2'
|
|
||||||
magenta: '0xb218b2'
|
|
||||||
cyan: '0x18b2b2'
|
|
||||||
white: '0xb2b2b2'
|
|
||||||
@ -1,33 +0,0 @@
|
|||||||
# Colors (Dim)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x333333'
|
|
||||||
foreground: '0xdddddd'
|
|
||||||
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: '0xaaaaaa'
|
|
||||||
cursor: '0xffffff'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xbb0000'
|
|
||||||
green: '0x00bb00'
|
|
||||||
yellow: '0xbbbb00'
|
|
||||||
blue: '0x0000bb'
|
|
||||||
magenta: '0xbb00bb'
|
|
||||||
cyan: '0x00bbbb'
|
|
||||||
white: '0xbbbbbb'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xbb0000'
|
|
||||||
green: '0x00bb00'
|
|
||||||
yellow: '0xbbbb00'
|
|
||||||
blue: '0x0000bb'
|
|
||||||
magenta: '0xbb00bb'
|
|
||||||
cyan: '0x00bbbb'
|
|
||||||
white: '0xbbbbbb'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Material Theme)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1e282d'
|
|
||||||
foreground: '0xc4c7d1'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x666666'
|
|
||||||
red: '0xeb606b'
|
|
||||||
green: '0xc3e88d'
|
|
||||||
yellow: '0xf7eb95'
|
|
||||||
blue: '0x80cbc4'
|
|
||||||
magenta: '0xff2f90'
|
|
||||||
cyan: '0xaeddff'
|
|
||||||
white: '0xffffff'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0xff262b'
|
|
||||||
red: '0xeb606b'
|
|
||||||
green: '0xc3e88d'
|
|
||||||
yellow: '0xf7eb95'
|
|
||||||
blue: '0x7dc6bf'
|
|
||||||
magenta: '0x6c71c4'
|
|
||||||
cyan: '0x35434d'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Material Theme)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1e282d'
|
|
||||||
foreground: '0xc4c7d1'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x666666'
|
|
||||||
red: '0xeb606b'
|
|
||||||
green: '0xc3e88d'
|
|
||||||
yellow: '0xf7eb95'
|
|
||||||
blue: '0x80cbc4'
|
|
||||||
magenta: '0xff2f90'
|
|
||||||
cyan: '0xaeddff'
|
|
||||||
white: '0xffffff'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0xa1a1a1'
|
|
||||||
red: '0xeb606b'
|
|
||||||
green: '0xc3e88d'
|
|
||||||
yellow: '0xf7eb95'
|
|
||||||
blue: '0x7dc6bf'
|
|
||||||
magenta: '0x6c71c4'
|
|
||||||
cyan: '0x35434d'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,27 +0,0 @@
|
|||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x2D2A2E'
|
|
||||||
foreground: '0xfff1f3'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x2c2525'
|
|
||||||
red: '0xfd6883'
|
|
||||||
green: '0xadda78'
|
|
||||||
yellow: '0xf9cc6c'
|
|
||||||
blue: '0xf38d70'
|
|
||||||
magenta: '0xa8a9eb'
|
|
||||||
cyan: '0x85dacc'
|
|
||||||
white: '0xfff1f3'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x72696a'
|
|
||||||
red: '0xfd6883'
|
|
||||||
green: '0xadda78'
|
|
||||||
yellow: '0xf9cc6c'
|
|
||||||
blue: '0xf38d70'
|
|
||||||
magenta: '0xa8a9eb'
|
|
||||||
cyan: '0x85dacc'
|
|
||||||
white: '0xfff1f3'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
colors:
|
|
||||||
primary:
|
|
||||||
background: '0x1e2030'
|
|
||||||
foreground: '0x7f85a3'
|
|
||||||
|
|
||||||
cursor:
|
|
||||||
text: '0x7f85a3'
|
|
||||||
cursor: '0x808080'
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x444a73'
|
|
||||||
red: '0xff5370'
|
|
||||||
green: '0x4fd6be'
|
|
||||||
yellow: '0xffc777'
|
|
||||||
blue: '0x3e68d7'
|
|
||||||
magenta: '0xfc7b7b'
|
|
||||||
cyan: '0x86e1fc'
|
|
||||||
white: '0xd0d0d0'
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0x828bb8'
|
|
||||||
red: '0xff98a4'
|
|
||||||
green: '0xc3e88d'
|
|
||||||
yellow: '0xffc777'
|
|
||||||
blue: '0x82aaff'
|
|
||||||
magenta: '0xff966c'
|
|
||||||
cyan: '0xb4f9f8'
|
|
||||||
white: '0x5f8787'
|
|
||||||
@ -1,29 +0,0 @@
|
|||||||
# Colors (Night Owlish Light)
|
|
||||||
colors:
|
|
||||||
bright:
|
|
||||||
black: '#7a8181'
|
|
||||||
blue: '#5ca7e4'
|
|
||||||
cyan: '#00c990'
|
|
||||||
green: '#49d0c5'
|
|
||||||
magenta: '#697098'
|
|
||||||
red: '#f76e6e'
|
|
||||||
white: '#989fb1'
|
|
||||||
yellow: '#dac26b'
|
|
||||||
cursor:
|
|
||||||
cursor: '#403f53'
|
|
||||||
text: '#fbfbfb'
|
|
||||||
normal:
|
|
||||||
black: '#011627'
|
|
||||||
blue: '#4876d6'
|
|
||||||
cyan: '#08916a'
|
|
||||||
green: '#2aa298'
|
|
||||||
magenta: '#403f53'
|
|
||||||
red: '#d3423e'
|
|
||||||
white: '#7a8181'
|
|
||||||
yellow: '#daaa01'
|
|
||||||
primary:
|
|
||||||
background: '#ffffff'
|
|
||||||
foreground: '#403f53'
|
|
||||||
selection:
|
|
||||||
background: '#f2f2f2'
|
|
||||||
text: '#403f53'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Nord)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x2E3440'
|
|
||||||
foreground: '0xD8DEE9'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x3B4252'
|
|
||||||
red: '0xBF616A'
|
|
||||||
green: '0xA3BE8C'
|
|
||||||
yellow: '0xEBCB8B'
|
|
||||||
blue: '0x81A1C1'
|
|
||||||
magenta: '0xB48EAD'
|
|
||||||
cyan: '0x88C0D0'
|
|
||||||
white: '0xE5E9F0'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x4C566A'
|
|
||||||
red: '0xBF616A'
|
|
||||||
green: '0xA3BE8C'
|
|
||||||
yellow: '0xEBCB8B'
|
|
||||||
blue: '0x81A1C1'
|
|
||||||
magenta: '0xB48EAD'
|
|
||||||
cyan: '0x8FBCBB'
|
|
||||||
white: '0xECEFF4'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Oceanic Next)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1b2b34'
|
|
||||||
foreground: '0xd8dee9'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x29414f'
|
|
||||||
red: '0xec5f67'
|
|
||||||
green: '0x99c794'
|
|
||||||
yellow: '0xfac863'
|
|
||||||
blue: '0x6699cc'
|
|
||||||
magenta: '0xc594c5'
|
|
||||||
cyan: '0x5fb3b3'
|
|
||||||
white: '0x65737e'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x405860'
|
|
||||||
red: '0xec5f67'
|
|
||||||
green: '0x99c794'
|
|
||||||
yellow: '0xfac863'
|
|
||||||
blue: '0x6699cc'
|
|
||||||
magenta: '0xc594c5'
|
|
||||||
cyan: '0x5fb3b3'
|
|
||||||
white: '0xadb5c0'
|
|
||||||
@ -1,38 +0,0 @@
|
|||||||
colors:
|
|
||||||
primary:
|
|
||||||
background: '0x191622'
|
|
||||||
foreground: '0xe1e1e6'
|
|
||||||
|
|
||||||
cursor:
|
|
||||||
text: '0x191622'
|
|
||||||
cursor: '0xf8f8f2'
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xff5555'
|
|
||||||
green: '0x50fa7b'
|
|
||||||
yellow: '0xeffa78'
|
|
||||||
blue: '0xbd93f9'
|
|
||||||
magenta: '0xff79c6'
|
|
||||||
cyan: '0x8d79ba'
|
|
||||||
white: '0xbfbfbf'
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0x4d4d4d'
|
|
||||||
red: '0xff6e67'
|
|
||||||
green: '0x5af78e'
|
|
||||||
yellow: '0xeaf08d'
|
|
||||||
blue: '0xcaa9fa'
|
|
||||||
magenta: '0xff92d0'
|
|
||||||
cyan: '0xaa91e3'
|
|
||||||
white: '0xe6e6e6'
|
|
||||||
|
|
||||||
dim:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xa90000'
|
|
||||||
green: '0x049f2b'
|
|
||||||
yellow: '0xa3b106'
|
|
||||||
blue: '0x530aba'
|
|
||||||
magenta: '0xbb006b'
|
|
||||||
cyan: '0x433364'
|
|
||||||
white: '0x5f5f5f'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (One Dark)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1e2127'
|
|
||||||
foreground: '0xabb2bf'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x1e2127'
|
|
||||||
red: '0xe06c75'
|
|
||||||
green: '0x98c379'
|
|
||||||
yellow: '0xd19a66'
|
|
||||||
blue: '0x61afef'
|
|
||||||
magenta: '0xc678dd'
|
|
||||||
cyan: '0x56b6c2'
|
|
||||||
white: '0xabb2bf'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x5c6370'
|
|
||||||
red: '0xe06c75'
|
|
||||||
green: '0x98c379'
|
|
||||||
yellow: '0xd19a66'
|
|
||||||
blue: '0x61afef'
|
|
||||||
magenta: '0xc678dd'
|
|
||||||
cyan: '0x56b6c2'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,30 +0,0 @@
|
|||||||
# iTerm2 Material Design - Palenight theme for Alacritty
|
|
||||||
# Source : https://github.com/JonathanSpeek/palenight-iterm2
|
|
||||||
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x292d3e'
|
|
||||||
foreground: '0xd0d0d0'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x292d3e'
|
|
||||||
red: '0xf07178'
|
|
||||||
green: '0xc3e88d'
|
|
||||||
yellow: '0xffcb6b'
|
|
||||||
blue: '0x82aaff'
|
|
||||||
magenta: '0xc792ea'
|
|
||||||
cyan: '0x89ddff'
|
|
||||||
white: '0xd0d0d0'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x434758'
|
|
||||||
red: '0xff8b92'
|
|
||||||
green: '0xddffa7'
|
|
||||||
yellow: '0xffe585'
|
|
||||||
blue: '0x9cc4ff'
|
|
||||||
magenta: '0xe1acff'
|
|
||||||
cyan: '0xa3f7ff'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,32 +0,0 @@
|
|||||||
# Colors (PaperColor - Dark)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1c1c1c'
|
|
||||||
foreground: '0x808080'
|
|
||||||
|
|
||||||
cursor:
|
|
||||||
text: '0x1c1c1c'
|
|
||||||
cursor: '0x808080'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x1c1c1c'
|
|
||||||
red: '0xaf005f'
|
|
||||||
green: '0x5faf00'
|
|
||||||
yellow: '0xd7af5f'
|
|
||||||
blue: '0x5fafd7'
|
|
||||||
magenta: '0x808080'
|
|
||||||
cyan: '0xd7875f'
|
|
||||||
white: '0xd0d0d0'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x585858'
|
|
||||||
red: '0x5faf5f'
|
|
||||||
green: '0xafd700'
|
|
||||||
yellow: '0xaf87d7'
|
|
||||||
blue: '0xffaf00'
|
|
||||||
magenta: '0xffaf00'
|
|
||||||
cyan: '0x00afaf'
|
|
||||||
white: '0x5f8787'
|
|
||||||
@ -1,32 +0,0 @@
|
|||||||
# Colors (PaperColor - Light)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0xeeeeee'
|
|
||||||
foreground: '0x878787'
|
|
||||||
|
|
||||||
cursor:
|
|
||||||
text: '0xeeeeee'
|
|
||||||
cursor: '0x878787'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0xeeeeee'
|
|
||||||
red: '0xaf0000'
|
|
||||||
green: '0x008700'
|
|
||||||
yellow: '0x5f8700'
|
|
||||||
blue: '0x0087af'
|
|
||||||
magenta: '0x878787'
|
|
||||||
cyan: '0x005f87'
|
|
||||||
white: '0x444444'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0xbcbcbc'
|
|
||||||
red: '0xd70000'
|
|
||||||
green: '0xd70087'
|
|
||||||
yellow: '0x8700af'
|
|
||||||
blue: '0xd75f00'
|
|
||||||
magenta: '0xd75f00'
|
|
||||||
cyan: '0x005faf'
|
|
||||||
white: '0x005f87'
|
|
||||||
@ -1,26 +0,0 @@
|
|||||||
# Colors (Pencil Dark)
|
|
||||||
colors:
|
|
||||||
# Default Colors
|
|
||||||
primary:
|
|
||||||
background: '0x212121'
|
|
||||||
foreground: '0xf1f1f1'
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x212121'
|
|
||||||
red: '0xc30771'
|
|
||||||
green: '0x10a778'
|
|
||||||
yellow: '0xa89c14'
|
|
||||||
blue: '0x008ec4'
|
|
||||||
magenta: '0x523c79'
|
|
||||||
cyan: '0x20a5ba'
|
|
||||||
white: '0xe0e0e0'
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x818181'
|
|
||||||
red: '0xfb007a'
|
|
||||||
green: '0x5fd7af'
|
|
||||||
yellow: '0xf3e430'
|
|
||||||
blue: '0x20bbfc'
|
|
||||||
magenta: '0x6855de'
|
|
||||||
cyan: '0x4fb8cc'
|
|
||||||
white: '0xf1f1f1'
|
|
||||||
@ -1,26 +0,0 @@
|
|||||||
# Colors (Pencil Light)
|
|
||||||
colors:
|
|
||||||
# Default Colors
|
|
||||||
primary:
|
|
||||||
background: '0xf1f1f1'
|
|
||||||
foreground: '0x424242'
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x212121'
|
|
||||||
red: '0xc30771'
|
|
||||||
green: '0x10a778'
|
|
||||||
yellow: '0xa89c14'
|
|
||||||
blue: '0x008ec4'
|
|
||||||
magenta: '0x523c79'
|
|
||||||
cyan: '0x20a5ba'
|
|
||||||
white: '0xe0e0e0'
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x212121'
|
|
||||||
red: '0xfb007a'
|
|
||||||
green: '0x5fd7af'
|
|
||||||
yellow: '0xf3e430'
|
|
||||||
blue: '0x20bbfc'
|
|
||||||
magenta: '0x6855de'
|
|
||||||
cyan: '0x4fb8cc'
|
|
||||||
white: '0xf1f1f1'
|
|
||||||
@ -1,38 +0,0 @@
|
|||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x2c2b2a'
|
|
||||||
foreground: '0xf9e7c4'
|
|
||||||
|
|
||||||
dim_foreground: '0x685E4A'
|
|
||||||
bright_foreground: '0x1C1508'
|
|
||||||
dim_background: '0x202322'
|
|
||||||
bright_background: '0x353433'
|
|
||||||
|
|
||||||
# Cursor colors
|
|
||||||
cursor:
|
|
||||||
text: '0xf9e7c4'
|
|
||||||
cursor: '0xf9e7c4'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x282a2e'
|
|
||||||
blue: '0x5f819d'
|
|
||||||
cyan: '0x5e8d87'
|
|
||||||
green: '0x8c9440'
|
|
||||||
magenta: '0x85678f'
|
|
||||||
orange: '0xcc6953'
|
|
||||||
red: '0xa54242'
|
|
||||||
white: '0x707880'
|
|
||||||
yellow: '0xde935f'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x373b41'
|
|
||||||
blue: '0x81a2be'
|
|
||||||
cyan: '0x8abeb7'
|
|
||||||
green: '0xb5bd68'
|
|
||||||
magenta: '0xb294bb'
|
|
||||||
red: '0xcc6666'
|
|
||||||
white: '0xc5c8c6'
|
|
||||||
yellow: '0xf0c674'
|
|
||||||
@ -1,38 +0,0 @@
|
|||||||
# Colors (SeaShells)
|
|
||||||
# Source : https://raw.githubusercontent.com/mbadolato/iTerm2-Color-Schemes/master/schemes/SeaShells.itermcolors
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '#061923'
|
|
||||||
foreground: '#e5c49e'
|
|
||||||
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: '#061822'
|
|
||||||
cursor: '#feaf3c'
|
|
||||||
|
|
||||||
selection:
|
|
||||||
text: '#ffe9d7'
|
|
||||||
background: '#265b75'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '#1d485f'
|
|
||||||
red: '#db662d'
|
|
||||||
green: '#008eab'
|
|
||||||
yellow: '#feaf3c'
|
|
||||||
blue: '#255a62'
|
|
||||||
magenta: '#77dbf4'
|
|
||||||
cyan: '#5fb1c2'
|
|
||||||
white: '#e5c49e'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '#545d65'
|
|
||||||
red: '#dd998a'
|
|
||||||
green: '#739da8'
|
|
||||||
yellow: '#fedaae'
|
|
||||||
blue: '#0bc7e3'
|
|
||||||
magenta: '#c6e8f1'
|
|
||||||
cyan: '#97b9c0'
|
|
||||||
white: '#ffe9d7'
|
|
||||||
@ -1,30 +0,0 @@
|
|||||||
# Color theme ported from iTerm 2: Smoooooth
|
|
||||||
|
|
||||||
colors:
|
|
||||||
primary:
|
|
||||||
foreground: '0xdbdbdb'
|
|
||||||
background: '0x14191e'
|
|
||||||
cursor:
|
|
||||||
text: '0x000000'
|
|
||||||
cursor: '0xfefffe'
|
|
||||||
selection:
|
|
||||||
text: '0x000000'
|
|
||||||
background: '0xb3d7ff'
|
|
||||||
normal:
|
|
||||||
black: '0x14191e'
|
|
||||||
red: '0xb43c29'
|
|
||||||
green: '0x00c200'
|
|
||||||
yellow: '0xc7c400'
|
|
||||||
blue: '0x2743c7'
|
|
||||||
magenta: '0xbf3fbd'
|
|
||||||
cyan: '0x00c5c7'
|
|
||||||
white: '0xc7c7c7'
|
|
||||||
bright:
|
|
||||||
black: '0x676767'
|
|
||||||
red: '0xdc7974'
|
|
||||||
green: '0x57e690'
|
|
||||||
yellow: '0xece100'
|
|
||||||
blue: '0xa6aaf1'
|
|
||||||
magenta: '0xe07de0'
|
|
||||||
cyan: '0x5ffdff'
|
|
||||||
white: '0xfeffff'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Snazzy)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x282a36'
|
|
||||||
foreground: '0xeff0eb'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x282a36'
|
|
||||||
red: '0xff5c57'
|
|
||||||
green: '0x5af78e'
|
|
||||||
yellow: '0xf3f99d'
|
|
||||||
blue: '0x57c7ff'
|
|
||||||
magenta: '0xff6ac1'
|
|
||||||
cyan: '0x9aedfe'
|
|
||||||
white: '0xf1f1f0'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x686868'
|
|
||||||
red: '0xff5c57'
|
|
||||||
green: '0x5af78e'
|
|
||||||
yellow: '0xf3f99d'
|
|
||||||
blue: '0x57c7ff'
|
|
||||||
magenta: '0xff6ac1'
|
|
||||||
cyan: '0x9aedfe'
|
|
||||||
white: '0xf1f1f0'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Solarized Dark)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x002b36'
|
|
||||||
foreground: '0x839496'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x073642'
|
|
||||||
red: '0xdc322f'
|
|
||||||
green: '0x859900'
|
|
||||||
yellow: '0xb58900'
|
|
||||||
blue: '0x268bd2'
|
|
||||||
magenta: '0xd33682'
|
|
||||||
cyan: '0x2aa198'
|
|
||||||
white: '0xeee8d5'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x002b36'
|
|
||||||
red: '0xcb4b16'
|
|
||||||
green: '0x586e75'
|
|
||||||
yellow: '0x657b83'
|
|
||||||
blue: '0x839496'
|
|
||||||
magenta: '0x6c71c4'
|
|
||||||
cyan: '0x93a1a1'
|
|
||||||
white: '0xfdf6e3'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Solarized Light)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0xfdf6e3'
|
|
||||||
foreground: '0x586e75'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x073642'
|
|
||||||
red: '0xdc322f'
|
|
||||||
green: '0x859900'
|
|
||||||
yellow: '0xb58900'
|
|
||||||
blue: '0x268bd2'
|
|
||||||
magenta: '0xd33682'
|
|
||||||
cyan: '0x2aa198'
|
|
||||||
white: '0xeee8d5'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x002b36'
|
|
||||||
red: '0xcb4b16'
|
|
||||||
green: '0x586e75'
|
|
||||||
yellow: '0x657b83'
|
|
||||||
blue: '0x839496'
|
|
||||||
magenta: '0x6c71c4'
|
|
||||||
cyan: '0x93a1a1'
|
|
||||||
white: '0xfdf6e3'
|
|
||||||
@ -1,31 +0,0 @@
|
|||||||
# Colors (Taerminal)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x26282a'
|
|
||||||
foreground: '0xf0f0f0'
|
|
||||||
cursor:
|
|
||||||
background: '0xf0f0f0'
|
|
||||||
foreground: '0x26282a'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x26282a'
|
|
||||||
red: '0xff8878'
|
|
||||||
green: '0xb4fb73'
|
|
||||||
yellow: '0xfffcb7'
|
|
||||||
blue: '0x8bbce5'
|
|
||||||
magenta: '0xffb2fe'
|
|
||||||
cyan: '0xa2e1f8'
|
|
||||||
white: '0xf1f1f1'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x6f6f6f'
|
|
||||||
red: '0xfe978b'
|
|
||||||
green: '0xd6fcba'
|
|
||||||
yellow: '0xfffed5'
|
|
||||||
blue: '0xc2e3ff'
|
|
||||||
magenta: '0xffc6ff'
|
|
||||||
cyan: '0xc0e9f8'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,26 +0,0 @@
|
|||||||
# GNOME Terminal Tango Dark
|
|
||||||
colors:
|
|
||||||
primary:
|
|
||||||
background: '0x2e3436'
|
|
||||||
foreground: '0xd3d7cf'
|
|
||||||
|
|
||||||
normal:
|
|
||||||
black: '0x2e3436'
|
|
||||||
red: '0xcc0000'
|
|
||||||
green: '0x4e9a06'
|
|
||||||
yellow: '0xc4a000'
|
|
||||||
blue: '0x3465a4'
|
|
||||||
magenta: '0x75507b'
|
|
||||||
cyan: '0x06989a'
|
|
||||||
white: '0xd3d7cf'
|
|
||||||
|
|
||||||
bright:
|
|
||||||
black: '0x555753'
|
|
||||||
red: '0xef2929'
|
|
||||||
green: '0x8ae234'
|
|
||||||
yellow: '0xfce94f'
|
|
||||||
blue: '0x729fcf'
|
|
||||||
magenta: '0xad7fa8'
|
|
||||||
cyan: '0x34e2e2'
|
|
||||||
white: '0xeeeeec'
|
|
||||||
|
|
||||||
@ -1,27 +0,0 @@
|
|||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x282828'
|
|
||||||
foreground: '0xeeeeee'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x282828'
|
|
||||||
red: '0xf43753'
|
|
||||||
green: '0xc9d05c'
|
|
||||||
yellow: '0xffc24b'
|
|
||||||
blue: '0xb3deef'
|
|
||||||
magenta: '0xd3b987'
|
|
||||||
cyan: '0x73cef4'
|
|
||||||
white: '0xeeeeee'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x4c4c4c'
|
|
||||||
red: '0xf43753'
|
|
||||||
green: '0xc9d05c'
|
|
||||||
yellow: '0xffc24b'
|
|
||||||
blue: '0xb3deef'
|
|
||||||
magenta: '0xd3b987'
|
|
||||||
cyan: '0x73cef4'
|
|
||||||
white: '0xfeffff'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Terminal.app)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x000000'
|
|
||||||
foreground: '0xb6b6b6'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0x990000'
|
|
||||||
green: '0x00a600'
|
|
||||||
yellow: '0x999900'
|
|
||||||
blue: '0x0000b2'
|
|
||||||
magenta: '0xb200b2'
|
|
||||||
cyan: '0x00a6b2'
|
|
||||||
white: '0xbfbfbf'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x666666'
|
|
||||||
red: '0xe50000'
|
|
||||||
green: '0x00d900'
|
|
||||||
yellow: '0xe5e500'
|
|
||||||
blue: '0x0000ff'
|
|
||||||
magenta: '0xe500e5'
|
|
||||||
cyan: '0x00e5e5'
|
|
||||||
white: '0xe5e5e5'
|
|
||||||
@ -1,27 +0,0 @@
|
|||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1D1F28'
|
|
||||||
foreground: '0xFDFDFD'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
# Bright colors
|
|
||||||
black: '0x282A36'
|
|
||||||
red: '0xF37F97'
|
|
||||||
green: '0x5ADECD'
|
|
||||||
yellow: '0xF2A272'
|
|
||||||
blue: '0x8897F4'
|
|
||||||
magenta: '0xC574DD'
|
|
||||||
cyan: '0x79E6F3'
|
|
||||||
white: '0xFDFDFD'
|
|
||||||
bright:
|
|
||||||
black: '0x414458'
|
|
||||||
red: '0xFF4971'
|
|
||||||
green: '0x18E3C8'
|
|
||||||
yellow: '0xEBCB8B'
|
|
||||||
blue: '0xFF8037'
|
|
||||||
magenta: '0x556FFF'
|
|
||||||
cyan: '0x3FDCEE'
|
|
||||||
white: '0xBEBEC1'
|
|
||||||
indexed_colors: []
|
|
||||||
@ -1,29 +0,0 @@
|
|||||||
# Colors (Tokyo Night: Storm variant)
|
|
||||||
# Source: https://github.com/zatchheems/tokyo-night-alacritty-theme
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x24283b'
|
|
||||||
foreground: '0xa9b1d6'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x32344a'
|
|
||||||
red: '0xf7768e'
|
|
||||||
green: '0x9ece6a'
|
|
||||||
yellow: '0xe0af68'
|
|
||||||
blue: '0x7aa2f7'
|
|
||||||
magenta: '0xad8ee6'
|
|
||||||
cyan: '0x449dab'
|
|
||||||
white: '0x9699a8'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x444b6a'
|
|
||||||
red: '0xff7a93'
|
|
||||||
green: '0xb9f27c'
|
|
||||||
yellow: '0xff9e64'
|
|
||||||
blue: '0x7da6ff'
|
|
||||||
magenta: '0xbb9af7'
|
|
||||||
cyan: '0x0db9d7'
|
|
||||||
white: '0xacb0d0'
|
|
||||||
@ -1,29 +0,0 @@
|
|||||||
# Colors (Tokyo Night)
|
|
||||||
# Source: https://github.com/zatchheems/tokyo-night-alacritty-theme
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1a1b26'
|
|
||||||
foreground: '0xa9b1d6'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x32344a'
|
|
||||||
red: '0xf7768e'
|
|
||||||
green: '0x9ece6a'
|
|
||||||
yellow: '0xe0af68'
|
|
||||||
blue: '0x7aa2f7'
|
|
||||||
magenta: '0xad8ee6'
|
|
||||||
cyan: '0x449dab'
|
|
||||||
white: '0x787c99'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x444b6a'
|
|
||||||
red: '0xff7a93'
|
|
||||||
green: '0xb9f27c'
|
|
||||||
yellow: '0xff9e64'
|
|
||||||
blue: '0x7da6ff'
|
|
||||||
magenta: '0xbb9af7'
|
|
||||||
cyan: '0x0db9d7'
|
|
||||||
white: '0xacb0d0'
|
|
||||||
@ -1,33 +0,0 @@
|
|||||||
# Colors (Tomorrow Night)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1d1f21'
|
|
||||||
foreground: '0xc5c8c6'
|
|
||||||
|
|
||||||
# Colors the cursor will use if `custom_cursor_colors` is true
|
|
||||||
cursor:
|
|
||||||
text: '0x1d1f21'
|
|
||||||
cursor: '0xffffff'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x1d1f21'
|
|
||||||
red: '0xcc6666'
|
|
||||||
green: '0xb5bd68'
|
|
||||||
yellow: '0xe6c547'
|
|
||||||
blue: '0x81a2be'
|
|
||||||
magenta: '0xb294bb'
|
|
||||||
cyan: '0x70c0ba'
|
|
||||||
white: '0x373b41'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x666666'
|
|
||||||
red: '0xff3334'
|
|
||||||
green: '0x9ec400'
|
|
||||||
yellow: '0xf0c674'
|
|
||||||
blue: '0x81a2be'
|
|
||||||
magenta: '0xb77ee0'
|
|
||||||
cyan: '0x54ced6'
|
|
||||||
white: '0x282a2e'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Tomorrow Night Bright)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x000000'
|
|
||||||
foreground: '0xeaeaea'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xd54e53'
|
|
||||||
green: '0xb9ca4a'
|
|
||||||
yellow: '0xe6c547'
|
|
||||||
blue: '0x7aa6da'
|
|
||||||
magenta: '0xc397d8'
|
|
||||||
cyan: '0x70c0ba'
|
|
||||||
white: '0x424242'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x666666'
|
|
||||||
red: '0xff3334'
|
|
||||||
green: '0x9ec400'
|
|
||||||
yellow: '0xe7c547'
|
|
||||||
blue: '0x7aa6da'
|
|
||||||
magenta: '0xb77ee0'
|
|
||||||
cyan: '0x54ced6'
|
|
||||||
white: '0x2a2a2a'
|
|
||||||
@ -1,28 +0,0 @@
|
|||||||
# Colors (Wombat)
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x1f1f1f'
|
|
||||||
foreground: '0xe5e1d8'
|
|
||||||
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xf7786d'
|
|
||||||
green: '0xbde97c'
|
|
||||||
yellow: '0xefdfac'
|
|
||||||
blue: '0x6ebaf8'
|
|
||||||
magenta: '0xef88ff'
|
|
||||||
cyan: '0x90fdf8'
|
|
||||||
white: '0xe5e1d8'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0xb4b4b4'
|
|
||||||
red: '0xf99f92'
|
|
||||||
green: '0xe3f7a1'
|
|
||||||
yellow: '0xf2e9bf'
|
|
||||||
blue: '0xb3d2ff'
|
|
||||||
magenta: '0xe5bdff'
|
|
||||||
cyan: '0xc2fefa'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,27 +0,0 @@
|
|||||||
# XTerm's default colors
|
|
||||||
colors:
|
|
||||||
# Default colors
|
|
||||||
primary:
|
|
||||||
background: '0x000000'
|
|
||||||
foreground: '0xffffff'
|
|
||||||
# Normal colors
|
|
||||||
normal:
|
|
||||||
black: '0x000000'
|
|
||||||
red: '0xcd0000'
|
|
||||||
green: '0x00cd00'
|
|
||||||
yellow: '0xcdcd00'
|
|
||||||
blue: '0x0000ee'
|
|
||||||
magenta: '0xcd00cd'
|
|
||||||
cyan: '0x00cdcd'
|
|
||||||
white: '0xe5e5e5'
|
|
||||||
|
|
||||||
# Bright colors
|
|
||||||
bright:
|
|
||||||
black: '0x7f7f7f'
|
|
||||||
red: '0xff0000'
|
|
||||||
green: '0x00ff00'
|
|
||||||
yellow: '0xffff00'
|
|
||||||
blue: '0x5c5cff'
|
|
||||||
magenta: '0xff00ff'
|
|
||||||
cyan: '0x00ffff'
|
|
||||||
white: '0xffffff'
|
|
||||||
@ -1,464 +0,0 @@
|
|||||||
-- If LuaRocks is installed, make sure that packages installed through it are
|
|
||||||
-- found (e.g. lgi). If LuaRocks is not installed, do nothing.
|
|
||||||
pcall(require, "luarocks.loader")
|
|
||||||
|
|
||||||
-- Standard awesome library
|
|
||||||
local gears = require("gears")
|
|
||||||
local awful = require("awful")
|
|
||||||
require("awful.autofocus")
|
|
||||||
-- Widget and layout library
|
|
||||||
local wibox = require("wibox")
|
|
||||||
-- Theme handling library
|
|
||||||
local beautiful = require("beautiful")
|
|
||||||
-- Notification library
|
|
||||||
local naughty = require("naughty")
|
|
||||||
local hotkeys_popup = require("awful.hotkeys_popup")
|
|
||||||
-- Enable hotkeys help widget for VIM and other apps
|
|
||||||
-- when client with a matching name is opened:
|
|
||||||
require("awful.hotkeys_popup.keys")
|
|
||||||
|
|
||||||
-- {{{ Error handling
|
|
||||||
-- Check if awesome encountered an error during startup and fell back to
|
|
||||||
-- another config (This code will only ever execute for the fallback config)
|
|
||||||
if awesome.startup_errors then
|
|
||||||
naughty.notify({
|
|
||||||
preset = naughty.config.presets.critical,
|
|
||||||
title = "Oops, there were errors during startup!",
|
|
||||||
text = awesome.startup_errors,
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Handle runtime errors after startup
|
|
||||||
do
|
|
||||||
local in_error = false
|
|
||||||
awesome.connect_signal("debug::error", function(err)
|
|
||||||
-- Make sure we don't go into an endless error loop
|
|
||||||
if in_error then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
in_error = true
|
|
||||||
|
|
||||||
naughty.notify({
|
|
||||||
preset = naughty.config.presets.critical,
|
|
||||||
title = "Oops, an error happened!",
|
|
||||||
text = tostring(err),
|
|
||||||
})
|
|
||||||
in_error = false
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
-- }}}
|
|
||||||
|
|
||||||
-- {{{ Variable definitions
|
|
||||||
-- Themes define colours, icons, font and wallpapers.
|
|
||||||
beautiful.init(gears.filesystem.get_themes_dir() .. "default/theme.lua")
|
|
||||||
|
|
||||||
-- This is used later as the default terminal and editor to run.
|
|
||||||
browser = "librewolf"
|
|
||||||
terminal = "alacritty"
|
|
||||||
editor = os.getenv("nvim") or "nvim"
|
|
||||||
editor_cmd = terminal .. " -e " .. editor
|
|
||||||
|
|
||||||
modkey = "Mod4"
|
|
||||||
|
|
||||||
awful.layout.layouts = {
|
|
||||||
awful.layout.suit.tile,
|
|
||||||
}
|
|
||||||
|
|
||||||
local taglist_buttons = gears.table.join(
|
|
||||||
awful.button({}, 1, function(t)
|
|
||||||
t:view_only()
|
|
||||||
end),
|
|
||||||
awful.button({ modkey }, 1, function(t)
|
|
||||||
if client.focus then
|
|
||||||
client.focus:move_to_tag(t)
|
|
||||||
end
|
|
||||||
end),
|
|
||||||
awful.button({}, 3, awful.tag.viewtoggle),
|
|
||||||
awful.button({ modkey }, 3, function(t)
|
|
||||||
if client.focus then
|
|
||||||
client.focus:toggle_tag(t)
|
|
||||||
end
|
|
||||||
end),
|
|
||||||
awful.button({}, 4, function(t)
|
|
||||||
awful.tag.viewnext(t.screen)
|
|
||||||
end),
|
|
||||||
awful.button({}, 5, function(t)
|
|
||||||
awful.tag.viewprev(t.screen)
|
|
||||||
end)
|
|
||||||
)
|
|
||||||
|
|
||||||
local tasklist_buttons = gears.table.join(
|
|
||||||
awful.button({}, 1, function(c)
|
|
||||||
if c == client.focus then
|
|
||||||
c.minimized = true
|
|
||||||
else
|
|
||||||
c:emit_signal("request::activate", "tasklist", { raise = true })
|
|
||||||
end
|
|
||||||
end),
|
|
||||||
awful.button({}, 3, function()
|
|
||||||
awful.menu.client_list({ theme = { width = 250 } })
|
|
||||||
end),
|
|
||||||
awful.button({}, 4, function()
|
|
||||||
awful.client.focus.byidx(1)
|
|
||||||
end),
|
|
||||||
awful.button({}, 5, function()
|
|
||||||
awful.client.focus.byidx(-1)
|
|
||||||
end)
|
|
||||||
)
|
|
||||||
|
|
||||||
local function set_wallpaper(s)
|
|
||||||
-- Wallpaper
|
|
||||||
if beautiful.wallpaper then
|
|
||||||
local wallpaper = beautiful.wallpaper
|
|
||||||
-- If wallpaper is a function, call it with the screen
|
|
||||||
if type(wallpaper) == "function" then
|
|
||||||
wallpaper = wallpaper(s)
|
|
||||||
end
|
|
||||||
gears.wallpaper.maximized(wallpaper, s, true)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Re-set wallpaper when a screen's geometry changes (e.g. different resolution)
|
|
||||||
screen.connect_signal("property::geometry", set_wallpaper)
|
|
||||||
|
|
||||||
awful.screen.connect_for_each_screen(function(s)
|
|
||||||
awful.tag({ "1", "2", "3", "4", "5", "6", "7", "8", "9" }, s, awful.layout.layouts[1])
|
|
||||||
end)
|
|
||||||
|
|
||||||
-- {{{ Mouse bindings
|
|
||||||
root.buttons(gears.table.join(
|
|
||||||
-- awful.button({}, 3, function()
|
|
||||||
-- mymainmenu:toggle()
|
|
||||||
-- end),
|
|
||||||
awful.button({}, 4, awful.tag.viewnext),
|
|
||||||
awful.button({}, 5, awful.tag.viewprev)
|
|
||||||
))
|
|
||||||
-- }}}
|
|
||||||
|
|
||||||
-- {{{ Key bindings
|
|
||||||
globalkeys = gears.table.join(
|
|
||||||
awful.key({ modkey }, "s", hotkeys_popup.show_help, { description = "show help", group = "awesome" }),
|
|
||||||
-- awful.key({ modkey }, "Left", awful.tag.viewprev, { description = "view previous", group = "tag" }),
|
|
||||||
-- awful.key({ modkey }, "Right", awful.tag.viewnext, { description = "view next", group = "tag" }),
|
|
||||||
awful.key({ modkey }, "Escape", awful.tag.history.restore, { description = "go back", group = "tag" }),
|
|
||||||
awful.key({ modkey }, "l", function()
|
|
||||||
awful.client.focus.byidx(1)
|
|
||||||
end, { description = "focus next by index", group = "client" }),
|
|
||||||
awful.key({ modkey }, "h", function()
|
|
||||||
awful.client.focus.byidx(-1)
|
|
||||||
end, { description = "focus previous by index", group = "client" }),
|
|
||||||
awful.key({ modkey }, "w", function()
|
|
||||||
mymainmenu:show()
|
|
||||||
end, { description = "show main menu", group = "awesome" }),
|
|
||||||
|
|
||||||
-- Layout manipulation
|
|
||||||
awful.key({ modkey, "Shift" }, "h", function()
|
|
||||||
awful.client.swap.byidx(1)
|
|
||||||
end, { description = "swap with next client by index", group = "client" }),
|
|
||||||
awful.key({ modkey, "Shift" }, "l", function()
|
|
||||||
awful.client.swap.byidx(-1)
|
|
||||||
end, { description = "swap with previous client by index", group = "client" }),
|
|
||||||
awful.key({ modkey }, "k", function()
|
|
||||||
awful.screen.focus_relative(1)
|
|
||||||
end, { description = "focus the next screen", group = "screen" }),
|
|
||||||
awful.key({ modkey }, "j", function()
|
|
||||||
awful.screen.focus_relative(-1)
|
|
||||||
end, { description = "focus the previous screen", group = "screen" }),
|
|
||||||
awful.key({ modkey }, "u", awful.client.urgent.jumpto, { description = "jump to urgent client", group = "client" }),
|
|
||||||
awful.key({ modkey }, "Tab", function()
|
|
||||||
awful.client.focus.history.previous()
|
|
||||||
if client.focus then
|
|
||||||
client.focus:raise()
|
|
||||||
end
|
|
||||||
end, { description = "go back", group = "client" }),
|
|
||||||
|
|
||||||
-- Standard program
|
|
||||||
awful.key({ modkey, "Shift" }, "r", awesome.restart, { description = "reload awesome", group = "awesome" }),
|
|
||||||
awful.key({ modkey, "Shift" }, "e", awesome.quit, { description = "quit awesome", group = "awesome" }),
|
|
||||||
awful.key({ modkey }, "y", function()
|
|
||||||
awful.tag.incmwfact(0.05)
|
|
||||||
end, { description = "increase master width factor", group = "layout" }),
|
|
||||||
awful.key({ modkey }, "o", function()
|
|
||||||
awful.tag.incmwfact(-0.05)
|
|
||||||
end, { description = "decrease master width factor", group = "layout" }),
|
|
||||||
|
|
||||||
-- launch dmenu
|
|
||||||
awful.key({ modkey }, "d", function()
|
|
||||||
awful.util.spawn("dmenu_run")
|
|
||||||
end, { description = "dmenu", group = "launcher" }),
|
|
||||||
|
|
||||||
-- launch browser
|
|
||||||
awful.key({ modkey }, "b", function()
|
|
||||||
awful.util.spawn(browser)
|
|
||||||
end, { description = "launch browser", group = "launcher" }),
|
|
||||||
|
|
||||||
-- launch terminal
|
|
||||||
awful.key({ modkey }, "Return", function()
|
|
||||||
awful.spawn(terminal)
|
|
||||||
end, { description = "open a terminal", group = "launcher" }),
|
|
||||||
|
|
||||||
-- launch ncmpcpp
|
|
||||||
awful.key({ modkey }, "m", function()
|
|
||||||
awful.spawn.with_shell(terminal .. " -e ncmpcpp")
|
|
||||||
end, { description = "open ncmpcpp", group = "launcher" }),
|
|
||||||
|
|
||||||
-- music player daemon controls
|
|
||||||
awful.key({}, "XF86AudioPlay", function()
|
|
||||||
awful.spawn("playerctl play-pause")
|
|
||||||
end, { description = "toggle play", group = "launcher" }),
|
|
||||||
awful.key({}, "XF86AudioPause", function()
|
|
||||||
awful.spawn.with_shell("playerctl play-pause")
|
|
||||||
end, { description = "toggle play", group = "launcher" }),
|
|
||||||
awful.key({}, "XF86AudioNext", function()
|
|
||||||
awful.spawn.with_shell("playerctl next")
|
|
||||||
end, { description = "next", group = "launcher" }),
|
|
||||||
awful.key({}, "XF86AudioPrev", function()
|
|
||||||
awful.spawn.with_shell("playerctl previous")
|
|
||||||
end, { description = "previous", group = "launcher" }),
|
|
||||||
awful.key({ modkey, "Shift" }, "bracketleft", function()
|
|
||||||
awful.spawn.with_shell("playerctl -p mpd volume 0.05-")
|
|
||||||
end, { description = "decrease volume", group = "launcher" }),
|
|
||||||
awful.key({ modkey, "Shift" }, "bracketright", function()
|
|
||||||
awful.spawn.with_shell("playerctl -p mpd volume 0.05+")
|
|
||||||
end, { description = "increase volume", group = "launcher" }),
|
|
||||||
-- media hotkeys
|
|
||||||
awful.key({}, "XF86AudioRaiseVolume", function()
|
|
||||||
awful.spawn("pactl set-sink-volume @DEFAULT_SINK@ +10%")
|
|
||||||
end, { description = "raise volume", group = "launcher" }),
|
|
||||||
awful.key({}, "XF86AudioLowerVolume", function()
|
|
||||||
awful.spawn("pactl set-sink-volume @DEFAULT_SINK@ -10%")
|
|
||||||
end, { description = "lower volume", group = "launcher" }),
|
|
||||||
awful.key({}, "XF86AudioMute", function()
|
|
||||||
awful.spawn("pactl set-sink-mute @DEFAULT_SINK@ toggle")
|
|
||||||
end, { description = "toggle mute", group = "launcher" }),
|
|
||||||
|
|
||||||
-- toggle picom
|
|
||||||
awful.key({ modkey }, "c", function()
|
|
||||||
awful.spawn.with_shell("~/.config/awesome/scripts/toggle_picom.sh")
|
|
||||||
end, { description = "toggle picom", group = "launcher" }),
|
|
||||||
|
|
||||||
-- make screenshot
|
|
||||||
awful.key({ modkey }, "Print", function()
|
|
||||||
awful.spawn.with_shell("flameshot gui")
|
|
||||||
end, { description = "flameshot", group = "launcher" }),
|
|
||||||
|
|
||||||
-- logout
|
|
||||||
awful.key({ modkey, "Shift" }, "BackSpace", function()
|
|
||||||
awful.spawn.with_shell("$HOME/.config/awesome/scripts/logout_script.sh")
|
|
||||||
end, { description = "logout", group = "launcher" })
|
|
||||||
)
|
|
||||||
|
|
||||||
clientkeys = gears.table.join(
|
|
||||||
awful.key({ modkey }, "f", function(c)
|
|
||||||
c.fullscreen = not c.fullscreen
|
|
||||||
c:raise()
|
|
||||||
end, { description = "toggle fullscreen", group = "client" }),
|
|
||||||
awful.key({ modkey, "Shift" }, "q", function(c)
|
|
||||||
c:kill()
|
|
||||||
end, { description = "close", group = "client" }),
|
|
||||||
awful.key(
|
|
||||||
{ modkey, "Shift" },
|
|
||||||
"space",
|
|
||||||
awful.client.floating.toggle,
|
|
||||||
{ description = "toggle floating", group = "client" }
|
|
||||||
),
|
|
||||||
awful.key({ modkey }, "space", function(c)
|
|
||||||
c:swap(awful.client.getmaster())
|
|
||||||
end, { description = "move to master", group = "client" }),
|
|
||||||
awful.key({ modkey }, "p", function(c)
|
|
||||||
c:move_to_screen()
|
|
||||||
end, { description = "move to screen", group = "client" }),
|
|
||||||
awful.key({ modkey }, "t", function(c)
|
|
||||||
c.ontop = not c.ontop
|
|
||||||
end, { description = "toggle keep on top", group = "client" })
|
|
||||||
)
|
|
||||||
|
|
||||||
-- Bind all key numbers to tags.
|
|
||||||
-- Be careful: we use keycodes to make it work on any keyboard layout.
|
|
||||||
-- This should map on the top row of your keyboard, usually 1 to 9.
|
|
||||||
for i = 1, 9 do
|
|
||||||
globalkeys = gears.table.join(
|
|
||||||
globalkeys,
|
|
||||||
-- View tag only.
|
|
||||||
awful.key({ modkey }, "#" .. i + 9, function()
|
|
||||||
local screen = awful.screen.focused()
|
|
||||||
local tag = screen.tags[i]
|
|
||||||
if tag then
|
|
||||||
tag:view_only()
|
|
||||||
end
|
|
||||||
end, { description = "view tag #" .. i, group = "tag" }),
|
|
||||||
-- Toggle tag display.
|
|
||||||
awful.key({ modkey, "Control" }, "#" .. i + 9, function()
|
|
||||||
local screen = awful.screen.focused()
|
|
||||||
local tag = screen.tags[i]
|
|
||||||
if tag then
|
|
||||||
awful.tag.viewtoggle(tag)
|
|
||||||
end
|
|
||||||
end, { description = "toggle tag #" .. i, group = "tag" }),
|
|
||||||
-- Move client to tag.
|
|
||||||
awful.key({ modkey, "Shift" }, "#" .. i + 9, function()
|
|
||||||
if client.focus then
|
|
||||||
local tag = client.focus.screen.tags[i]
|
|
||||||
if tag then
|
|
||||||
client.focus:move_to_tag(tag)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end, { description = "move focused client to tag #" .. i, group = "tag" }),
|
|
||||||
-- Toggle tag on focused client.
|
|
||||||
awful.key({ modkey, "Control", "Shift" }, "#" .. i + 9, function()
|
|
||||||
if client.focus then
|
|
||||||
local tag = client.focus.screen.tags[i]
|
|
||||||
if tag then
|
|
||||||
client.focus:toggle_tag(tag)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end, { description = "toggle focused client on tag #" .. i, group = "tag" })
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
clientbuttons = gears.table.join(
|
|
||||||
awful.button({}, 1, function(c)
|
|
||||||
c:emit_signal("request::activate", "mouse_click", { raise = true })
|
|
||||||
end),
|
|
||||||
awful.button({ modkey }, 1, function(c)
|
|
||||||
c:emit_signal("request::activate", "mouse_click", { raise = true })
|
|
||||||
awful.mouse.client.move(c)
|
|
||||||
end),
|
|
||||||
awful.button({ modkey }, 3, function(c)
|
|
||||||
c:emit_signal("request::activate", "mouse_click", { raise = true })
|
|
||||||
awful.mouse.client.resize(c)
|
|
||||||
end)
|
|
||||||
)
|
|
||||||
|
|
||||||
-- Set keys
|
|
||||||
root.keys(globalkeys)
|
|
||||||
-- }}}
|
|
||||||
|
|
||||||
-- {{{ Rules
|
|
||||||
-- Rules to apply to new clients (through the "manage" signal).
|
|
||||||
awful.rules.rules = {
|
|
||||||
-- All clients will match this rule.
|
|
||||||
{
|
|
||||||
rule = {},
|
|
||||||
properties = {
|
|
||||||
border_width = beautiful.border_width,
|
|
||||||
border_color = beautiful.border_normal,
|
|
||||||
focus = awful.client.focus.filter,
|
|
||||||
raise = true,
|
|
||||||
keys = clientkeys,
|
|
||||||
buttons = clientbuttons,
|
|
||||||
screen = awful.screen.preferred,
|
|
||||||
placement = awful.placement.no_overlap + awful.placement.no_offscreen,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
rule = { instance = "polybar" },
|
|
||||||
properties = { border_width = false, focusable = false, below = true },
|
|
||||||
},
|
|
||||||
|
|
||||||
-- Floating clients.
|
|
||||||
{
|
|
||||||
rule_any = {
|
|
||||||
instance = {
|
|
||||||
"DTA", -- Firefox addon DownThemAll.
|
|
||||||
"copyq", -- Includes session name in class.
|
|
||||||
"pinentry",
|
|
||||||
},
|
|
||||||
class = {
|
|
||||||
"Arandr",
|
|
||||||
"Blueman-manager",
|
|
||||||
"Gpick",
|
|
||||||
"Kruler",
|
|
||||||
"MessageWin", -- kalarm.
|
|
||||||
"Sxiv",
|
|
||||||
"Tor Browser", -- Needs a fixed window size to avoid fingerprinting by screen size.
|
|
||||||
"Wpa_gui",
|
|
||||||
"veromix",
|
|
||||||
"xtightvncviewer",
|
|
||||||
},
|
|
||||||
-- Note that the name property shown in xprop might be set slightly after creation of the client
|
|
||||||
-- and the name shown there might not match defined rules here.
|
|
||||||
name = {
|
|
||||||
"Event Tester", -- xev.
|
|
||||||
},
|
|
||||||
role = {
|
|
||||||
"AlarmWindow", -- Thunderbird's calendar.
|
|
||||||
"ConfigManager", -- Thunderbird's about:config.
|
|
||||||
"pop-up", -- e.g. Google Chrome's (detached) Developer Tools.
|
|
||||||
},
|
|
||||||
},
|
|
||||||
properties = { floating = true },
|
|
||||||
},
|
|
||||||
|
|
||||||
-- Add titlebars to normal clients and dialogs
|
|
||||||
{ rule_any = { type = { "normal", "dialog" } }, properties = { titlebars_enabled = false } },
|
|
||||||
}
|
|
||||||
-- }}}
|
|
||||||
|
|
||||||
-- {{{ Signals
|
|
||||||
-- Signal function to execute when a new client appears.
|
|
||||||
client.connect_signal("manage", function(c)
|
|
||||||
-- Set the windows at the slave,
|
|
||||||
-- i.e. put it at the end of others instead of setting it master.
|
|
||||||
-- if not awesome.startup then awful.client.setslave(c) end
|
|
||||||
|
|
||||||
if awesome.startup and not c.size_hints.user_position and not c.size_hints.program_position then
|
|
||||||
-- Prevent clients from being unreachable after screen count changes.
|
|
||||||
awful.placement.no_offscreen(c)
|
|
||||||
end
|
|
||||||
end)
|
|
||||||
|
|
||||||
-- Enable sloppy focus, so that focus follows mouse.
|
|
||||||
client.connect_signal("mouse::enter", function(c)
|
|
||||||
c:emit_signal("request::activate", "mouse_enter", { raise = false })
|
|
||||||
end)
|
|
||||||
|
|
||||||
client.connect_signal("focus", function(c)
|
|
||||||
c.border_color = beautiful.border_focus
|
|
||||||
end)
|
|
||||||
client.connect_signal("unfocus", function(c)
|
|
||||||
c.border_color = beautiful.border_normal
|
|
||||||
end)
|
|
||||||
|
|
||||||
-- Gaps
|
|
||||||
beautiful.useless_gap = 10
|
|
||||||
|
|
||||||
client.connect_signal("property::minimized", function(c)
|
|
||||||
c.minimized = false
|
|
||||||
end)
|
|
||||||
|
|
||||||
-- client.connect_signal("property::maximized", function(c)
|
|
||||||
-- c.shape = function(cr, w, h)
|
|
||||||
-- gears.shape.rounded_rect(cr, w, h, 0)
|
|
||||||
-- end
|
|
||||||
-- end)
|
|
||||||
|
|
||||||
-- rounded borders
|
|
||||||
client.connect_signal("manage", function(c)
|
|
||||||
if c.instance ~= "polybar" then
|
|
||||||
c.shape = function(cr, w, h)
|
|
||||||
gears.shape.rounded_rect(cr, w, h, 0)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end)
|
|
||||||
|
|
||||||
-- !!! somehow this breaks fullscreen !!!
|
|
||||||
-- floating on top always
|
|
||||||
-- client.connect_signal("property::floating", function(c)
|
|
||||||
-- if c.floating then
|
|
||||||
-- c.ontop = true
|
|
||||||
-- else
|
|
||||||
-- c.ontop = false
|
|
||||||
-- end
|
|
||||||
-- end)
|
|
||||||
|
|
||||||
-- Autostart
|
|
||||||
-- awful.spawn.with_shell("picom")
|
|
||||||
awful.spawn.with_shell("$HOME/.config/polybar/launch_polybar.sh")
|
|
||||||
awful.spawn.with_shell("~/.fehbg")
|
|
||||||
awful.spawn.with_shell("xinput set-prop 13 298 0, -1")
|
|
||||||
awful.spawn.with_shell("amixer -c 0 set Front unmute")
|
|
||||||
-- awful.spawn.with_shell("mpDris2")
|
|
||||||
-- awful.spawn.with_shell("dex -ae i3")
|
|
||||||
|
|
||||||
naughty.config.defaults.icon_size = 32
|
|
||||||
@ -1,15 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# a simple dmenu session script
|
|
||||||
#
|
|
||||||
###
|
|
||||||
|
|
||||||
DMENU='dmenu -i'
|
|
||||||
choice=$(echo -e "logout\nshutdown\nreboot\nsuspend\nhibernate" | $DMENU)
|
|
||||||
|
|
||||||
case "$choice" in
|
|
||||||
shutdown) shutdown -h now & ;;
|
|
||||||
reboot) shutdown -r now & ;;
|
|
||||||
suspend) systemctl suspend & ;;
|
|
||||||
hibernate) systemctl hibernate & ;;
|
|
||||||
esac
|
|
||||||
@ -1,5 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
pgrep picom>/dev/null &&
|
|
||||||
killall picom &>/dev/null ||
|
|
||||||
setsid picom --config ~/.config/picom/picom.conf & >/dev/null
|
|
||||||
@ -1,236 +0,0 @@
|
|||||||
exec-once = copyq --start-server
|
|
||||||
|
|
||||||
exec-once=waybar
|
|
||||||
exec-once=hyprpaper
|
|
||||||
exec-once=dunst
|
|
||||||
|
|
||||||
exec-once = hyprpm reload -n
|
|
||||||
|
|
||||||
monitor=HDMI-A-1,1920x1080@60,0x360,1
|
|
||||||
monitor=DP-2,2560x1440@144,1920x0,1,vrr,2
|
|
||||||
|
|
||||||
env = GDK_BACKEND,wayland,x11,*
|
|
||||||
# env = QT_QPA_PLATFORM,wayland,xcb,*
|
|
||||||
env = QT_WAYLAND_DISABLE_WINDOWDECORATION,1
|
|
||||||
|
|
||||||
debug {
|
|
||||||
disable_logs = false
|
|
||||||
}
|
|
||||||
|
|
||||||
# For all categories, see https://wiki.hyprland.org/Configuring/Variables/
|
|
||||||
input {
|
|
||||||
kb_layout = us,ru
|
|
||||||
kb_variant =
|
|
||||||
kb_model =
|
|
||||||
kb_options = grp:alt_shift_toggle, caps:escape
|
|
||||||
kb_rules =
|
|
||||||
|
|
||||||
accel_profile =
|
|
||||||
|
|
||||||
sensitivity = 1
|
|
||||||
follow_mouse = 1
|
|
||||||
mouse_refocus = true
|
|
||||||
|
|
||||||
repeat_rate = 35
|
|
||||||
repeat_delay = 500
|
|
||||||
|
|
||||||
sensitivity = 0 # -1.0 - 1.0, 0 means no modification.
|
|
||||||
force_no_accel = true
|
|
||||||
}
|
|
||||||
|
|
||||||
general {
|
|
||||||
gaps_in = 8
|
|
||||||
gaps_out = 20
|
|
||||||
border_size = 2
|
|
||||||
|
|
||||||
col.active_border = rgba(7e9cd8FF)
|
|
||||||
col.inactive_border = rgba(1f1f28FF)
|
|
||||||
|
|
||||||
layout = master
|
|
||||||
}
|
|
||||||
|
|
||||||
cursor {
|
|
||||||
inactive_timeout = 3
|
|
||||||
}
|
|
||||||
|
|
||||||
decoration {
|
|
||||||
# See https://wiki.hyprland.org/Configuring/Variables/ for more
|
|
||||||
|
|
||||||
# rounding = 10
|
|
||||||
rounding = 2
|
|
||||||
# drop_shadow = no
|
|
||||||
# shadow_range = 4
|
|
||||||
# shadow_render_power = 3
|
|
||||||
# col.shadow = rgba(1a1a1aee)
|
|
||||||
# inactive_opacity = 0.90
|
|
||||||
# active_opacity = 0.90
|
|
||||||
|
|
||||||
blur {
|
|
||||||
enabled = yes
|
|
||||||
size = 4
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
animations {
|
|
||||||
enabled = false
|
|
||||||
|
|
||||||
# Some default animations, see https://wiki.hyprland.org/Configuring/Animations/ for more
|
|
||||||
|
|
||||||
bezier = myBezier, 0.05, 0.9, 0.1, 1.05
|
|
||||||
|
|
||||||
animation = windows, 1, 4, myBezier, popin 70%
|
|
||||||
animation = windowsOut, 1, 4, default, popin 80%
|
|
||||||
animation = border, 0, 10, default
|
|
||||||
animation = borderangle, 0, 8, default
|
|
||||||
animation = fade, 0, 7, default
|
|
||||||
animation = workspaces, 0, 6, default
|
|
||||||
}
|
|
||||||
|
|
||||||
dwindle {
|
|
||||||
# See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more
|
|
||||||
pseudotile = yes # master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below
|
|
||||||
preserve_split = yes # you probably want this
|
|
||||||
}
|
|
||||||
|
|
||||||
master {
|
|
||||||
# See https://wiki.hyprland.org/Configuring/Master-Layout/ for more
|
|
||||||
new_status = master
|
|
||||||
new_on_top = true
|
|
||||||
mfact = 0.5
|
|
||||||
}
|
|
||||||
|
|
||||||
gestures {
|
|
||||||
# See https://wiki.hyprland.org/Configuring/Variables/ for more
|
|
||||||
workspace_swipe = off
|
|
||||||
}
|
|
||||||
|
|
||||||
misc {
|
|
||||||
vrr = 2
|
|
||||||
disable_hyprland_logo = true
|
|
||||||
# no_direct_scanout = false
|
|
||||||
}
|
|
||||||
|
|
||||||
# Example windowrule v1
|
|
||||||
# windowrule = float, ^(kitty)$
|
|
||||||
# Example windowrule v2
|
|
||||||
# windowrulev2 = float,class:^(kitty)$,title:^(kitty)$
|
|
||||||
# See https://wiki.hyprland.org/Configuring/Window-Rules/ for more
|
|
||||||
|
|
||||||
|
|
||||||
# See https://wiki.hyprland.org/Configuring/Keywords/ for more
|
|
||||||
$mainMod = SUPER
|
|
||||||
$terminal = alacritty
|
|
||||||
# Example binds, see https://wiki.hyprland.org/Configuring/Binds/ for more
|
|
||||||
#
|
|
||||||
bind = $mainMod_SHIFT, E, exit
|
|
||||||
bind = $mainMod_SHIFT, Q, killactive,
|
|
||||||
bind = $mainMod_SHIFT, SPACE, togglefloating,
|
|
||||||
|
|
||||||
bind = $mainMod, D, exec, tofi-drun | xargs hyprctl dispatch exec --
|
|
||||||
|
|
||||||
|
|
||||||
# Apps binds
|
|
||||||
bind = $mainMod, RETURN, exec, $terminal
|
|
||||||
bind = $mainMod, B, exec, librewolf
|
|
||||||
bind = $mainMod, M, exec, $terminal -e ncmpcpp
|
|
||||||
bind = $mainMod, E, exec, $terminal -e neomutt
|
|
||||||
bind = $mainMod, N, exec, $terminal -e newsboat
|
|
||||||
|
|
||||||
# screenshot area
|
|
||||||
bind = $mainMod_SHIFT, S, exec, grim -g "$(slurp)" - | wl-copy
|
|
||||||
|
|
||||||
# powermenu
|
|
||||||
bind = $mainMod_SHIFT, BackSpace, exec, ~/.config/tofi/powermenu.sh
|
|
||||||
|
|
||||||
# bind = $mainMod, P, pseudo, # dwindle
|
|
||||||
# bind = $mainMod, J, togglesplit, # dwindle
|
|
||||||
|
|
||||||
# Move focus with mainMod + arrow keys
|
|
||||||
# bind = $mainMod, L, movefocus, l
|
|
||||||
# bind = $mainMod, H, movefocus, r
|
|
||||||
# bind = $mainMod, up, movefocus, u
|
|
||||||
# bind = $mainMod, down, movefocus, d
|
|
||||||
#
|
|
||||||
bind = $mainMod, L, layoutmsg, cyclenext
|
|
||||||
bind = $mainMod, H, layoutmsg, cycleprev
|
|
||||||
|
|
||||||
bind = $mainMod, J, focusmonitor, -1
|
|
||||||
bind = $mainMod, K, focusmonitor, +1
|
|
||||||
|
|
||||||
bind = $mainMod, Y, splitratio, +0.1
|
|
||||||
bind = $mainMod, O, splitratio, -0.1
|
|
||||||
|
|
||||||
bind = $mainMod, P, movewindow, mon:-1
|
|
||||||
|
|
||||||
bind = $mainMod, SPACE, layoutmsg, swapwithmaster
|
|
||||||
|
|
||||||
bind = $mainMod, F, fullscreen, swapwithmaster
|
|
||||||
|
|
||||||
bind = $mainMod, MINUS, exec, pkill -SIGUSR1 waybar
|
|
||||||
# bindr = SUPER, H, exec, pkill -SIGUSR1 waybar
|
|
||||||
|
|
||||||
|
|
||||||
# volume controls
|
|
||||||
bind = ,XF86AudioPlay, exec, playerctl play-pause
|
|
||||||
bind = ,XF86AudioPause, exec, playerctl play-pause
|
|
||||||
bind = ,XF86AudioNext, exec, playerctl next
|
|
||||||
bind = ,XF86AudioPrev, exec, playerctl previous
|
|
||||||
|
|
||||||
bind = $mainMod_SHIFT, bracketleft, exec, playerctl -p mpd volume 0.05-
|
|
||||||
bind = $mainMod_SHIFT, bracketright, exec, playerctl -p mpd volume 0.05+
|
|
||||||
|
|
||||||
bind = $mainMod, PAGE_UP, pass, ^(discord)$
|
|
||||||
# bind = $mainMod, PAGE_UP, pass, ^(vencord)$
|
|
||||||
# bind = $mainMod, PAGE_UP, pass, ^(discord-screenaudio)$
|
|
||||||
|
|
||||||
bind = ,XF86AudioRaiseVolume, exec, pactl set-sink-volume @DEFAULT_SINK@ +5%
|
|
||||||
bind = ,XF86AudioLowerVolume, exec, pactl set-sink-volume @DEFAULT_SINK@ -5%
|
|
||||||
bind = ,XF86AudioMute, exec, pactl set-sink-mute @DEFAULT_SINK@ toggle
|
|
||||||
|
|
||||||
bind = ,XF86MonBrightnessDown, exec, ddcutil -d 2 setvcp 10 - 5
|
|
||||||
bind = ,XF86MonBrightnessUp, exec, ddcutil -d 2 setvcp 10 + 5
|
|
||||||
|
|
||||||
exec=sleep 5; amixer -c 0 set Front unmute
|
|
||||||
exec=sleep 5; amixer -c 1 set Front unmute
|
|
||||||
|
|
||||||
plugin {
|
|
||||||
split-monitor-workspaces {
|
|
||||||
count = 10
|
|
||||||
enable_persistent_workspaces = 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
# Switch workspaces with mainMod + [0-9]
|
|
||||||
bind = $mainMod, 1, split-workspace, 1
|
|
||||||
bind = $mainMod, 2, split-workspace, 2
|
|
||||||
bind = $mainMod, 3, split-workspace, 3
|
|
||||||
bind = $mainMod, 4, split-workspace, 4
|
|
||||||
bind = $mainMod, 5, split-workspace, 5
|
|
||||||
bind = $mainMod, 6, split-workspace, 6
|
|
||||||
bind = $mainMod, 7, split-workspace, 7
|
|
||||||
bind = $mainMod, 8, split-workspace, 8
|
|
||||||
bind = $mainMod, 9, split-workspace, 9
|
|
||||||
|
|
||||||
# Move active window to a workspace with mainMod + SHIFT + [0-9]
|
|
||||||
bind = $mainMod SHIFT, 1, split-movetoworkspacesilent, 1
|
|
||||||
bind = $mainMod SHIFT, 2, split-movetoworkspacesilent, 2
|
|
||||||
bind = $mainMod SHIFT, 3, split-movetoworkspacesilent, 3
|
|
||||||
bind = $mainMod SHIFT, 4, split-movetoworkspacesilent, 4
|
|
||||||
bind = $mainMod SHIFT, 5, split-movetoworkspacesilent, 5
|
|
||||||
bind = $mainMod SHIFT, 6, split-movetoworkspacesilent, 6
|
|
||||||
bind = $mainMod SHIFT, 7, split-movetoworkspacesilent, 7
|
|
||||||
bind = $mainMod SHIFT, 8, split-movetoworkspacesilent, 8
|
|
||||||
bind = $mainMod SHIFT, 9, split-movetoworkspacesilent, 9
|
|
||||||
|
|
||||||
|
|
||||||
# Scroll through existing workspaces with mainMod + scroll
|
|
||||||
bind = $mainMod, mouse_down, workspace, e+1
|
|
||||||
bind = $mainMod, mouse_up, workspace, e-1
|
|
||||||
|
|
||||||
# Move/resize windows with mainMod + LMB/RMB and dragging
|
|
||||||
bindm = $mainMod, mouse:272, movewindow
|
|
||||||
bindm = $mainMod, mouse:273, resizewindow
|
|
||||||
|
|
||||||
|
|
||||||
exec=sleep 10;xrandr --output DP-2 --primary
|
|
||||||
@ -1,5 +0,0 @@
|
|||||||
preload = ~/Pictures/wallpapers/nord-street.png
|
|
||||||
|
|
||||||
wallpaper = HDMI-A-1,~/Pictures/wallpapers/nord-street.png
|
|
||||||
wallpaper = DP-2,~/Pictures/wallpapers/nord-street.png
|
|
||||||
splash = false
|
|
||||||
@ -1,61 +0,0 @@
|
|||||||
$rosewaterAlpha = f5e0dc
|
|
||||||
$flamingoAlpha = f2cdcd
|
|
||||||
$pinkAlpha = f5c2e7
|
|
||||||
$mauveAlpha = cba6f7
|
|
||||||
$redAlpha = f38ba8
|
|
||||||
$maroonAlpha = eba0ac
|
|
||||||
$peachAlpha = fab387
|
|
||||||
$yellowAlpha = f9e2af
|
|
||||||
$greenAlpha = a6e3a1
|
|
||||||
$tealAlpha = 94e2d5
|
|
||||||
$skyAlpha = 89dceb
|
|
||||||
$sapphireAlpha = 74c7ec
|
|
||||||
$blueAlpha = 89b4fa
|
|
||||||
$lavenderAlpha = b4befe
|
|
||||||
|
|
||||||
$textAlpha = cdd6f4
|
|
||||||
$subtext1Alpha = bac2de
|
|
||||||
$subtext0Alpha = a6adc8
|
|
||||||
|
|
||||||
$overlay2Alpha = 9399b2
|
|
||||||
$overlay1Alpha = 7f849c
|
|
||||||
$overlay0Alpha = 6c7086
|
|
||||||
|
|
||||||
$surface2Alpha = 585b70
|
|
||||||
$surface1Alpha = 45475a
|
|
||||||
$surface0Alpha = 313244
|
|
||||||
|
|
||||||
$baseAlpha = 1e1e2e
|
|
||||||
$mantleAlpha = 181825
|
|
||||||
$crustAlpha = 11111b
|
|
||||||
|
|
||||||
$rosewater = 0xfff5e0dc
|
|
||||||
$flamingo = 0xfff2cdcd
|
|
||||||
$pink = 0xfff5c2e7
|
|
||||||
$mauve = 0xffcba6f7
|
|
||||||
$red = 0xfff38ba8
|
|
||||||
$maroon = 0xffeba0ac
|
|
||||||
$peach = 0xfffab387
|
|
||||||
$yellow = 0xfff9e2af
|
|
||||||
$green = 0xffa6e3a1
|
|
||||||
$teal = 0xff94e2d5
|
|
||||||
$sky = 0xff89dceb
|
|
||||||
$sapphire = 0xff74c7ec
|
|
||||||
$blue = 0xff89b4fa
|
|
||||||
$lavender = 0xffb4befe
|
|
||||||
|
|
||||||
$text = 0xffcdd6f4
|
|
||||||
$subtext1 = 0xffbac2de
|
|
||||||
$subtext0 = 0xffa6adc8
|
|
||||||
|
|
||||||
$overlay2 = 0xff9399b2
|
|
||||||
$overlay1 = 0xff7f849c
|
|
||||||
$overlay0 = 0xff6c7086
|
|
||||||
|
|
||||||
$surface2 = 0xff585b70
|
|
||||||
$surface1 = 0xff45475a
|
|
||||||
$surface0 = 0xff313244
|
|
||||||
|
|
||||||
$base = 0xff1e1e2e
|
|
||||||
$mantle = 0xff181825
|
|
||||||
$crust = 0xff11111b
|
|
||||||
@ -1,155 +0,0 @@
|
|||||||
General usage
|
|
||||||
=============
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
mpv infile -o outfile [-of outfileformat] [-ofopts formatoptions] [-orawts] \
|
|
||||||
[(any other mpv options)] \
|
|
||||||
-ovc outvideocodec [-ovcopts outvideocodecoptions] \
|
|
||||||
-oac outaudiocodec [-oacopts outaudiocodecoptions]
|
|
||||||
|
|
||||||
Help for these options is provided if giving help as parameter, as in::
|
|
||||||
|
|
||||||
mpv -ovc help
|
|
||||||
|
|
||||||
The suboptions of these generally are identical to ffmpeg's (as option parsing
|
|
||||||
is simply delegated to ffmpeg). The option -ocopyts enables copying timestamps
|
|
||||||
from the source as-is, instead of fixing them to match audio playback time
|
|
||||||
(note: this doesn't work with all output container formats); -orawts even turns
|
|
||||||
off discontinuity fixing.
|
|
||||||
|
|
||||||
Note that if neither -ofps nor -oautofps is specified, VFR encoding is assumed
|
|
||||||
and the time base is 24000fps. -oautofps sets -ofps to a guessed fps number
|
|
||||||
from the input video. Note that not all codecs and not all formats support VFR
|
|
||||||
encoding, and some which do have bugs when a target bitrate is specified - use
|
|
||||||
-ofps or -oautofps to force CFR encoding in these cases.
|
|
||||||
|
|
||||||
Of course, the options can be stored in a profile, like this .config/mpv/mpv.conf
|
|
||||||
section::
|
|
||||||
|
|
||||||
[myencprofile]
|
|
||||||
vf-add = scale=480:-2
|
|
||||||
ovc = libx264
|
|
||||||
ovcopts-add = preset=medium
|
|
||||||
ovcopts-add = tune=fastdecode
|
|
||||||
ovcopts-add = crf=23
|
|
||||||
ovcopts-add = maxrate=1500k
|
|
||||||
ovcopts-add = bufsize=1000k
|
|
||||||
ovcopts-add = rc_init_occupancy=900k
|
|
||||||
ovcopts-add = refs=2
|
|
||||||
ovcopts-add = profile=baseline
|
|
||||||
oac = aac
|
|
||||||
oacopts-add = b=96k
|
|
||||||
|
|
||||||
It's also possible to define default encoding options by putting them into
|
|
||||||
the section named ``[encoding]``. (This behavior changed after mpv 0.3.x. In
|
|
||||||
mpv 0.3.x, config options in the default section / no section were applied
|
|
||||||
to encoding. This is not the case anymore.)
|
|
||||||
|
|
||||||
One can then encode using this profile using the command::
|
|
||||||
|
|
||||||
mpv infile -o outfile.mp4 -profile myencprofile
|
|
||||||
|
|
||||||
Some example profiles are provided in a file
|
|
||||||
etc/encoding-profiles.conf; as for this, see below.
|
|
||||||
|
|
||||||
|
|
||||||
Encoding examples
|
|
||||||
=================
|
|
||||||
|
|
||||||
These are some examples of encoding targets this code has been used and tested
|
|
||||||
for.
|
|
||||||
|
|
||||||
Typical MPEG-4 Part 2 ("ASP", "DivX") encoding, AVI container::
|
|
||||||
|
|
||||||
mpv infile -o outfile.avi \
|
|
||||||
--vf=fps=25 \
|
|
||||||
-ovc mpeg4 -ovcopts qscale=4 \
|
|
||||||
-oac libmp3lame -oacopts ab=128k
|
|
||||||
|
|
||||||
Note: AVI does not support variable frame rate, so the fps filter must be used.
|
|
||||||
The frame rate should ideally match the input (25 for PAL, 24000/1001 or
|
|
||||||
30000/1001 for NTSC)
|
|
||||||
|
|
||||||
Typical MPEG-4 Part 10 ("AVC", "H.264") encoding, Matroska (MKV) container::
|
|
||||||
|
|
||||||
mpv infile -o outfile.mkv \
|
|
||||||
-ovc libx264 -ovcopts preset=medium,crf=23,profile=baseline \
|
|
||||||
-oac libvorbis -oacopts qscale=3
|
|
||||||
|
|
||||||
Typical MPEG-4 Part 10 ("AVC", "H.264") encoding, MPEG-4 (MP4) container::
|
|
||||||
|
|
||||||
mpv infile -o outfile.mp4 \
|
|
||||||
-ovc libx264 -ovcopts preset=medium,crf=23,profile=baseline \
|
|
||||||
-oac aac -oacopts ab=128k
|
|
||||||
|
|
||||||
Typical VP8 encoding, WebM (restricted Matroska) container::
|
|
||||||
|
|
||||||
mpv infile -o outfile.mkv \
|
|
||||||
-of webm \
|
|
||||||
-ovc libvpx -ovcopts qmin=6,b=1000000k \
|
|
||||||
-oac libvorbis -oacopts qscale=3
|
|
||||||
|
|
||||||
|
|
||||||
Device targets
|
|
||||||
==============
|
|
||||||
|
|
||||||
As the options for various devices can get complex, profiles can be used.
|
|
||||||
|
|
||||||
An example profile file for encoding is provided in
|
|
||||||
etc/encoding-profiles.conf in the source tree. This file is installed and loaded
|
|
||||||
by default. If you want to modify it, you can replace and it with your own copy
|
|
||||||
by doing::
|
|
||||||
|
|
||||||
mkdir -p ~/.mpv
|
|
||||||
cp /etc/mpv/encoding-profiles.conf ~/.mpv/encoding-profiles.conf
|
|
||||||
|
|
||||||
Keep in mind that the default profile is the playback one. If you want to add
|
|
||||||
options that apply only in encoding mode, put them into a ``[encoding]``
|
|
||||||
section.
|
|
||||||
|
|
||||||
Refer to the top of that file for more comments - in a nutshell, the following
|
|
||||||
options are added by it::
|
|
||||||
|
|
||||||
-profile enc-to-dvdpal DVD-Video PAL, use dvdauthor -v pal+4:3 -a ac3+en
|
|
||||||
-profile enc-to-dvdntsc DVD-Video NTSC, use dvdauthor -v ntsc+4:3 -a ac3+en
|
|
||||||
-profile enc-to-bb-9000 MP4 for Blackberry Bold 9000
|
|
||||||
-profile enc-to-nok-6300 3GP for Nokia 6300
|
|
||||||
-profile enc-to-psp MP4 for PlayStation Portable
|
|
||||||
-profile enc-to-iphone MP4 for iPhone
|
|
||||||
-profile enc-to-iphone-4 MP4 for iPhone 4 (double res)
|
|
||||||
-profile enc-to-iphone-5 MP4 for iPhone 5 (even larger res)
|
|
||||||
|
|
||||||
You can encode using these with a command line like::
|
|
||||||
|
|
||||||
mpv infile -o outfile.mp4 -profile enc-to-bb-9000
|
|
||||||
|
|
||||||
Of course, you are free to override options set by these profiles by specifying
|
|
||||||
them after the -profile option.
|
|
||||||
|
|
||||||
|
|
||||||
What works
|
|
||||||
==========
|
|
||||||
|
|
||||||
* Encoding at variable frame rate (default)
|
|
||||||
* Encoding at constant frame rate using --vf=fps=RATE
|
|
||||||
* 2-pass encoding (specify flags=+pass1 in the first pass's -ovcopts, specify
|
|
||||||
flags=+pass2 in the second pass)
|
|
||||||
* Hardcoding subtitles using vobsub, ass or srt subtitle rendering (just
|
|
||||||
configure mpv for the subtitles as usual)
|
|
||||||
* Hardcoding any other mpv OSD (e.g. time codes, using -osdlevel 3 and -vf
|
|
||||||
expand=::::1)
|
|
||||||
* Encoding directly from a DVD, network stream, webcam, or any other source
|
|
||||||
mpv supports
|
|
||||||
* Using x264 presets/tunings/profiles (by using profile=, tune=, preset= in the
|
|
||||||
-ovcopts)
|
|
||||||
* Deinterlacing/Inverse Telecine with any of mpv's filters for that
|
|
||||||
* Audio file converting: mpv -o outfile.mp3 infile.flac -no-video -oac
|
|
||||||
libmp3lame -oacopts ab=320k
|
|
||||||
|
|
||||||
What does not work yet
|
|
||||||
======================
|
|
||||||
|
|
||||||
* 3-pass encoding (ensuring constant total size and bitrate constraints while
|
|
||||||
having VBR audio; mencoder calls this "frameno")
|
|
||||||
* Direct stream copy
|
|
||||||
@ -1,179 +0,0 @@
|
|||||||
# mpv keybindings
|
|
||||||
#
|
|
||||||
# Location of user-defined bindings: ~/.config/mpv/input.conf
|
|
||||||
#
|
|
||||||
# Lines starting with # are comments. Use SHARP to assign the # key.
|
|
||||||
# Copy this file and uncomment and edit the bindings you want to change.
|
|
||||||
#
|
|
||||||
# List of commands and further details: DOCS/man/input.rst
|
|
||||||
# List of special keys: --input-keylist
|
|
||||||
# Keybindings testing mode: mpv --input-test --force-window --idle
|
|
||||||
#
|
|
||||||
# Use 'ignore' to unbind a key fully (e.g. 'ctrl+a ignore').
|
|
||||||
#
|
|
||||||
# Strings need to be quoted and escaped:
|
|
||||||
# KEY show-text "This is a single backslash: \\ and a quote: \" !"
|
|
||||||
#
|
|
||||||
# You can use modifier-key combinations like Shift+Left or Ctrl+Alt+x with
|
|
||||||
# the modifiers Shift, Ctrl, Alt and Meta (may not work on the terminal).
|
|
||||||
#
|
|
||||||
# The default keybindings are hardcoded into the mpv binary.
|
|
||||||
# You can disable them completely with: --no-input-default-bindings
|
|
||||||
|
|
||||||
# Developer note:
|
|
||||||
# On compilation, this file is baked into the mpv binary, and all lines are
|
|
||||||
# uncommented (unless '#' is followed by a space) - thus this file defines the
|
|
||||||
# default key bindings.
|
|
||||||
|
|
||||||
# If this is enabled, treat all the following bindings as default.
|
|
||||||
#default-bindings start
|
|
||||||
|
|
||||||
#MBTN_LEFT ignore # don't do anything
|
|
||||||
#MBTN_LEFT_DBL cycle fullscreen # toggle fullscreen
|
|
||||||
#MBTN_RIGHT cycle pause # toggle pause/playback mode
|
|
||||||
#MBTN_BACK playlist-prev # skip to the previous file
|
|
||||||
#MBTN_FORWARD playlist-next # skip to the next file
|
|
||||||
|
|
||||||
# Mouse wheels, touchpad or other input devices that have axes
|
|
||||||
# if the input devices supports precise scrolling it will also scale the
|
|
||||||
# numeric value accordingly
|
|
||||||
#WHEEL_UP seek 10 # seek 10 seconds forward
|
|
||||||
#WHEEL_DOWN seek -10 # seek 10 seconds backward
|
|
||||||
#WHEEL_LEFT add volume -2
|
|
||||||
#WHEEL_RIGHT add volume 2
|
|
||||||
|
|
||||||
## Seek units are in seconds, but note that these are limited by keyframes
|
|
||||||
#RIGHT seek 5 # seek 5 seconds forward
|
|
||||||
#LEFT seek -5 # seek 5 seconds backward
|
|
||||||
#UP seek 60 # seek 1 minute forward
|
|
||||||
#DOWN seek -60 # seek 1 minute backward
|
|
||||||
# Do smaller, always exact (non-keyframe-limited), seeks with shift.
|
|
||||||
# Don't show them on the OSD (no-osd).
|
|
||||||
#Shift+RIGHT no-osd seek 1 exact # seek exactly 1 second forward
|
|
||||||
#Shift+LEFT no-osd seek -1 exact # seek exactly 1 second backward
|
|
||||||
#Shift+UP no-osd seek 5 exact # seek exactly 5 seconds forward
|
|
||||||
#Shift+DOWN no-osd seek -5 exact # seek exactly 5 seconds backward
|
|
||||||
#Ctrl+LEFT no-osd sub-seek -1 # seek to the previous subtitle
|
|
||||||
#Ctrl+RIGHT no-osd sub-seek 1 # seek to the next subtitle
|
|
||||||
#Ctrl+Shift+LEFT sub-step -1 # change subtitle timing such that the previous subtitle is displayed
|
|
||||||
#Ctrl+Shift+RIGHT sub-step 1 # change subtitle timing such that the next subtitle is displayed
|
|
||||||
#Alt+left add video-pan-x 0.1 # move the video right
|
|
||||||
#Alt+right add video-pan-x -0.1 # move the video left
|
|
||||||
#Alt+up add video-pan-y 0.1 # move the video down
|
|
||||||
#Alt+down add video-pan-y -0.1 # move the video up
|
|
||||||
#Alt++ add video-zoom 0.1 # zoom in
|
|
||||||
#Alt+- add video-zoom -0.1 # zoom out
|
|
||||||
#Alt+BS set video-zoom 0 ; set video-pan-x 0 ; set video-pan-y 0 # reset zoom and pan settings
|
|
||||||
#PGUP add chapter 1 # seek to the next chapter
|
|
||||||
#PGDWN add chapter -1 # seek to the previous chapter
|
|
||||||
#Shift+PGUP seek 600 # seek 10 minutes forward
|
|
||||||
#Shift+PGDWN seek -600 # seek 10 minutes backward
|
|
||||||
#[ multiply speed 1/1.1 # decrease the playback speed
|
|
||||||
#] multiply speed 1.1 # increase the playback speed
|
|
||||||
#{ multiply speed 0.5 # halve the playback speed
|
|
||||||
#} multiply speed 2.0 # double the playback speed
|
|
||||||
#BS set speed 1.0 # reset the speed to normal
|
|
||||||
#Shift+BS revert-seek # undo the previous (or marked) seek
|
|
||||||
#Shift+Ctrl+BS revert-seek mark # mark the position for revert-seek
|
|
||||||
#q quit
|
|
||||||
#Q quit-watch-later # exit and remember the playback position
|
|
||||||
#q {encode} quit 4
|
|
||||||
#ESC set fullscreen no # leave fullscreen
|
|
||||||
#ESC {encode} quit 4
|
|
||||||
#p cycle pause # toggle pause/playback mode
|
|
||||||
#. frame-step # advance one frame and pause
|
|
||||||
#, frame-back-step # go back by one frame and pause
|
|
||||||
#SPACE cycle pause # toggle pause/playback mode
|
|
||||||
#> playlist-next # skip to the next file
|
|
||||||
#ENTER playlist-next # skip to the next file
|
|
||||||
#< playlist-prev # skip to the previous file
|
|
||||||
#O no-osd cycle-values osd-level 3 1 # toggle displaying the OSD on user interaction or always
|
|
||||||
#o show-progress # show playback progress
|
|
||||||
#P show-progress # show playback progress
|
|
||||||
#i script-binding stats/display-stats # display information and statistics
|
|
||||||
#I script-binding stats/display-stats-toggle # toggle displaying information and statistics
|
|
||||||
#` script-binding console/enable # open the console
|
|
||||||
#z add sub-delay -0.1 # shift subtitles 100 ms earlier
|
|
||||||
#Z add sub-delay +0.1 # delay subtitles by 100 ms
|
|
||||||
#x add sub-delay +0.1 # delay subtitles by 100 ms
|
|
||||||
#ctrl++ add audio-delay 0.100 # change audio/video sync by delaying the audio
|
|
||||||
#ctrl+- add audio-delay -0.100 # change audio/video sync by shifting the audio earlier
|
|
||||||
#Shift+g add sub-scale +0.1 # increase the subtitle font size
|
|
||||||
#Shift+f add sub-scale -0.1 # decrease the subtitle font size
|
|
||||||
#9 add volume -2
|
|
||||||
#/ add volume -2
|
|
||||||
#0 add volume 2
|
|
||||||
#* add volume 2
|
|
||||||
#m cycle mute # toggle mute
|
|
||||||
#1 add contrast -1
|
|
||||||
#2 add contrast 1
|
|
||||||
#3 add brightness -1
|
|
||||||
#4 add brightness 1
|
|
||||||
#5 add gamma -1
|
|
||||||
#6 add gamma 1
|
|
||||||
#7 add saturation -1
|
|
||||||
#8 add saturation 1
|
|
||||||
#Alt+0 set current-window-scale 0.5 # halve the window size
|
|
||||||
#Alt+1 set current-window-scale 1.0 # reset the window size
|
|
||||||
#Alt+2 set current-window-scale 2.0 # double the window size
|
|
||||||
#d cycle deinterlace # toggle the deinterlacing filter
|
|
||||||
#r add sub-pos -1 # move subtitles up
|
|
||||||
#R add sub-pos +1 # move subtitles down
|
|
||||||
#t add sub-pos +1 # move subtitles down
|
|
||||||
#v cycle sub-visibility # hide or show the subtitles
|
|
||||||
#Alt+v cycle secondary-sub-visibility # hide or show the secondary subtitles
|
|
||||||
#V cycle sub-ass-vsfilter-aspect-compat # toggle stretching SSA/ASS subtitles with anamorphic videos to match the historical renderer
|
|
||||||
#u cycle-values sub-ass-override "force" "no" # toggle overriding SSA/ASS subtitle styles with the normal styles
|
|
||||||
#j cycle sub # switch subtitle track
|
|
||||||
#J cycle sub down # switch subtitle track backwards
|
|
||||||
#SHARP cycle audio # switch audio track
|
|
||||||
#_ cycle video # switch video track
|
|
||||||
#T cycle ontop # toggle placing the video on top of other windows
|
|
||||||
#f cycle fullscreen # toggle fullscreen
|
|
||||||
#s screenshot # take a screenshot of the video in its original resolution with subtitles
|
|
||||||
#S screenshot video # take a screenshot of the video in its original resolution without subtitles
|
|
||||||
#Ctrl+s screenshot window # take a screenshot of the window with OSD and subtitles
|
|
||||||
#Alt+s screenshot each-frame # automatically screenshot every frame; issue this command again to stop taking screenshots
|
|
||||||
#w add panscan -0.1 # decrease panscan
|
|
||||||
#W add panscan +0.1 # shrink black bars by cropping the video
|
|
||||||
#e add panscan +0.1 # shrink black bars by cropping the video
|
|
||||||
#A cycle-values video-aspect-override "16:9" "4:3" "2.35:1" "-1" # cycle the video aspect ratio ("-1" is the container aspect)
|
|
||||||
#POWER quit
|
|
||||||
#PLAY cycle pause # toggle pause/playback mode
|
|
||||||
#PAUSE cycle pause # toggle pause/playback mode
|
|
||||||
#PLAYPAUSE cycle pause # toggle pause/playback mode
|
|
||||||
#PLAYONLY set pause no # unpause
|
|
||||||
#PAUSEONLY set pause yes # pause
|
|
||||||
#STOP quit
|
|
||||||
#FORWARD seek 60 # seek 1 minute forward
|
|
||||||
#REWIND seek -60 # seek 1 minute backward
|
|
||||||
#NEXT playlist-next # skip to the next file
|
|
||||||
#PREV playlist-prev # skip to the previous file
|
|
||||||
#VOLUME_UP add volume 2
|
|
||||||
#VOLUME_DOWN add volume -2
|
|
||||||
#MUTE cycle mute # toggle mute
|
|
||||||
#CLOSE_WIN quit
|
|
||||||
#CLOSE_WIN {encode} quit 4
|
|
||||||
#ctrl+w quit
|
|
||||||
#E cycle edition # switch edition
|
|
||||||
#l ab-loop # set/clear A-B loop points
|
|
||||||
#L cycle-values loop-file "inf" "no" # toggle infinite looping
|
|
||||||
#ctrl+c quit 4
|
|
||||||
#DEL script-binding osc/visibility # cycle OSC visibility between never, auto (mouse-move) and always
|
|
||||||
#ctrl+h cycle-values hwdec "auto" "no" # toggle hardware decoding
|
|
||||||
#F8 show-text ${playlist} # show the playlist
|
|
||||||
#F9 show-text ${track-list} # show the list of video, audio and sub tracks
|
|
||||||
|
|
||||||
#
|
|
||||||
# Legacy bindings (may or may not be removed in the future)
|
|
||||||
#
|
|
||||||
#! add chapter -1 # seek to the previous chapter
|
|
||||||
#@ add chapter 1 # seek to the next chapter
|
|
||||||
|
|
||||||
#
|
|
||||||
# Not assigned by default
|
|
||||||
# (not an exhaustive list of unbound commands)
|
|
||||||
#
|
|
||||||
|
|
||||||
# ? cycle sub-forced-only # toggle DVD forced subs
|
|
||||||
# ? stop # stop playback (quit or enter idle mode)
|
|
||||||
@ -1,61 +0,0 @@
|
|||||||
|
|
||||||
# This file contains all bindings that were removed after a certain release.
|
|
||||||
# If you want MPlayer bindings, use mplayer-input.conf
|
|
||||||
|
|
||||||
# Pick the bindings you want back and add them to your own input.conf. Append
|
|
||||||
# this file to your input.conf if you want them all back:
|
|
||||||
#
|
|
||||||
# cat restore-old-bindings.conf >> ~/.config/mpv/input.conf
|
|
||||||
#
|
|
||||||
# Older installations use ~/.mpv/input.conf instead.
|
|
||||||
|
|
||||||
# changed in mpv 0.27.0 (macOS and Wayland only)
|
|
||||||
|
|
||||||
# WHEEL_UP seek 10
|
|
||||||
# WHEEL_DOWN seek -10
|
|
||||||
# WHEEL_LEFT seek 5
|
|
||||||
# WHEEL_RIGHT seek -5
|
|
||||||
|
|
||||||
# changed in mpv 0.26.0
|
|
||||||
|
|
||||||
h cycle tv-channel -1 # previous channel
|
|
||||||
k cycle tv-channel +1 # next channel
|
|
||||||
H cycle dvb-channel-name -1 # previous channel
|
|
||||||
K cycle dvb-channel-name +1 # next channel
|
|
||||||
|
|
||||||
I show-text "${filename}" # display filename in osd
|
|
||||||
|
|
||||||
# changed in mpv 0.24.0
|
|
||||||
|
|
||||||
L cycle-values loop "inf" "no"
|
|
||||||
|
|
||||||
# changed in mpv 0.10.0
|
|
||||||
|
|
||||||
O osd
|
|
||||||
D cycle deinterlace
|
|
||||||
d cycle framedrop
|
|
||||||
|
|
||||||
# changed in mpv 0.7.0
|
|
||||||
|
|
||||||
ENTER playlist-next force
|
|
||||||
|
|
||||||
# changed in mpv 0.6.0
|
|
||||||
|
|
||||||
ESC quit
|
|
||||||
|
|
||||||
# changed in mpv 0.5.0
|
|
||||||
|
|
||||||
PGUP seek 600
|
|
||||||
PGDWN seek -600
|
|
||||||
RIGHT seek 10
|
|
||||||
LEFT seek -10
|
|
||||||
+ add audio-delay 0.100
|
|
||||||
- add audio-delay -0.100
|
|
||||||
( add balance -0.1
|
|
||||||
) add balance 0.1
|
|
||||||
F cycle sub-forced-only
|
|
||||||
TAB cycle program
|
|
||||||
A cycle angle
|
|
||||||
U stop
|
|
||||||
o osd
|
|
||||||
I show-text "${filename}"
|
|
||||||
@ -1,657 +0,0 @@
|
|||||||
This file intends to give a big picture overview of how mpv is structured.
|
|
||||||
|
|
||||||
player/*.c:
|
|
||||||
Essentially makes up the player applications, including the main() function
|
|
||||||
and the playback loop.
|
|
||||||
|
|
||||||
Generally, it accesses all other subsystems, initializes them, and pushes
|
|
||||||
data between them during playback.
|
|
||||||
|
|
||||||
The structure is as follows (as of commit e13c05366557cb):
|
|
||||||
* main():
|
|
||||||
* basic initializations (e.g. init_libav() and more)
|
|
||||||
* pre-parse command line (verbosity level, config file locations)
|
|
||||||
* load config files (parse_cfgfiles())
|
|
||||||
* parse command line, add files from the command line to playlist
|
|
||||||
(m_config_parse_mp_command_line())
|
|
||||||
* check help options etc. (call handle_help_options()), possibly exit
|
|
||||||
* call mp_play_files() function that works down the playlist:
|
|
||||||
* run idle loop (idle_loop()), until there are files in the
|
|
||||||
playlist or an exit command was given (only if --idle it set)
|
|
||||||
* actually load and play a file in play_current_file():
|
|
||||||
* run all the dozens of functions to load the file and
|
|
||||||
initialize playback
|
|
||||||
* run a small loop that does normal playback, until the file is
|
|
||||||
done or a command terminates playback
|
|
||||||
(on each iteration, run_playloop() is called, which is rather
|
|
||||||
big and complicated - it decodes some audio and video on
|
|
||||||
each frame, waits for input, etc.)
|
|
||||||
* uninitialize playback
|
|
||||||
* determine next entry on the playlist to play
|
|
||||||
* loop, or exit if no next file or quit is requested
|
|
||||||
(see enum stop_play_reason)
|
|
||||||
* call mp_destroy()
|
|
||||||
* run_playloop():
|
|
||||||
* calls fill_audio_out_buffers()
|
|
||||||
This checks whether new audio needs to be decoded, and pushes it
|
|
||||||
to the AO.
|
|
||||||
* calls write_video()
|
|
||||||
Decode new video, and push it to the VO.
|
|
||||||
* determines whether playback of the current file has ended
|
|
||||||
* determines when to start playback after seeks
|
|
||||||
* and calls a whole lot of other stuff
|
|
||||||
(Really, this function does everything.)
|
|
||||||
|
|
||||||
Things worth saying about the playback core:
|
|
||||||
- most state is in MPContext (core.h), which is not available to the
|
|
||||||
subsystems (and should not be made available)
|
|
||||||
- the currently played tracks are in mpctx->current_tracks, and decoder
|
|
||||||
state in track.dec/d_sub
|
|
||||||
- the other subsystems rarely call back into the frontend, and the frontend
|
|
||||||
polls them instead (probably a good thing)
|
|
||||||
- one exceptions are wakeup callbacks, which notify a "higher" component
|
|
||||||
of a changed situation in a subsystem
|
|
||||||
|
|
||||||
I like to call the player/*.c files the "frontend".
|
|
||||||
|
|
||||||
ta.h & ta.c:
|
|
||||||
Hierarchical memory manager inspired by talloc from Samba. It's like a
|
|
||||||
malloc() with more features. Most importantly, each talloc allocation can
|
|
||||||
have a parent, and if the parent is free'd, all children will be free'd as
|
|
||||||
well. The parent is an arbitrary talloc allocation. It's either set by the
|
|
||||||
allocation call by passing a talloc parent, usually as first argument to the
|
|
||||||
allocation function. It can also be set or reset later by other calls (at
|
|
||||||
least talloc_steal()). A talloc allocation that is used as parent is often
|
|
||||||
called a talloc context.
|
|
||||||
|
|
||||||
One very useful feature of talloc is fast tracking of memory leaks. ("Fast"
|
|
||||||
as in it doesn't require valgrind.) You can enable it by setting the
|
|
||||||
MPV_LEAK_REPORT environment variable to "1":
|
|
||||||
export MPV_LEAK_REPORT=1
|
|
||||||
Or permanently by building with --enable-ta-leak-report.
|
|
||||||
This will list all unfree'd allocations on exit.
|
|
||||||
|
|
||||||
Documentation can be found here:
|
|
||||||
http://git.samba.org/?p=samba.git;a=blob;f=lib/talloc/talloc.h;hb=HEAD
|
|
||||||
|
|
||||||
For some reason, we're still using API-compatible wrappers instead of TA
|
|
||||||
directly. The talloc wrapper has only a subset of the functionality, and
|
|
||||||
in particular the wrappers abort() on memory allocation failure.
|
|
||||||
|
|
||||||
Note: unlike tcmalloc, jemalloc, etc., talloc() is not actually a malloc
|
|
||||||
replacement. It works on top of system malloc and provides additional
|
|
||||||
features that are supposed to make memory management easier.
|
|
||||||
|
|
||||||
player/command.c:
|
|
||||||
This contains the implementation for client API commands and properties.
|
|
||||||
Properties are essentially dynamic variables changed by certain commands.
|
|
||||||
This is basically responsible for all user commands, like initiating
|
|
||||||
seeking, switching tracks, etc. It calls into other player/*.c files,
|
|
||||||
where most of the work is done, but also calls other parts of mpv.
|
|
||||||
|
|
||||||
player/core.h:
|
|
||||||
Data structures and function prototypes for most of player/*.c. They are
|
|
||||||
usually not accessed by other parts of mpv for the sake of modularization.
|
|
||||||
|
|
||||||
player/client.c:
|
|
||||||
This implements the client API (libmpv/client.h). For the most part, this
|
|
||||||
just calls into other parts of the player. This also manages a ringbuffer
|
|
||||||
of events from player to clients.
|
|
||||||
|
|
||||||
options/options.h, options/options.c
|
|
||||||
options.h contains the global option struct MPOpts. The option declarations
|
|
||||||
(option names, types, and MPOpts offsets for the option parser) are in
|
|
||||||
options.c. Most default values for options and MPOpts are in
|
|
||||||
mp_default_opts at the end of options.c.
|
|
||||||
|
|
||||||
MPOpts is unfortunately quite monolithic, but is being incrementally broken
|
|
||||||
up into sub-structs. Many components have their own sub-option structs
|
|
||||||
separate from MPOpts. New options should be bound to the component that uses
|
|
||||||
them. Add a new option table/struct if needed.
|
|
||||||
|
|
||||||
The global MPOpts still contains the sub-structs as fields, which serves to
|
|
||||||
link them to the option parser. For example, an entry like this may be
|
|
||||||
typical:
|
|
||||||
|
|
||||||
{"", OPT_SUBSTRUCT(demux_opts, demux_conf)},
|
|
||||||
|
|
||||||
This directs the option access code to include all options in demux_conf
|
|
||||||
into the global option list, with no prefix (""), and as part of the
|
|
||||||
MPOpts.demux_opts field. The MPOpts.demux_opts field is actually not
|
|
||||||
accessed anywhere, and instead demux.c does this:
|
|
||||||
|
|
||||||
struct m_config_cache *opts_cache =
|
|
||||||
m_config_cache_alloc(demuxer, global, &demux_conf);
|
|
||||||
struct demux_opts *opts = opts_cache->opts;
|
|
||||||
|
|
||||||
... to get a copy of its options.
|
|
||||||
|
|
||||||
See m_config.h (below) how to access options.
|
|
||||||
|
|
||||||
The actual option parser is spread over m_option.c, m_config.c, and
|
|
||||||
parse_commandline.c, and uses the option table in options.c.
|
|
||||||
|
|
||||||
options/m_config.h & m_config.c:
|
|
||||||
Code for querying and managing options. This (unfortunately) contains both
|
|
||||||
declarations for the "legacy-ish" global m_config struct, and ways to access
|
|
||||||
options in a threads-safe way anywhere, like m_config_cache_alloc().
|
|
||||||
|
|
||||||
m_config_cache_alloc() lets anyone read, observe, and write options in any
|
|
||||||
thread. The only state it needs is struct mpv_global, which is an opaque
|
|
||||||
type that can be passed "down" the component hierarchy. For safety reasons,
|
|
||||||
you should not pass down any pointers to option structs (like MPOpts), but
|
|
||||||
instead pass down mpv_global, and use m_config_cache_alloc() (or similar)
|
|
||||||
to get a synchronized copy of the options.
|
|
||||||
|
|
||||||
input/input.c:
|
|
||||||
This translates keyboard input coming from VOs and other sources (such
|
|
||||||
as remote control devices like Apple IR or client API commands) to the
|
|
||||||
key bindings listed in the user's (or the builtin) input.conf and turns
|
|
||||||
them into items of type struct mp_cmd. These commands are queued, and read
|
|
||||||
by playloop.c. They get pushed with run_command() to command.c.
|
|
||||||
|
|
||||||
Note that keyboard input and commands used by the client API are the same.
|
|
||||||
The client API only uses the command parser though, and has its own queue
|
|
||||||
of input commands somewhere else.
|
|
||||||
|
|
||||||
common/msg.h:
|
|
||||||
All terminal output must go through mp_msg().
|
|
||||||
|
|
||||||
stream/*:
|
|
||||||
File input is implemented here. stream.h/.c provides a simple stream based
|
|
||||||
interface (like reading a number of bytes at a given offset). mpv can
|
|
||||||
also play from http streams and such, which is implemented here.
|
|
||||||
|
|
||||||
E.g. if mpv sees "http://something" on the command line, it will pick
|
|
||||||
stream_lavf.c based on the prefix, and pass the rest of the filename to it.
|
|
||||||
|
|
||||||
Some stream inputs are quite special: stream_dvd.c turns DVDs into mpeg
|
|
||||||
streams (DVDs are actually a bunch of vob files etc. on a filesystem),
|
|
||||||
stream_tv.c provides TV input including channel switching.
|
|
||||||
|
|
||||||
Some stream inputs are just there to invoke special demuxers, like
|
|
||||||
stream_mf.c. (Basically to make the prefix "mf://" do something special.)
|
|
||||||
|
|
||||||
demux/:
|
|
||||||
Demuxers split data streams into audio/video/sub streams, which in turn
|
|
||||||
are split in packets. Packets (see demux_packet.h) are mostly byte chunks
|
|
||||||
tagged with a playback time (PTS). These packets are passed to the decoders.
|
|
||||||
|
|
||||||
Most demuxers have been removed from this fork, and the only important and
|
|
||||||
"actual" demuxers left are demux_mkv.c and demux_lavf.c (uses libavformat).
|
|
||||||
There are some pseudo demuxers like demux_cue.c.
|
|
||||||
|
|
||||||
The main interface is in demux.h. The stream headers are in stheader.h.
|
|
||||||
There is a stream header for each audio/video/sub stream, and each of them
|
|
||||||
holds codec information about the stream and other information.
|
|
||||||
|
|
||||||
demux.c is a bit big, the main reason being that it contains the demuxer
|
|
||||||
cache, which is implemented as a list of packets. The cache is complex
|
|
||||||
because it support seeking, multiple ranges, prefetching, and so on.
|
|
||||||
|
|
||||||
video/:
|
|
||||||
This contains several things related to audio/video decoding, as well as
|
|
||||||
video filters.
|
|
||||||
|
|
||||||
mp_image.h and img_format.h define how mpv stores decoded video frames
|
|
||||||
internally.
|
|
||||||
|
|
||||||
video/decode/:
|
|
||||||
vd_*.c are video decoders. (There's only vd_lavc.c left.) dec_video.c
|
|
||||||
handles most of connecting the frontend with the actual decoder.
|
|
||||||
|
|
||||||
video/filter/:
|
|
||||||
vf_*.c and vf.c form the video filter chain. They are fed by the video
|
|
||||||
decoder, and output the filtered images to the VOs though vf_vo.c. By
|
|
||||||
default, no video filters (except vf_vo) are used. vf_scale is automatically
|
|
||||||
inserted if the video output can't handle the video format used by the
|
|
||||||
decoder.
|
|
||||||
|
|
||||||
video/out/:
|
|
||||||
Video output. They also create GUI windows and handle user input. In most
|
|
||||||
cases, the windowing code is shared among VOs, like x11_common.c for X11 and
|
|
||||||
w32_common.c for Windows. The VOs stand between frontend and windowing code.
|
|
||||||
vo_gpu can pick a windowing system at runtime, e.g. the same binary can
|
|
||||||
provide both X11 and Cocoa support on OSX.
|
|
||||||
|
|
||||||
VOs can be reconfigured at runtime. A vo_reconfig() call can change the video
|
|
||||||
resolution and format, without destroying the window.
|
|
||||||
|
|
||||||
vo_gpu should be taken as reference.
|
|
||||||
|
|
||||||
audio/:
|
|
||||||
format.h/format.c define the uncompressed audio formats. (As well as some
|
|
||||||
compressed formats used for spdif.)
|
|
||||||
|
|
||||||
audio/decode/:
|
|
||||||
ad_*.c and dec_audio.c handle audio decoding. ad_lavc.c is the
|
|
||||||
decoder using ffmpeg. ad_spdif.c is not really a decoder, but is used for
|
|
||||||
compressed audio passthrough.
|
|
||||||
|
|
||||||
audio/filter/:
|
|
||||||
Audio filter chain. af_lavrresample is inserted if any form of conversion
|
|
||||||
between audio formats is needed.
|
|
||||||
|
|
||||||
audio/out/:
|
|
||||||
Audio outputs.
|
|
||||||
|
|
||||||
Unlike VOs, AOs can't be reconfigured on a format change. On audio format
|
|
||||||
changes, the AO will simply be closed and re-opened.
|
|
||||||
|
|
||||||
There are wrappers to support for two types of audio APIs: push.c and
|
|
||||||
pull.c. ao.c calls into one of these. They contain generic code to deal
|
|
||||||
with the data flow these APIs impose.
|
|
||||||
|
|
||||||
Note that mpv synchronizes the video to the audio. That's the reason
|
|
||||||
why buggy audio drivers can have a bad influence on playback quality.
|
|
||||||
|
|
||||||
sub/:
|
|
||||||
Contains subtitle and OSD rendering.
|
|
||||||
|
|
||||||
osd.c/.h is actually the OSD code. It queries dec_sub.c to retrieve
|
|
||||||
decoded/rendered subtitles. osd_libass.c is the actual implementation of
|
|
||||||
the OSD text renderer (which uses libass, and takes care of all the tricky
|
|
||||||
fontconfig/freetype API usage and text layouting).
|
|
||||||
|
|
||||||
The VOs call osd.c to render OSD and subtitle (via e.g. osd_draw()). osd.c
|
|
||||||
in turn asks dec_sub.c for subtitle overlay bitmaps, which relays the
|
|
||||||
request to one of the sd_*.c subtitle decoders/renderers.
|
|
||||||
|
|
||||||
Subtitle loading is in demux/. The MPlayer subreader.c is mostly gone - parts
|
|
||||||
of it survive in demux_subreader.c. It's used as last fallback, or to handle
|
|
||||||
some text subtitle types on Libav. It should go away eventually. Normally,
|
|
||||||
subtitles are loaded via demux_lavf.c.
|
|
||||||
|
|
||||||
The subtitles are passed to dec_sub.c and the subtitle decoders in sd_*.c
|
|
||||||
as they are demuxed. All text subtitles are rendered by sd_ass.c. If text
|
|
||||||
subtitles are not in the ASS format, the libavcodec subtitle converters are
|
|
||||||
used (lavc_conv.c).
|
|
||||||
|
|
||||||
Text subtitles can be preloaded, in which case they are read fully as soon
|
|
||||||
as the subtitle is selected. In this case, they are effectively stored in
|
|
||||||
sd_ass.c's internal state.
|
|
||||||
|
|
||||||
etc/:
|
|
||||||
The file input.conf is actually integrated into the mpv binary by the
|
|
||||||
build system. It contains the default keybindings.
|
|
||||||
|
|
||||||
Best practices and Concepts within mpv
|
|
||||||
======================================
|
|
||||||
|
|
||||||
General contribution etc.
|
|
||||||
-------------------------
|
|
||||||
|
|
||||||
See: DOCS/contribute.md
|
|
||||||
|
|
||||||
Error checking
|
|
||||||
--------------
|
|
||||||
|
|
||||||
If an error is relevant, it should be handled. If it's interesting, log the
|
|
||||||
error. However, mpv often keeps errors silent and reports failures somewhat
|
|
||||||
coarsely by propagating them upwards the caller chain. This is OK, as long as
|
|
||||||
the errors are not very interesting, or would require a developer to debug it
|
|
||||||
anyway (in which case using a debugger would be more convenient, and the
|
|
||||||
developer would need to add temporary debug printfs to get extremely detailed
|
|
||||||
information which would not be appropriate during normal operation).
|
|
||||||
|
|
||||||
Basically, keep a balance on error reporting. But always check them, unless you
|
|
||||||
have a good argument not to.
|
|
||||||
|
|
||||||
Memory allocation errors (OOM) are a special class of errors. Normally such
|
|
||||||
allocation failures are not handled "properly". Instead, abort() is called.
|
|
||||||
(New code should use MP_HANDLE_OOM() for this.) This is done out of laziness and
|
|
||||||
for convenience, and due to the fact that MPlayer/mplayer2 never handled it
|
|
||||||
correctly. (MPlayer varied between handling it correctly, trying to do so but
|
|
||||||
failing, and just not caring, while mplayer2 started using abort() for it.)
|
|
||||||
|
|
||||||
This is justifiable in a number of ways. Error handling paths are notoriously
|
|
||||||
untested and buggy, so merely having them won't make your program more reliable.
|
|
||||||
Having these error handling paths also complicates non-error code, due to the
|
|
||||||
need to roll back state at any point after a memory allocation.
|
|
||||||
|
|
||||||
Take any larger body of code, that is supposed to handle OOM, and test whether
|
|
||||||
the error paths actually work, for example by overriding malloc with a version
|
|
||||||
that randomly fails. You will find bugs quickly, and often they will be very
|
|
||||||
annoying to fix (if you can even reproduce them).
|
|
||||||
|
|
||||||
In addition, a clear indication that something went wrong may be missing. On
|
|
||||||
error your program may exhibit "degraded" behavior by design. Consider a video
|
|
||||||
encoder dropping frames somewhere in the middle of a video due to temporary
|
|
||||||
allocation failures, instead of just exiting with an errors. In other cases, it
|
|
||||||
may open conceptual security holes. Failing fast may be better.
|
|
||||||
|
|
||||||
mpv uses GPU APIs, which may be break on allocation errors (because driver
|
|
||||||
authors will have the same issues as described here), or don't even have a real
|
|
||||||
concept for dealing with OOM (OpenGL).
|
|
||||||
|
|
||||||
libmpv is often used by GUIs, which I predict always break if OOM happens.
|
|
||||||
|
|
||||||
Last but not least, OSes like Linux use "overcommit", which basically means that
|
|
||||||
your program may crash any time OOM happens, even if it doesn't use malloc() at
|
|
||||||
all!
|
|
||||||
|
|
||||||
But still, don't just assume malloc() always succeeds. Use MP_HANDLE_OOM(). The
|
|
||||||
ta* APIs do this for you. The reason for this is that dereferencing a NULL
|
|
||||||
pointer can have security relevant consequences if large offsets are involved.
|
|
||||||
Also, a clear error message is better than a random segfault.
|
|
||||||
|
|
||||||
Some big memory allocations are checked anyway. For example, all code must
|
|
||||||
assume that allocating video frames or packets can fail. (The above example
|
|
||||||
of dropping video frames during encoding is entirely possible in mpv.)
|
|
||||||
|
|
||||||
Undefined behavior
|
|
||||||
------------------
|
|
||||||
|
|
||||||
Undefined behavior (UB) is a concept in the C language. C is famous for being a
|
|
||||||
language that makes it almost impossible to write working code, because
|
|
||||||
undefined behavior is so easily triggered, compilers will happily abuse it to
|
|
||||||
generate "faster" code, debugging tools will shout at you, and sometimes it
|
|
||||||
even means your code doesn't work.
|
|
||||||
|
|
||||||
There is a lot of literature on this topic. Read it.
|
|
||||||
|
|
||||||
(In C's defense, UB exists in other languages too, but since they're not used
|
|
||||||
for low level infrastructure, and/or these languages are at times not rigorously
|
|
||||||
defined, simply nobody cares. However, the C standard committee is still guilty
|
|
||||||
for not addressing this. I'll admit that I can't even tell from the standard's
|
|
||||||
gibberish whether some specific behavior is UB or not. It's written like tax
|
|
||||||
law.)
|
|
||||||
|
|
||||||
In mpv, we generally try to avoid undefined behavior. For one, we want portable
|
|
||||||
and reliable operation. But more importantly, we want clean output from
|
|
||||||
debugging tools, in order to find real bugs more quickly and effectively.
|
|
||||||
|
|
||||||
Avoid the "works in practice" argument. Once debugging tools come into play, or
|
|
||||||
simply when "in practice" stops being true, this will all get back to you in a
|
|
||||||
bad way.
|
|
||||||
|
|
||||||
Global state, library safety
|
|
||||||
----------------------------
|
|
||||||
|
|
||||||
Mutable global state is when code uses global variables that are not read-only.
|
|
||||||
This must be avoided in mpv. Always use context structs that the caller of
|
|
||||||
your code needs to allocate, and whose pointers are passed to your functions.
|
|
||||||
|
|
||||||
Library safety means that your code (or library) can be used by a library
|
|
||||||
without causing conflicts with other library users in the same process. To any
|
|
||||||
piece of code, a "safe" library's API can simply be used, without having to
|
|
||||||
worry about other API users that may be around somewhere.
|
|
||||||
|
|
||||||
Libraries are often not library safe, because they they use global mutable state
|
|
||||||
or other "global" resources. Typical examples include use of signals, simple
|
|
||||||
global variables (like hsearch() in libc), or internal caches not protected by
|
|
||||||
locks.
|
|
||||||
|
|
||||||
A surprisingly high number of libraries are not library safe because they need
|
|
||||||
global initialization. Typically they provide an API function, which
|
|
||||||
"initializes" the library, and which must be called before calling any other
|
|
||||||
API functions. Often, you are to provide global configuration parameters, which
|
|
||||||
can change the behavior of the library. If two libraries A and B use library C,
|
|
||||||
but A and B initialize C with different parameters, something "bad" may happen.
|
|
||||||
In addition, these global initialization functions are often not thread-safe. So
|
|
||||||
if A and B try to initialize C at the same time (from different threads and
|
|
||||||
without knowing about each other), it may cause undefined behavior. (libcurl is
|
|
||||||
a good example of both of these issues. FFmpeg and some TLS libraries used to be
|
|
||||||
affected, but improved.)
|
|
||||||
|
|
||||||
This is so bad because library A and B from the previous example most likely
|
|
||||||
have no way to cooperate, because they're from different authors and have no
|
|
||||||
business knowing each others. They'd need a library D, which wraps library C
|
|
||||||
in a safe way. Unfortunately, typically something worse happens: libraries get
|
|
||||||
"infected" by the unsafeness of its sub-libraries, and export a global init API
|
|
||||||
just to initialize the sub-libraries. In the previous example, libraries A and B
|
|
||||||
would export global init APIs just to init library C, even though the rest of
|
|
||||||
A/B are clean and library safe. (Again, libcurl is an example of this, if you
|
|
||||||
subtract other historic anti-features.)
|
|
||||||
|
|
||||||
The main problem with library safety is that its lack propagates to all
|
|
||||||
libraries using the library.
|
|
||||||
|
|
||||||
We require libmpv to be library safe. This is not really possible, because some
|
|
||||||
libraries are not library safe (FFmpeg, Xlib, partially ALSA). However, for
|
|
||||||
ideological reasons, there is no global init API, and best effort is made to try
|
|
||||||
to avoid problems.
|
|
||||||
|
|
||||||
libmpv has some features that are not library safe, but which are disabled by
|
|
||||||
default (such as terminal usage aka stdout, or JSON IPC blocking SIGPIPE for
|
|
||||||
internal convenience).
|
|
||||||
|
|
||||||
A notable, very disgustingly library unsafe behavior of libmpv is calling
|
|
||||||
abort() on some memory allocation failure. See error checking section.
|
|
||||||
|
|
||||||
Logging
|
|
||||||
-------
|
|
||||||
|
|
||||||
All logging and terminal output in mpv goes through the functions and macros
|
|
||||||
provided in common/msg.h. This is in part for library safety, and in part to
|
|
||||||
make sure users can silence all output, or to redirect the output elsewhere,
|
|
||||||
like a log file or the internal console.lua script.
|
|
||||||
|
|
||||||
Locking
|
|
||||||
-------
|
|
||||||
|
|
||||||
See generally available literature. In mpv, we use pthread for this.
|
|
||||||
|
|
||||||
Always keep locking clean. Don't skip locking just because it will work "in
|
|
||||||
practice". (See undefined behavior section.) If your use case is simple, you may
|
|
||||||
use C11 atomics (osdep/atomic.h for partial C99 support), but most likely you
|
|
||||||
will only hurt yourself and others.
|
|
||||||
|
|
||||||
Always make clear which fields in a struct are protected by which lock. If a
|
|
||||||
field is immutable, or simply not thread-safe (e.g. state for a single worker
|
|
||||||
thread), document it as well.
|
|
||||||
|
|
||||||
Internal mpv APIs are assumed to be not thread-safe by default. If they have
|
|
||||||
special guarantees (such as being usable by more than one thread at a time),
|
|
||||||
these should be explicitly documented.
|
|
||||||
|
|
||||||
All internal mpv APIs must be free of global state. Even if a component is not
|
|
||||||
thread-safe, multiple threads can use _different_ instances of it without any
|
|
||||||
locking.
|
|
||||||
|
|
||||||
On a side note, recursive locks may seem convenient at first, but introduce
|
|
||||||
additional problems with condition variables and locking hierarchies. They
|
|
||||||
should be avoided.
|
|
||||||
|
|
||||||
Locking hierarchy
|
|
||||||
-----------------
|
|
||||||
|
|
||||||
A simple way to avoid deadlocks with classic locking is to define a locking
|
|
||||||
hierarchy or lock order. If all threads acquire locks in the same order, no
|
|
||||||
deadlocks will happen.
|
|
||||||
|
|
||||||
For example, a "leaf" lock is a lock that is below all other locks in the
|
|
||||||
hierarchy. You can acquire it any time, as long as you don't acquire other
|
|
||||||
locks while holding it.
|
|
||||||
|
|
||||||
Unfortunately, C has no way to declare or check the lock order, so you should at
|
|
||||||
least document it.
|
|
||||||
|
|
||||||
In addition, try to avoid exposing locks to the outside. Making the declaration
|
|
||||||
of a lock private to a specific .c file (and _not_ exporting accessors or
|
|
||||||
lock/unlock functions that manipulate the lock) is a good idea. Your component's
|
|
||||||
API may acquire internal locks, but should release them when returning. Keeping
|
|
||||||
the entire locking in a single file makes it easy to check it.
|
|
||||||
|
|
||||||
Avoiding callback hell
|
|
||||||
----------------------
|
|
||||||
|
|
||||||
mpv code is separated in components, like the "frontend" (i.e. MPContext mpctx),
|
|
||||||
VOs, AOs, demuxers, and more. The frontend usually calls "down" the usage
|
|
||||||
hierarchy: mpctx almost on top, then things like vo/ao, and utility code on the
|
|
||||||
very bottom.
|
|
||||||
|
|
||||||
"Callback hell" is when when components call both up and down the hierarchy,
|
|
||||||
which for example leads to accidentally recursion, reentrancy problems, or
|
|
||||||
locking nightmares. This is avoided by (mostly) calling only down the hierarchy.
|
|
||||||
Basically the call graph forms a DAG. The other direction is handled by event
|
|
||||||
queues, wakeup callbacks, and similar mechanisms.
|
|
||||||
|
|
||||||
Typically, a component provides an API, and does not know anything about its
|
|
||||||
user. The API user (component higher in the hierarchy) polls the state of the
|
|
||||||
lower component when needed.
|
|
||||||
|
|
||||||
This also enforces some level of modularization, and with some luck the locking
|
|
||||||
hierarchy. (Basically, locks of lower components automatically become leaf
|
|
||||||
locks.) Another positive effect is simpler memory management.
|
|
||||||
|
|
||||||
(Also see e.g.: http://250bpm.com/blog:24)
|
|
||||||
|
|
||||||
Wakeup callbacks
|
|
||||||
----------------
|
|
||||||
|
|
||||||
This is a common concept in mpv. Even the public API uses it. It's used when an
|
|
||||||
API has internal threads (or otherwise triggers asynchronous events), but the
|
|
||||||
component call hierarchy needs to be kept. The wakeup callback is the only
|
|
||||||
exception to the call hierarchy, and always calls up.
|
|
||||||
|
|
||||||
For example, vo spawns a thread that the API user (the mpv frontend) does not
|
|
||||||
need to know about. vo simply provides a single-threaded API (or that looks like
|
|
||||||
one). This API needs a way to notify the API user of new events. But the vo
|
|
||||||
event producer is on the vo thread - it can't simply invoke a callback back into
|
|
||||||
the API user, because then the API user has to deal with locking, despite not
|
|
||||||
using threads. In addition, this will probably cause problems like mentioned in
|
|
||||||
the "callback hell" section, especially lock order issues.
|
|
||||||
|
|
||||||
The solution is the wakeup callback. It merely unblocks the API user from
|
|
||||||
waiting, and the API user then uses the normal vo API to examine whether or
|
|
||||||
which state changed. As a concept, it documents what a wakeup callback is
|
|
||||||
allowed to do and what not, to avoid the aforementioned problems.
|
|
||||||
|
|
||||||
Generally, you are not allowed to call any API from the wakeup callback. You
|
|
||||||
just do whatever is needed to unblock your thread. For example, if it's waiting
|
|
||||||
on a mutex/condition variable, acquire the mutex, set a change flag, signal
|
|
||||||
the condition variable, unlock, return. (This mutex must not be held when
|
|
||||||
calling the API. It must be a leaf lock.)
|
|
||||||
|
|
||||||
Restricting the wakeup callback like this sidesteps any reentrancy issues and
|
|
||||||
other complexities. The API implementation can simply hold internal (and
|
|
||||||
non-recursive) locks while invoking the wakeup callback.
|
|
||||||
|
|
||||||
The API user still needs to deal with locking (probably), but there's only the
|
|
||||||
need to implement a single "receiver", that can handle the entire API of the
|
|
||||||
used component. (Or multiple APIs - MPContext for example has only 1 wakeup
|
|
||||||
callback that handles all AOs, VOs, input, demuxers, and more. It simple re-runs
|
|
||||||
the playloop.)
|
|
||||||
|
|
||||||
You could get something more advanced by turning this into a message queue. The
|
|
||||||
API would append a message to the queue, and the API user can read it. But then
|
|
||||||
you still need a way to "wakeup" the API user (unless you force the API user
|
|
||||||
to block on your API, which will make things inconvenient for the API user). You
|
|
||||||
also need to worry about what happens if the message queue overruns (you either
|
|
||||||
lose messages or have unbounded memory usage). In the mpv public API, the
|
|
||||||
distinction between message queue and wakeup callback is sort of blurry, because
|
|
||||||
it does provide a message queue, but an additional wakeup callback, so API
|
|
||||||
users are not required to call mpv_wait_event() with a high timeout.
|
|
||||||
|
|
||||||
mpv itself prefers using wakeup callbacks over a generic event queue, because
|
|
||||||
most times an event queue is not needed (or complicates things), and it is
|
|
||||||
better to do it manually.
|
|
||||||
|
|
||||||
(You could still abstract the API user side of wakeup callback handling, and
|
|
||||||
avoid reimplementing it all the time. Although mp_dispatch_queue already
|
|
||||||
provides mechanisms for this.)
|
|
||||||
|
|
||||||
Condition variables
|
|
||||||
-------------------
|
|
||||||
|
|
||||||
They're used whenever a thread needs to wait for something, without nonsense
|
|
||||||
like sleep calls or busy waiting. mpv uses the standard pthread API for this.
|
|
||||||
There's a lot of literature on it. Read it.
|
|
||||||
|
|
||||||
For initial understanding, it may be helpful to know that condition variables
|
|
||||||
are not variables that signal a condition. pthread_cond_t does not have any
|
|
||||||
state per-se. Maybe pthread_cond_t would better be named pthread_interrupt_t,
|
|
||||||
because its sole purpose is to interrupt a thread waiting via pthread_cond_wait()
|
|
||||||
(or similar). The "something" in "waiting for something" can be called
|
|
||||||
predicate (to avoid confusing it with "condition"). Consult literature for the
|
|
||||||
proper terms.
|
|
||||||
|
|
||||||
The very short version is...
|
|
||||||
|
|
||||||
Shared declarations:
|
|
||||||
|
|
||||||
pthread_mutex_t lock;
|
|
||||||
pthread_cond_t cond_var;
|
|
||||||
struct something state_var; // protected by lock, changes signaled by cond_var
|
|
||||||
|
|
||||||
Waiter thread:
|
|
||||||
|
|
||||||
pthread_mutex_lock(&lock);
|
|
||||||
|
|
||||||
// Wait for a change in state_var. We want to wait until predicate_fulfilled()
|
|
||||||
// returns true.
|
|
||||||
// Must be a loop for 2 reasons:
|
|
||||||
// 1. cond_var may be associated with other conditions too
|
|
||||||
// 2. pthread_cond_wait() can have sporadic wakeups
|
|
||||||
while (!predicate_fulfilled(&state_var)) {
|
|
||||||
// This unlocks, waits for cond_var to be signaled, and then locks again.
|
|
||||||
// The _whole_ point of cond_var is that unlocking and waiting for the
|
|
||||||
// signal happens atomically.
|
|
||||||
pthread_cond_wait(&cond_var, &lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Here you may react to the state change. The state cannot change
|
|
||||||
// asynchronously as long as you still hold the lock (and didn't release
|
|
||||||
// and reacquire it).
|
|
||||||
// ...
|
|
||||||
|
|
||||||
pthread_mutex_unlock(&lock);
|
|
||||||
|
|
||||||
Signaler thread:
|
|
||||||
|
|
||||||
pthread_mutex_lock(&lock);
|
|
||||||
|
|
||||||
// Something changed. Update the shared variable with the new state.
|
|
||||||
update_state(&state_var);
|
|
||||||
|
|
||||||
// Notify that something changed. This will wake up the waiter thread if
|
|
||||||
// it's blocked in pthread_cond_wait(). If not, nothing happens.
|
|
||||||
pthread_cond_broadcast(&cond_var);
|
|
||||||
|
|
||||||
// Fun fact: good implementations wake up the waiter only when the lock is
|
|
||||||
// released, to reduce kernel scheduling overhead.
|
|
||||||
pthread_mutex_unlock(&lock);
|
|
||||||
|
|
||||||
Some basic rules:
|
|
||||||
1. Always access your state under proper locking
|
|
||||||
2. Always check your predicate before every call to pthread_cond_wait()
|
|
||||||
(And don't call pthread_cond_wait() if the predicate is fulfilled.)
|
|
||||||
3. Always call pthread_cond_wait() in a loop
|
|
||||||
(And only if your predicate failed without releasing the lock..)
|
|
||||||
4. Always call pthread_cond_broadcast()/_signal() inside of its associated
|
|
||||||
lock
|
|
||||||
|
|
||||||
mpv sometimes violates rule 3, and leaves "retrying" (i.e. looping) to the
|
|
||||||
caller.
|
|
||||||
|
|
||||||
Common pitfalls:
|
|
||||||
- Thinking that pthread_cond_t is some kind of semaphore, or holds any
|
|
||||||
application state or the user predicate (it _only_ wakes up threads
|
|
||||||
that are at the same time blocking on pthread_cond_wait() and friends,
|
|
||||||
nothing else)
|
|
||||||
- Changing the predicate, but not updating all pthread_cond_broadcast()/
|
|
||||||
_signal() calls correctly
|
|
||||||
- Forgetting that pthread_cond_wait() unlocks the lock (other threads can
|
|
||||||
and must acquire the lock)
|
|
||||||
- Holding multiple nested locks while trying to wait (=> deadlock, violates
|
|
||||||
the lock order anyway)
|
|
||||||
- Waiting for a predicate correctly, but unlocking/relocking before acting
|
|
||||||
on it (unlocking allows arbitrary state changes)
|
|
||||||
- Confusing which lock/condition var. is used to manage a bit of state
|
|
||||||
|
|
||||||
Generally available literature probably has better examples and explanations.
|
|
||||||
|
|
||||||
Using condition variables the proper way is generally preferred over using more
|
|
||||||
messy variants of them. (Just saying because on win32, "SetEvent" exists, and
|
|
||||||
it's inferior to condition variables. Try to avoid the win32 primitives, even if
|
|
||||||
you're dealing with Windows-only code.)
|
|
||||||
|
|
||||||
Threads
|
|
||||||
-------
|
|
||||||
|
|
||||||
Threading should be conservatively used. Normally, mpv code pretends to be
|
|
||||||
single-threaded, and provides thread-unsafe APIs. Threads are used coarsely,
|
|
||||||
and if you can avoid messing with threads, you should. For example, VOs and AOs
|
|
||||||
do not need to deal with threads normally, even though they run on separate
|
|
||||||
threads. The glue code "isolates" them from any threading issues.
|
|
||||||
@ -1,4 +0,0 @@
|
|||||||
start=7562.692000
|
|
||||||
volume=52.000000
|
|
||||||
aid=4
|
|
||||||
sid=1
|
|
||||||
@ -10,4 +10,5 @@ def_key "l"
|
|||||||
enter_directory
|
enter_directory
|
||||||
def_key "h"
|
def_key "h"
|
||||||
jump_to_parent_directory
|
jump_to_parent_directory
|
||||||
|
def_key "4"
|
||||||
|
show_lyrics
|
||||||
|
|||||||
@ -375,7 +375,7 @@ song_list_format = {%a - }{%t}|{$8%f$9}$R{$3%l$9}
|
|||||||
#
|
#
|
||||||
## Available values: classic, alternative.
|
## Available values: classic, alternative.
|
||||||
##
|
##
|
||||||
#user_interface = classic
|
user_interface = alternative
|
||||||
#
|
#
|
||||||
#data_fetching_delay = yes
|
#data_fetching_delay = yes
|
||||||
#
|
#
|
||||||
@ -406,7 +406,7 @@ song_list_format = {%a - }{%t}|{$8%f$9}$R{$3%l$9}
|
|||||||
#
|
#
|
||||||
#cyclic_scrolling = no
|
#cyclic_scrolling = no
|
||||||
#
|
#
|
||||||
#lyrics_fetchers = azlyrics, genius, musixmatch, sing365, metrolyrics, justsomelyrics, jahlyrics, plyrics, tekstowo, zeneszoveg, internet
|
lyrics_fetchers = genius
|
||||||
#
|
#
|
||||||
#follow_now_playing_lyrics = no
|
#follow_now_playing_lyrics = no
|
||||||
#
|
#
|
||||||
|
|||||||
@ -1,28 +1,4 @@
|
|||||||
require("user.plugins")
|
|
||||||
|
|
||||||
require("user.themes.kanagawa")
|
|
||||||
vim.cmd("colorscheme kanagawa")
|
|
||||||
|
|
||||||
require("user.options")
|
|
||||||
require("user.keymaps")
|
require("user.keymaps")
|
||||||
|
require("user.options")
|
||||||
|
|
||||||
require("user.cmp")
|
require("user.lazy")
|
||||||
require("user.lsp")
|
|
||||||
require("user.lsp_format")
|
|
||||||
require("user.nvim_navic")
|
|
||||||
require("user.treesitter")
|
|
||||||
require("user.blank_indent_highlight")
|
|
||||||
require("user.autopairs")
|
|
||||||
require("user.telescope")
|
|
||||||
-- require("user.neoscroll")
|
|
||||||
-- require("user.bufferline")
|
|
||||||
require("user.dropbar")
|
|
||||||
require("user.nvim_scrollbar")
|
|
||||||
require("user.gitsigns")
|
|
||||||
-- require("user.lualine")
|
|
||||||
require("user.dap.dapui")
|
|
||||||
require("user.dap.dap")
|
|
||||||
require("user.neotree")
|
|
||||||
-- require("user.oil")
|
|
||||||
require("user.which_key")
|
|
||||||
require("user.harpoon")
|
|
||||||
|
|||||||
@ -1,33 +0,0 @@
|
|||||||
-- Setup nvim-cmp.
|
|
||||||
local status_ok, npairs = pcall(require, "nvim-autopairs")
|
|
||||||
if not status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
npairs.setup {
|
|
||||||
check_ts = true,
|
|
||||||
ts_config = {
|
|
||||||
lua = { "string", "source" },
|
|
||||||
javascript = { "string", "template_string" },
|
|
||||||
java = false,
|
|
||||||
},
|
|
||||||
disable_filetype = { "TelescopePrompt", "spectre_panel" },
|
|
||||||
fast_wrap = {
|
|
||||||
map = "<M-e>",
|
|
||||||
chars = { "{", "[", "(", '"', "'" },
|
|
||||||
pattern = string.gsub([[ [%'%"%)%>%]%)%}%,] ]], "%s+", ""),
|
|
||||||
offset = 0, -- Offset from pattern match
|
|
||||||
end_key = "$",
|
|
||||||
keys = "qwertyuiopzxcvbnmasdfghjkl",
|
|
||||||
check_comma = true,
|
|
||||||
highlight = "PmenuSel",
|
|
||||||
highlight_grey = "LineNr",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
local cmp_autopairs = require "nvim-autopairs.completion.cmp"
|
|
||||||
local cmp_status_ok, cmp = pcall(require, "cmp")
|
|
||||||
if not cmp_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
cmp.event:on("confirm_done", cmp_autopairs.on_confirm_done { map_char = { tex = "" } })
|
|
||||||
@ -1,7 +0,0 @@
|
|||||||
require("ibl").setup({
|
|
||||||
scope = {
|
|
||||||
enabled = true,
|
|
||||||
show_start = false,
|
|
||||||
show_end = false,
|
|
||||||
},
|
|
||||||
})
|
|
||||||
@ -1,37 +0,0 @@
|
|||||||
local status_ok, bufferline = pcall(require, "bufferline")
|
|
||||||
|
|
||||||
if not status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
bufferline.setup({
|
|
||||||
options = {
|
|
||||||
mode = "tabs",
|
|
||||||
offsets = {
|
|
||||||
{ filetype = "NvimTree", text = "", padding = 1 },
|
|
||||||
{ filetype = "neo-tree", text = "", padding = 1 },
|
|
||||||
},
|
|
||||||
style_preset = bufferline.style_preset.minimal,
|
|
||||||
buffer_close_icon = "",
|
|
||||||
modified_icon = "",
|
|
||||||
close_icon = "",
|
|
||||||
max_name_length = 14,
|
|
||||||
max_prefix_length = 13,
|
|
||||||
tab_size = 20,
|
|
||||||
separator_style = { "", "" },
|
|
||||||
hover = {
|
|
||||||
enabled = true,
|
|
||||||
delay = 200,
|
|
||||||
reveal = { 'close' }
|
|
||||||
}
|
|
||||||
|
|
||||||
-- indicator = {
|
|
||||||
-- style = "underline"
|
|
||||||
-- },
|
|
||||||
-- highlights = {
|
|
||||||
-- tab_separator_selected = {
|
|
||||||
-- underline = "0xc8c093",
|
|
||||||
-- },
|
|
||||||
-- }
|
|
||||||
},
|
|
||||||
})
|
|
||||||
@ -1,128 +0,0 @@
|
|||||||
local cmp_status_ok, cmp = pcall(require, "cmp")
|
|
||||||
if not cmp_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
local snip_status_ok, luasnip = pcall(require, "luasnip")
|
|
||||||
if not snip_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
require("luasnip/loaders/from_vscode").lazy_load()
|
|
||||||
|
|
||||||
local check_backspace = function()
|
|
||||||
local col = vim.fn.col "." - 1
|
|
||||||
return col == 0 or vim.fn.getline("."):sub(col, col):match "%s"
|
|
||||||
end
|
|
||||||
|
|
||||||
local cmp_kinds = {
|
|
||||||
Text = ' ',
|
|
||||||
Method = ' ',
|
|
||||||
Function = ' ',
|
|
||||||
Constructor = ' ',
|
|
||||||
Field = ' ',
|
|
||||||
Variable = ' ',
|
|
||||||
Class = ' ',
|
|
||||||
Interface = ' ',
|
|
||||||
Module = ' ',
|
|
||||||
Property = ' ',
|
|
||||||
Unit = ' ',
|
|
||||||
Value = ' ',
|
|
||||||
Enum = ' ',
|
|
||||||
Keyword = ' ',
|
|
||||||
Snippet = ' ',
|
|
||||||
Color = ' ',
|
|
||||||
File = ' ',
|
|
||||||
Reference = ' ',
|
|
||||||
Folder = ' ',
|
|
||||||
EnumMember = ' ',
|
|
||||||
Constant = ' ',
|
|
||||||
Struct = ' ',
|
|
||||||
Event = ' ',
|
|
||||||
Operator = ' ',
|
|
||||||
TypeParameter = ' ',
|
|
||||||
}
|
|
||||||
|
|
||||||
cmp.setup {
|
|
||||||
snippet = {
|
|
||||||
expand = function(args)
|
|
||||||
luasnip.lsp_expand(args.body) -- For `luasnip` users.
|
|
||||||
end,
|
|
||||||
},
|
|
||||||
mapping = {
|
|
||||||
["<C-k>"] = cmp.mapping.select_prev_item(),
|
|
||||||
["<C-j>"] = cmp.mapping.select_next_item(),
|
|
||||||
["<C-b>"] = cmp.mapping(cmp.mapping.scroll_docs(-1), { "i", "c" }),
|
|
||||||
["<C-f>"] = cmp.mapping(cmp.mapping.scroll_docs(1), { "i", "c" }),
|
|
||||||
["<C-Space>"] = cmp.mapping(cmp.mapping.complete(), { "i", "c" }),
|
|
||||||
["<C-y>"] = cmp.config.disable, -- Specify `cmp.config.disable` if you want to remove the default `<C-y>` mapping.
|
|
||||||
["<C-e>"] = cmp.mapping {
|
|
||||||
i = cmp.mapping.abort(),
|
|
||||||
c = cmp.mapping.close(),
|
|
||||||
},
|
|
||||||
-- Accept currently selected item. If none selected, `select` first item.
|
|
||||||
-- Set `select` to `false` to only confirm explicitly selected items.
|
|
||||||
["<CR>"] = cmp.mapping.confirm { select = false },
|
|
||||||
["<Tab>"] = cmp.mapping(function(fallback)
|
|
||||||
if cmp.visible() then
|
|
||||||
cmp.select_next_item()
|
|
||||||
elseif luasnip.expandable() then
|
|
||||||
luasnip.expand()
|
|
||||||
elseif luasnip.expand_or_jumpable() then
|
|
||||||
luasnip.expand_or_jump()
|
|
||||||
elseif check_backspace() then
|
|
||||||
fallback()
|
|
||||||
else
|
|
||||||
fallback()
|
|
||||||
end
|
|
||||||
end, {
|
|
||||||
"i",
|
|
||||||
"s",
|
|
||||||
}),
|
|
||||||
["<S-Tab>"] = cmp.mapping(function(fallback)
|
|
||||||
if cmp.visible() then
|
|
||||||
cmp.select_prev_item()
|
|
||||||
elseif luasnip.jumpable(-1) then
|
|
||||||
luasnip.jump(-1)
|
|
||||||
else
|
|
||||||
fallback()
|
|
||||||
end
|
|
||||||
end, {
|
|
||||||
"i",
|
|
||||||
"s",
|
|
||||||
}),
|
|
||||||
},
|
|
||||||
formatting = {
|
|
||||||
fields = { "kind", "abbr", "menu" },
|
|
||||||
format = function(entry, vim_item)
|
|
||||||
-- Kind icons
|
|
||||||
vim_item.kind = string.format("%s", cmp_kinds[vim_item.kind])
|
|
||||||
vim_item.menu = ({
|
|
||||||
nvim_lsp = "[LSP]",
|
|
||||||
luasnip = "[Snippet]",
|
|
||||||
buffer = "[Buffer]",
|
|
||||||
path = "[Path]",
|
|
||||||
})[entry.source.name]
|
|
||||||
return vim_item
|
|
||||||
end,
|
|
||||||
},
|
|
||||||
sources = {
|
|
||||||
{ name = "nvim_lsp" },
|
|
||||||
{ name = "luasnip" },
|
|
||||||
{ name = "buffer" },
|
|
||||||
{ name = "path" },
|
|
||||||
},
|
|
||||||
confirm_opts = {
|
|
||||||
behavior = cmp.ConfirmBehavior.Replace,
|
|
||||||
select = false,
|
|
||||||
},
|
|
||||||
window = {
|
|
||||||
documentation = {
|
|
||||||
border = { "╭", "─", "╮", "│", "╯", "─", "╰", "│" },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
experimental = {
|
|
||||||
ghost_text = false,
|
|
||||||
native_menu = false,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
@ -1,81 +0,0 @@
|
|||||||
local dap_status_ok, dap = pcall(require, "dap")
|
|
||||||
if not dap_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
local dapui_status_ok, dapui = pcall(require, "dapui")
|
|
||||||
if not dapui_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
dap.adapters.coreclr = {
|
|
||||||
type = 'executable',
|
|
||||||
command = '/home/nikita/.local/share/nvim/mason/bin/netcoredbg',
|
|
||||||
args = { '--interpreter=vscode' }
|
|
||||||
}
|
|
||||||
|
|
||||||
vim.g.dotnet_build_project = function()
|
|
||||||
local default_path = vim.fn.getcwd() .. '/'
|
|
||||||
if vim.g['dotnet_last_proj_path'] ~= nil then
|
|
||||||
default_path = vim.g['dotnet_last_proj_path']
|
|
||||||
end
|
|
||||||
local path = vim.fn.input('Path to your *proj file', default_path, 'file')
|
|
||||||
vim.g['dotnet_last_proj_path'] = path
|
|
||||||
local cmd = 'dotnet build -c Debug ' .. path .. ' > /dev/null'
|
|
||||||
print('')
|
|
||||||
print('Cmd to execute: ' .. cmd)
|
|
||||||
local f = os.execute(cmd)
|
|
||||||
if f == 0 then
|
|
||||||
print('\nBuild: ✔️ ')
|
|
||||||
else
|
|
||||||
print('\nBuild: ❌ (code: ' .. f .. ')')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
vim.g.dotnet_get_dll_path = function()
|
|
||||||
local request = function()
|
|
||||||
return vim.fn.input('Path to dll', vim.fn.getcwd(), 'file')
|
|
||||||
end
|
|
||||||
|
|
||||||
if vim.g['dotnet_last_dll_path'] == nil then
|
|
||||||
vim.g['dotnet_last_dll_path'] = request()
|
|
||||||
else
|
|
||||||
if vim.fn.confirm('Do you want to change the path to dll?\n' .. vim.g['dotnet_last_dll_path'], '&yes\n&no', 2) == 1 then
|
|
||||||
vim.g['dotnet_last_dll_path'] = request()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return vim.g['dotnet_last_dll_path']
|
|
||||||
end
|
|
||||||
|
|
||||||
local config = {
|
|
||||||
{
|
|
||||||
type = "coreclr",
|
|
||||||
name = "launch - netcoredbg",
|
|
||||||
request = "launch",
|
|
||||||
-- console = "integratedTerminal",
|
|
||||||
cwd = "${workspaceFolder}/src/ClientService.AspNet",
|
|
||||||
launchSettingsFilePath = "${workspaceFolder}/src/ClientService.AspNet/Properties/launchSettings.json",
|
|
||||||
launchSettingsProfile = "ClientService.AspNet",
|
|
||||||
program = function()
|
|
||||||
if vim.fn.confirm('Should I recompile first?', '&yes\n&no', 2) == 1 then
|
|
||||||
vim.g.dotnet_build_project()
|
|
||||||
end
|
|
||||||
return vim.g.dotnet_get_dll_path()
|
|
||||||
end,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
dap.configurations.cs = config
|
|
||||||
|
|
||||||
--Autostart ui when debugging
|
|
||||||
dap.listeners.after.event_initialized["dapui_config"] = function()
|
|
||||||
dapui.open()
|
|
||||||
end
|
|
||||||
-- dap.listeners.before.event_terminated["dapui_config"] = function()
|
|
||||||
-- dapui.close()
|
|
||||||
-- end
|
|
||||||
-- dap.listeners.before.event_exited["dapui_config"] = function()
|
|
||||||
-- dapui.close()
|
|
||||||
-- end
|
|
||||||
@ -1,6 +0,0 @@
|
|||||||
local dapui_status_ok, dapui = pcall(require, "dapui")
|
|
||||||
if not dapui_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
dapui.setup()
|
|
||||||
@ -1,6 +0,0 @@
|
|||||||
local null_ls_status_ok, breadcrumbs = pcall(require, "breadcrumbs")
|
|
||||||
if not null_ls_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
breadcrumbs.setup()
|
|
||||||
@ -1,39 +0,0 @@
|
|||||||
require("gitsigns").setup({
|
|
||||||
signs = {
|
|
||||||
add = { text = "│" },
|
|
||||||
change = { text = "│" },
|
|
||||||
delete = { text = "_" },
|
|
||||||
topdelete = { text = "‾" },
|
|
||||||
changedelete = { text = "~" },
|
|
||||||
untracked = { text = "┆" },
|
|
||||||
},
|
|
||||||
signcolumn = true, -- Toggle with `:Gitsigns toggle_signs`
|
|
||||||
numhl = false, -- Toggle with `:Gitsigns toggle_numhl`
|
|
||||||
linehl = false, -- Toggle with `:Gitsigns toggle_linehl`
|
|
||||||
word_diff = false, -- Toggle with `:Gitsigns toggle_word_diff`
|
|
||||||
watch_gitdir = {
|
|
||||||
interval = 1000,
|
|
||||||
follow_files = true,
|
|
||||||
},
|
|
||||||
attach_to_untracked = true,
|
|
||||||
current_line_blame = false, -- Toggle with `:Gitsigns toggle_current_line_blame`
|
|
||||||
current_line_blame_opts = {
|
|
||||||
virt_text = true,
|
|
||||||
virt_text_pos = "eol", -- 'eol' | 'overlay' | 'right_align'
|
|
||||||
delay = 1000,
|
|
||||||
ignore_whitespace = false,
|
|
||||||
},
|
|
||||||
current_line_blame_formatter = "<author>, <author_time:%Y-%m-%d> - <summary>",
|
|
||||||
sign_priority = 6,
|
|
||||||
update_debounce = 100,
|
|
||||||
status_formatter = nil, -- Use default
|
|
||||||
max_file_length = 40000, -- Disable if file is longer than this (in lines)
|
|
||||||
preview_config = {
|
|
||||||
-- Options passed to nvim_open_win
|
|
||||||
border = "single",
|
|
||||||
style = "minimal",
|
|
||||||
relative = "cursor",
|
|
||||||
row = 0,
|
|
||||||
col = 1,
|
|
||||||
}
|
|
||||||
})
|
|
||||||
@ -1,40 +0,0 @@
|
|||||||
local null_ls_status_ok, harpoon = pcall(require, "harpoon")
|
|
||||||
if not null_ls_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
-- REQUIRED
|
|
||||||
harpoon:setup()
|
|
||||||
-- REQUIRED
|
|
||||||
|
|
||||||
vim.keymap.set("n", "<leader>a", function() harpoon:list():add() end)
|
|
||||||
vim.keymap.set("n", "<leader>hm", function() harpoon.ui:toggle_quick_menu(harpoon:list()) end)
|
|
||||||
|
|
||||||
vim.keymap.set("n", "<C-1>", function() harpoon:list():select(1) end)
|
|
||||||
vim.keymap.set("n", "<C-2>", function() harpoon:list():select(2) end)
|
|
||||||
vim.keymap.set("n", "<C-3>", function() harpoon:list():select(3) end)
|
|
||||||
vim.keymap.set("n", "<C-4>", function() harpoon:list():select(4) end)
|
|
||||||
|
|
||||||
-- Toggle previous & next buffers stored within Harpoon list
|
|
||||||
vim.keymap.set("n", "<leader>hp", function() harpoon:list():prev() end)
|
|
||||||
vim.keymap.set("n", "<leader>hn", function() harpoon:list():next() end)
|
|
||||||
|
|
||||||
local conf = require("telescope.config").values
|
|
||||||
local function toggle_telescope(harpoon_files)
|
|
||||||
local file_paths = {}
|
|
||||||
for _, item in ipairs(harpoon_files.items) do
|
|
||||||
table.insert(file_paths, item.value)
|
|
||||||
end
|
|
||||||
|
|
||||||
require("telescope.pickers").new({}, {
|
|
||||||
prompt_title = "Harpoon",
|
|
||||||
finder = require("telescope.finders").new_table({
|
|
||||||
results = file_paths,
|
|
||||||
}),
|
|
||||||
previewer = conf.file_previewer({}),
|
|
||||||
sorter = conf.generic_sorter({}),
|
|
||||||
}):find()
|
|
||||||
end
|
|
||||||
|
|
||||||
vim.keymap.set("n", "<C-e>", function() toggle_telescope(harpoon:list()) end,
|
|
||||||
{ desc = "Open harpoon window" })
|
|
||||||
@ -1,14 +1,11 @@
|
|||||||
|
vim.g.mapleader = " "
|
||||||
|
vim.g.maplocalleader = " "
|
||||||
|
|
||||||
local opts = { noremap = true, silent = true }
|
local opts = { noremap = true, silent = true }
|
||||||
|
|
||||||
local term_opts = { silent = true }
|
|
||||||
|
|
||||||
local keymap = vim.api.nvim_set_keymap
|
local keymap = vim.api.nvim_set_keymap
|
||||||
|
|
||||||
keymap("", "<Space>", "<Nop>", opts)
|
keymap("", "<Space>", "<Nop>", opts)
|
||||||
|
|
||||||
vim.g.mapleader = " "
|
|
||||||
vim.g.maplocalleader = " "
|
|
||||||
|
|
||||||
--window navigation
|
--window navigation
|
||||||
keymap("n", "<C-h>", "<C-w>h", opts)
|
keymap("n", "<C-h>", "<C-w>h", opts)
|
||||||
keymap("n", "<C-j>", "<C-w>j", opts)
|
keymap("n", "<C-j>", "<C-w>j", opts)
|
||||||
|
|||||||
29
.config/nvim/lua/user/lazy.lua
Normal file
29
.config/nvim/lua/user/lazy.lua
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
local lazypath = vim.fn.stdpath("data") .. "/lazy/lazy.nvim"
|
||||||
|
if not vim.loop.fs_stat(lazypath) then
|
||||||
|
vim.fn.system({
|
||||||
|
"git",
|
||||||
|
"clone",
|
||||||
|
"--filter=blob:none",
|
||||||
|
"https://github.com/folke/lazy.nvim.git",
|
||||||
|
"--branch=stable", -- latest stable release
|
||||||
|
lazypath,
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
vim.opt.rtp:prepend(lazypath)
|
||||||
|
|
||||||
|
local status_ok, lazy = pcall(require, "lazy")
|
||||||
|
if not status_ok then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
lazy.setup(
|
||||||
|
{
|
||||||
|
change_detection = {
|
||||||
|
enabled = false,
|
||||||
|
},
|
||||||
|
spec = {
|
||||||
|
{ import = "user.plugins" },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
)
|
||||||
@ -1,12 +0,0 @@
|
|||||||
local status_ok, mason = pcall(require, "mason")
|
|
||||||
if not status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
mason.setup()
|
|
||||||
|
|
||||||
require("user.lsp.mason_lsp_config")
|
|
||||||
require("user.lsp.diagnostics_config").setup()
|
|
||||||
-- require("user.lsp.none_ls")
|
|
||||||
|
|
||||||
vim.cmd([[ command! Format execute 'lua vim.lsp.buf.format{async=true}' ]])
|
|
||||||
@ -1,7 +0,0 @@
|
|||||||
require("lsp-format").setup {}
|
|
||||||
|
|
||||||
local on_attach = function(client)
|
|
||||||
require "lsp-format".on_attach(client)
|
|
||||||
end
|
|
||||||
|
|
||||||
require "lspconfig".gopls.setup { on_attach = on_attach }
|
|
||||||
@ -1,46 +0,0 @@
|
|||||||
require('lualine').setup {
|
|
||||||
options = {
|
|
||||||
icons_enabled = true,
|
|
||||||
theme = 'kanagawa',
|
|
||||||
component_separators = { left = '', right = ''},
|
|
||||||
section_separators = { left = '', right = ''},
|
|
||||||
disabled_filetypes = {
|
|
||||||
statusline = {},
|
|
||||||
winbar = {},
|
|
||||||
},
|
|
||||||
ignore_focus = {},
|
|
||||||
always_divide_middle = true,
|
|
||||||
globalstatus = true,
|
|
||||||
refresh = {
|
|
||||||
statusline = 1000,
|
|
||||||
tabline = 1000,
|
|
||||||
winbar = 1000,
|
|
||||||
},
|
|
||||||
-- use_mode_colors = false
|
|
||||||
},
|
|
||||||
sections = {
|
|
||||||
lualine_a = {'branch'},
|
|
||||||
-- lualine_b = {'diff', 'diagnostics'},
|
|
||||||
lualine_b = {'diagnostics'},
|
|
||||||
lualine_c = {},
|
|
||||||
-- lualine_x = {'encoding', 'fileformat', 'filetype'},
|
|
||||||
lualine_x = {'encoding', 'fileformat'},
|
|
||||||
lualine_y = {'progress'},
|
|
||||||
lualine_z = {'location'}
|
|
||||||
},
|
|
||||||
inactive_sections = {
|
|
||||||
lualine_a = {},
|
|
||||||
lualine_b = {},
|
|
||||||
lualine_c = {},
|
|
||||||
lualine_x = {},
|
|
||||||
lualine_y = {},
|
|
||||||
lualine_z = {}
|
|
||||||
},
|
|
||||||
tabline = {},
|
|
||||||
winbar = {},
|
|
||||||
inactive_winbar = {},
|
|
||||||
extensions = {}
|
|
||||||
}
|
|
||||||
|
|
||||||
vim.api.nvim_create_autocmd('CursorMoved', {callback=require('lualine').refresh})
|
|
||||||
vim.api.nvim_create_autocmd('ModeChanged', {callback=require('lualine').refresh})
|
|
||||||
@ -1,26 +0,0 @@
|
|||||||
require("neoscroll").setup({
|
|
||||||
-- All these keys will be mapped to their corresponding default scrolling animation
|
|
||||||
mappings = { "<C-u>", "<C-d>", "<C-b>", "<C-f>", "<C-y>", "<C-e>", "zt", "zz", "zb" },
|
|
||||||
hide_cursor = true, -- Hide cursor while scrolling
|
|
||||||
stop_eof = true, -- Stop at <EOF> when scrolling downwards
|
|
||||||
respect_scrolloff = false, -- Stop scrolling when the cursor reaches the scrolloff margin of the file
|
|
||||||
cursor_scrolls_alone = true, -- The cursor will keep on scrolling even if the window cannot scroll further
|
|
||||||
easing_function = nil, -- Default easing function
|
|
||||||
pre_hook = nil, -- Function to run before the scrolling animation starts
|
|
||||||
post_hook = nil,
|
|
||||||
performance_mode = false,
|
|
||||||
})
|
|
||||||
|
|
||||||
-- local t = {}
|
|
||||||
-- -- Syntax: t[keys] = {function, {function arguments}}
|
|
||||||
-- t['<C-u>'] = { 'scroll', { '-vim.wo.scroll', 'true', '250' } }
|
|
||||||
-- t['<C-d>'] = { 'scroll', { 'vim.wo.scroll', 'true', '250' } }
|
|
||||||
-- t['<C-b>'] = { 'scroll', { '-vim.api.nvim_win_get_height(0)', 'true', '450' } }
|
|
||||||
-- t['<C-f>'] = { 'scroll', { 'vim.api.nvim_win_get_height(0)', 'true', '450' } }
|
|
||||||
-- t['<C-y>'] = { 'scroll', { '-0.10', 'false', '100' } }
|
|
||||||
-- t['<C-e>'] = { 'scroll', { '0.10', 'false', '100' } }
|
|
||||||
-- t['zt'] = { 'zt', { '250' } }
|
|
||||||
-- t['zz'] = { 'zz', { '250' } }
|
|
||||||
-- t['zb'] = { 'zb', { '250' } }
|
|
||||||
|
|
||||||
-- require('neoscroll.config').set_mappings(t)
|
|
||||||
@ -1,82 +0,0 @@
|
|||||||
require("neo-tree").setup({
|
|
||||||
enable_diagnostics = false,
|
|
||||||
enable_git_status = true,
|
|
||||||
default_component_configs = {
|
|
||||||
icon = {
|
|
||||||
folder_empty = "",
|
|
||||||
folder_empty_open = "",
|
|
||||||
},
|
|
||||||
git_status = {
|
|
||||||
symbols = {
|
|
||||||
-- Change type
|
|
||||||
added = "", -- or "✚", but this is redundant info if you use git_status_colors on the name
|
|
||||||
modified = "", -- or "", but this is redundant info if you use git_status_colors on the name
|
|
||||||
deleted = "✖", -- this can only be used in the git_status source
|
|
||||||
renamed = "", -- this can only be used in the git_status source
|
|
||||||
-- Status type
|
|
||||||
untracked = "",
|
|
||||||
ignored = "",
|
|
||||||
unstaged = "",
|
|
||||||
staged = "",
|
|
||||||
conflict = "",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
document_symbols = {
|
|
||||||
kinds = {
|
|
||||||
File = { icon = "", hl = "Tag" },
|
|
||||||
Namespace = { icon = "", hl = "Include" },
|
|
||||||
Package = { icon = "", hl = "Label" },
|
|
||||||
Class = { icon = "", hl = "Include" },
|
|
||||||
Property = { icon = "", hl = "@property" },
|
|
||||||
Enum = { icon = "", hl = "@number" },
|
|
||||||
Function = { icon = "", hl = "Function" },
|
|
||||||
String = { icon = "", hl = "String" },
|
|
||||||
Number = { icon = "", hl = "Number" },
|
|
||||||
Array = { icon = "", hl = "Type" },
|
|
||||||
Object = { icon = "", hl = "Type" },
|
|
||||||
Key = { icon = "", hl = "" },
|
|
||||||
Struct = { icon = "", hl = "Type" },
|
|
||||||
Operator = { icon = "", hl = "Operator" },
|
|
||||||
TypeParameter = { icon = "", hl = "Type" },
|
|
||||||
StaticMethod = { icon = " ", hl = "Function" },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
git_status = {
|
|
||||||
symbols = {
|
|
||||||
-- Change type
|
|
||||||
added = "", -- or "✚", but this is redundant info if you use git_status_colors on the name
|
|
||||||
modified = "", -- or "", but this is redundant info if you use git_status_colors on the name
|
|
||||||
deleted = "✖", -- this can only be used in the git_status source
|
|
||||||
renamed = "", -- this can only be used in the git_status source
|
|
||||||
-- Status type
|
|
||||||
untracked = "",
|
|
||||||
ignored = "",
|
|
||||||
unstaged = "",
|
|
||||||
staged = "",
|
|
||||||
conflict = "",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
-- Add this section only if you've configured source selector.
|
|
||||||
source_selector = {
|
|
||||||
sources = {
|
|
||||||
{ source = "filesystem", display_name = " Files " },
|
|
||||||
{ source = "git_status", display_name = " Git " },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
|
|
||||||
event_handlers = {
|
|
||||||
{
|
|
||||||
event = "neo_tree_buffer_enter",
|
|
||||||
handler = function(arg)
|
|
||||||
vim.opt.relativenumber = true
|
|
||||||
end,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
event = "file_open_requested",
|
|
||||||
handler = function()
|
|
||||||
require("neo-tree.command").execute({ action = "close" })
|
|
||||||
end
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})
|
|
||||||
@ -1,13 +0,0 @@
|
|||||||
local nvim_navic_status_ok, nvim_navic = pcall(require, "nvim-navic")
|
|
||||||
if not nvim_navic_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
nvim_navic.setup({
|
|
||||||
lsp = {
|
|
||||||
auto_attach = true,
|
|
||||||
preference = {"pyright", "pylsp"}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- vim.o.winbar = "%t %{%v:lua.require'nvim-navic'.get_location()%}"
|
|
||||||
@ -1,6 +0,0 @@
|
|||||||
local null_ls_status_ok, null_ls = pcall(require, "scrollbar")
|
|
||||||
if not null_ls_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
null_ls.setup()
|
|
||||||
@ -1,24 +0,0 @@
|
|||||||
-- examples for your init.lua
|
|
||||||
|
|
||||||
-- empty setup using defaults
|
|
||||||
|
|
||||||
-- OR setup with some options
|
|
||||||
require("nvim-tree").setup({
|
|
||||||
sort_by = "case_sensitive",
|
|
||||||
view = {
|
|
||||||
adaptive_size = false,
|
|
||||||
width = 22,
|
|
||||||
height = 22,
|
|
||||||
mappings = {
|
|
||||||
list = {
|
|
||||||
{ key = "u", action = "dir_up" },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
renderer = {
|
|
||||||
group_empty = true,
|
|
||||||
},
|
|
||||||
filters = {
|
|
||||||
dotfiles = true,
|
|
||||||
},
|
|
||||||
})
|
|
||||||
@ -1,113 +0,0 @@
|
|||||||
local oil_status_ok, oil = pcall(require, "scrollbar")
|
|
||||||
if not oil_status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
oil.setup({
|
|
||||||
default_file_explorer = false,
|
|
||||||
columns = {
|
|
||||||
"icon",
|
|
||||||
},
|
|
||||||
-- Buffer-local options to use for oil buffers
|
|
||||||
buf_options = {
|
|
||||||
buflisted = false,
|
|
||||||
bufhidden = "hide",
|
|
||||||
},
|
|
||||||
-- Window-local options to use for oil buffers
|
|
||||||
win_options = {
|
|
||||||
wrap = false,
|
|
||||||
signcolumn = "no",
|
|
||||||
cursorcolumn = false,
|
|
||||||
foldcolumn = "0",
|
|
||||||
spell = false,
|
|
||||||
list = false,
|
|
||||||
conceallevel = 3,
|
|
||||||
concealcursor = "nvic",
|
|
||||||
},
|
|
||||||
-- Send deleted files to the trash instead of permanently deleting them (:help oil-trash)
|
|
||||||
delete_to_trash = false,
|
|
||||||
-- Skip the confirmation popup for simple operations (:help oil.skip_confirm_for_simple_edits)
|
|
||||||
skip_confirm_for_simple_edits = false,
|
|
||||||
-- Selecting a new/moved/renamed file or directory will prompt you to save changes first
|
|
||||||
-- (:help prompt_save_on_select_new_entry)
|
|
||||||
prompt_save_on_select_new_entry = true,
|
|
||||||
-- Oil will automatically delete hidden buffers after this delay
|
|
||||||
-- You can set the delay to false to disable cleanup entirely
|
|
||||||
-- Note that the cleanup process only starts when none of the oil buffers are currently displayed
|
|
||||||
cleanup_delay_ms = 2000,
|
|
||||||
lsp_file_methods = {
|
|
||||||
-- Time to wait for LSP file operations to complete before skipping
|
|
||||||
timeout_ms = 1000,
|
|
||||||
-- Set to true to autosave buffers that are updated with LSP willRenameFiles
|
|
||||||
-- Set to "unmodified" to only save unmodified buffers
|
|
||||||
autosave_changes = false,
|
|
||||||
},
|
|
||||||
-- Constrain the cursor to the editable parts of the oil buffer
|
|
||||||
-- Set to `false` to disable, or "name" to keep it on the file names
|
|
||||||
constrain_cursor = "editable",
|
|
||||||
-- Set to true to watch the filesystem for changes and reload oil
|
|
||||||
experimental_watch_for_changes = false,
|
|
||||||
-- Keymaps in oil buffer. Can be any value that `vim.keymap.set` accepts OR a table of keymap
|
|
||||||
-- options with a `callback` (e.g. { callback = function() ... end, desc = "", mode = "n" })
|
|
||||||
-- Additionally, if it is a string that matches "actions.<name>",
|
|
||||||
-- it will use the mapping at require("oil.actions").<name>
|
|
||||||
-- Set to `false` to remove a keymap
|
|
||||||
-- See :help oil-actions for a list of all available actions
|
|
||||||
keymaps = {
|
|
||||||
["g?"] = "actions.show_help",
|
|
||||||
["<CR>"] = "actions.select",
|
|
||||||
["<C-s>"] = { "actions.select", opts = { vertical = true }, desc = "Open the entry in a vertical split" },
|
|
||||||
["<C-h>"] = { "actions.select", opts = { horizontal = true }, desc = "Open the entry in a horizontal split" },
|
|
||||||
["<C-t>"] = { "actions.select", opts = { tab = true }, desc = "Open the entry in new tab" },
|
|
||||||
["<C-p>"] = "actions.preview",
|
|
||||||
["<C-c>"] = "actions.close",
|
|
||||||
["<C-l>"] = "actions.refresh",
|
|
||||||
["-"] = "actions.parent",
|
|
||||||
["_"] = "actions.open_cwd",
|
|
||||||
["`"] = "actions.cd",
|
|
||||||
["~"] = { "actions.cd", opts = { scope = "tab" }, desc = ":tcd to the current oil directory" },
|
|
||||||
["gs"] = "actions.change_sort",
|
|
||||||
["gx"] = "actions.open_external",
|
|
||||||
["g."] = "actions.toggle_hidden",
|
|
||||||
["g\\"] = "actions.toggle_trash",
|
|
||||||
},
|
|
||||||
-- Set to false to disable all of the above keymaps
|
|
||||||
use_default_keymaps = true,
|
|
||||||
view_options = {
|
|
||||||
-- Show files and directories that start with "."
|
|
||||||
show_hidden = false,
|
|
||||||
-- This function defines what is considered a "hidden" file
|
|
||||||
is_hidden_file = function(name, bufnr)
|
|
||||||
return vim.startswith(name, ".")
|
|
||||||
end,
|
|
||||||
-- This function defines what will never be shown, even when `show_hidden` is set
|
|
||||||
is_always_hidden = function(name, bufnr)
|
|
||||||
return false
|
|
||||||
end,
|
|
||||||
-- Sort file names in a more intuitive order for humans. Is less performant,
|
|
||||||
-- so you may want to set to false if you work with large directories.
|
|
||||||
natural_order = true,
|
|
||||||
sort = {
|
|
||||||
-- sort order can be "asc" or "desc"
|
|
||||||
-- see :help oil-columns to see which columns are sortable
|
|
||||||
{ "type", "asc" },
|
|
||||||
{ "name", "asc" },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
-- Configuration for the floating window in oil.open_float
|
|
||||||
float = {
|
|
||||||
-- Padding around the floating window
|
|
||||||
padding = 2,
|
|
||||||
max_width = 0,
|
|
||||||
max_height = 0,
|
|
||||||
border = "rounded",
|
|
||||||
win_options = {
|
|
||||||
winblend = 0,
|
|
||||||
},
|
|
||||||
-- This is the config that will be passed to nvim_open_win.
|
|
||||||
-- Change values here to customize the layout
|
|
||||||
override = function(conf)
|
|
||||||
return conf
|
|
||||||
end,
|
|
||||||
},
|
|
||||||
})
|
|
||||||
@ -16,13 +16,9 @@ vim.opt.tabstop = 2
|
|||||||
vim.opt.shiftwidth = 2
|
vim.opt.shiftwidth = 2
|
||||||
vim.opt.updatetime = 300
|
vim.opt.updatetime = 300
|
||||||
vim.opt.timeoutlen = 2000
|
vim.opt.timeoutlen = 2000
|
||||||
-- vim.opt.ttimeoutlen = 5
|
|
||||||
-- vim.cmd "set notimeout"
|
|
||||||
-- vim.cmd "set ttimeout"
|
|
||||||
vim.opt.signcolumn = "yes:2"
|
vim.opt.signcolumn = "yes:2"
|
||||||
vim.opt.jumpoptions = "stack,view"
|
vim.opt.jumpoptions = "stack,view"
|
||||||
|
|
||||||
vim.opt.keymap = "russian-jcukenwin"
|
|
||||||
vim.opt.iminsert = 0
|
vim.opt.iminsert = 0
|
||||||
vim.opt.imsearch = 0
|
vim.opt.imsearch = 0
|
||||||
|
|
||||||
@ -47,3 +43,5 @@ vim.cmd "au VimLeave * silent! !xmodmap -e 'clear Lock' -e 'keycode 0x42 = Caps_
|
|||||||
|
|
||||||
|
|
||||||
vim.cmd "set cursorline"
|
vim.cmd "set cursorline"
|
||||||
|
--disable startup message
|
||||||
|
vim.cmd "set shortmess+=I"
|
||||||
|
|||||||
@ -1,165 +0,0 @@
|
|||||||
local fn = vim.fn
|
|
||||||
|
|
||||||
local lazypath = vim.fn.stdpath("data") .. "/lazy/lazy.nvim"
|
|
||||||
if not vim.loop.fs_stat(lazypath) then
|
|
||||||
vim.fn.system({
|
|
||||||
"git",
|
|
||||||
"clone",
|
|
||||||
"--filter=blob:none",
|
|
||||||
"https://github.com/folke/lazy.nvim.git",
|
|
||||||
"--branch=stable", -- latest stable release
|
|
||||||
lazypath,
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
vim.opt.rtp:prepend(lazypath)
|
|
||||||
|
|
||||||
local status_ok, lazy = pcall(require, "lazy")
|
|
||||||
if not status_ok then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
lazy.setup({
|
|
||||||
|
|
||||||
"nvim-lua/popup.nvim", -- An implementation of the Popup API from vim in Neovim
|
|
||||||
"nvim-lua/plenary.nvim", -- Useful lua functions used ny lots of plugins
|
|
||||||
"navarasu/onedark.nvim",
|
|
||||||
"windwp/nvim-autopairs",
|
|
||||||
|
|
||||||
"hrsh7th/nvim-cmp", -- The completion plugin
|
|
||||||
"hrsh7th/cmp-buffer", -- buffer completions
|
|
||||||
"hrsh7th/cmp-path", -- path completions
|
|
||||||
"hrsh7th/cmp-cmdline", -- cmdline completions
|
|
||||||
"saadparwaiz1/cmp_luasnip", -- snippet completions
|
|
||||||
"hrsh7th/cmp-nvim-lsp",
|
|
||||||
|
|
||||||
-- snippets
|
|
||||||
"L3MON4D3/LuaSnip", --snippet engine
|
|
||||||
"rafamadriz/friendly-snippets", -- a bunch of snippets to use
|
|
||||||
{ "dsznajder/vscode-es7-javascript-react-snippets", run = "yarn install --frozen-lockfile && yarn compile" },
|
|
||||||
|
|
||||||
-- LSP
|
|
||||||
"williamboman/mason.nvim", -- simple to use language server installer
|
|
||||||
"williamboman/mason-lspconfig.nvim",
|
|
||||||
"neovim/nvim-lspconfig", -- enable LSP
|
|
||||||
"nvim-treesitter/nvim-treesitter-refactor",
|
|
||||||
|
|
||||||
-- file explorer
|
|
||||||
-- {
|
|
||||||
-- 'stevearc/oil.nvim',
|
|
||||||
-- opts = {},
|
|
||||||
-- -- Optional dependencies
|
|
||||||
-- dependencies = { "nvim-tree/nvim-web-devicons" },
|
|
||||||
-- init = function()
|
|
||||||
|
|
||||||
-- end
|
|
||||||
-- },
|
|
||||||
{
|
|
||||||
"nvim-neo-tree/neo-tree.nvim",
|
|
||||||
branch = "v3.x",
|
|
||||||
dependencies = {
|
|
||||||
"nvim-lua/plenary.nvim",
|
|
||||||
"nvim-tree/nvim-web-devicons",
|
|
||||||
"MunifTanjim/nui.nvim",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
,
|
|
||||||
{
|
|
||||||
"akinsho/bufferline.nvim",
|
|
||||||
version = "*",
|
|
||||||
dependencies = { "kyazdani42/nvim-web-devicons" },
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"ThePrimeagen/harpoon",
|
|
||||||
branch = "harpoon2",
|
|
||||||
dependencies = { "nvim-lua/plenary.nvim" },
|
|
||||||
},
|
|
||||||
|
|
||||||
{
|
|
||||||
"folke/zen-mode.nvim",
|
|
||||||
opts = {
|
|
||||||
window = {
|
|
||||||
backdrop = 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
{
|
|
||||||
"nvim-treesitter/nvim-treesitter",
|
|
||||||
run = ":TSUpdate",
|
|
||||||
},
|
|
||||||
|
|
||||||
{
|
|
||||||
"nvimtools/none-ls.nvim",
|
|
||||||
},
|
|
||||||
|
|
||||||
"lukas-reineke/lsp-format.nvim",
|
|
||||||
"Vimjas/vim-python-pep8-indent",
|
|
||||||
|
|
||||||
--telescope
|
|
||||||
"nvim-telescope/telescope.nvim",
|
|
||||||
"nvim-telescope/telescope-media-files.nvim",
|
|
||||||
|
|
||||||
--comment out
|
|
||||||
"tpope/vim-commentary",
|
|
||||||
"lukas-reineke/indent-blankline.nvim",
|
|
||||||
"windwp/nvim-ts-autotag",
|
|
||||||
|
|
||||||
{
|
|
||||||
"rebelot/kanagawa.nvim",
|
|
||||||
lazy = false,
|
|
||||||
priority = 1000,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"folke/which-key.nvim",
|
|
||||||
init = function()
|
|
||||||
vim.o.timeout = true
|
|
||||||
vim.o.timeoutlen = 500
|
|
||||||
end,
|
|
||||||
lazy = false,
|
|
||||||
},
|
|
||||||
|
|
||||||
--scrollbar
|
|
||||||
"petertriho/nvim-scrollbar",
|
|
||||||
|
|
||||||
--heirline statusbar
|
|
||||||
"rebelot/heirline.nvim",
|
|
||||||
|
|
||||||
--heirline statusbar
|
|
||||||
"lewis6991/gitsigns.nvim",
|
|
||||||
|
|
||||||
--debugging
|
|
||||||
"mfussenegger/nvim-dap",
|
|
||||||
{
|
|
||||||
"rcarriga/nvim-dap-ui",
|
|
||||||
dependencies = {
|
|
||||||
"mfussenegger/nvim-dap",
|
|
||||||
"nvim-neotest/nvim-nio"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
"nvim-lualine/lualine.nvim",
|
|
||||||
|
|
||||||
"folke/neodev.nvim",
|
|
||||||
"MunifTanjim/nui.nvim",
|
|
||||||
"b0o/schemastore.nvim",
|
|
||||||
-- {
|
|
||||||
-- 'Bekaboo/dropbar.nvim',
|
|
||||||
-- -- optional, but required for fuzzy finder support
|
|
||||||
-- dependencies = {
|
|
||||||
-- 'nvim-telescope/telescope-fzf-native.nvim'
|
|
||||||
-- }
|
|
||||||
-- },
|
|
||||||
{
|
|
||||||
"LunarVim/breadcrumbs.nvim",
|
|
||||||
dependencies = {
|
|
||||||
{ "SmiteshP/nvim-navic" },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
-- {
|
|
||||||
-- "SmiteshP/nvim-navic",
|
|
||||||
-- },
|
|
||||||
{
|
|
||||||
"karb94/neoscroll.nvim",
|
|
||||||
},
|
|
||||||
})
|
|
||||||
31
.config/nvim/lua/user/plugins/autopairs.lua
Normal file
31
.config/nvim/lua/user/plugins/autopairs.lua
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
return {
|
||||||
|
"windwp/nvim-autopairs",
|
||||||
|
event = "VeryLazy",
|
||||||
|
opts = {
|
||||||
|
check_ts = true,
|
||||||
|
ts_config = {
|
||||||
|
lua = { "string", "source" },
|
||||||
|
javascript = { "string", "template_string" },
|
||||||
|
java = false,
|
||||||
|
},
|
||||||
|
disable_filetype = { "TelescopePrompt", "spectre_panel" },
|
||||||
|
fast_wrap = {
|
||||||
|
map = "<M-e>",
|
||||||
|
chars = { "{", "[", "(", '"', "'" },
|
||||||
|
pattern = string.gsub([[ [%'%"%)%>%]%)%}%,] ]], "%s+", ""),
|
||||||
|
offset = 0, -- Offset from pattern match
|
||||||
|
end_key = "$",
|
||||||
|
keys = "qwertyuiopzxcvbnmasdfghjkl",
|
||||||
|
check_comma = true,
|
||||||
|
highlight = "PmenuSel",
|
||||||
|
highlight_grey = "LineNr",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
config = function(_, opts)
|
||||||
|
require("nvim-autopairs").setup(opts)
|
||||||
|
|
||||||
|
local cmp_autopairs = require("nvim-autopairs.completion.cmp")
|
||||||
|
local cmp = require "cmp"
|
||||||
|
cmp.event:on("confirm_done", cmp_autopairs.on_confirm_done { map_char = { tex = "" } })
|
||||||
|
end
|
||||||
|
}
|
||||||
14
.config/nvim/lua/user/plugins/blank_indent_highlight.lua
Normal file
14
.config/nvim/lua/user/plugins/blank_indent_highlight.lua
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
return {
|
||||||
|
"lukas-reineke/indent-blankline.nvim",
|
||||||
|
event = "VeryLazy",
|
||||||
|
opts = {
|
||||||
|
scope = {
|
||||||
|
enabled = true,
|
||||||
|
show_start = false,
|
||||||
|
show_end = false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
config = function (_, _opts)
|
||||||
|
require("ibl").setup(_opts)
|
||||||
|
end
|
||||||
|
}
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user