Compare commits
No commits in common. "94dc8003aa5d5c6598bd9fb232c5717941b1a380" and "e33d2e37c938144e82df7c7195468239531c3a2b" have entirely different histories.
94dc8003aa
...
e33d2e37c9
@ -1 +0,0 @@
|
||||
src
|
147
.gitmodules
vendored
147
.gitmodules
vendored
@ -1,11 +1,11 @@
|
||||
################
|
||||
# note-taking setup
|
||||
################
|
||||
[submodule "src/dot_local/bin/external_pyinstantref"]
|
||||
path = src/dot_local/bin/external_pyinstantref
|
||||
[submodule "src/.local/bin/pyinstantref"]
|
||||
path = src/.local/bin/pyinstantref
|
||||
url = https://github.com/dogeystamp/pyinstantref
|
||||
[submodule "src/dot_local/bin/external_inkscape-shortcut-manager"]
|
||||
path = src/dot_local/bin/external_inkscape-shortcut-manager
|
||||
[submodule "src/.local/bin/inkscape-shortcut-manager"]
|
||||
path = src/.local/bin/inkscape-shortcut-manager
|
||||
url = https://github.com/dogeystamp/inkscape-shortcut-manager
|
||||
|
||||
|
||||
@ -16,151 +16,88 @@
|
||||
|
||||
# prompts
|
||||
# telescope.vim
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_telescope.nvim"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_telescope.nvim
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/telescope.nvim"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/telescope.nvim
|
||||
url = https://github.com/nvim-telescope/telescope.nvim.git
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_plenary.nvim"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_plenary.nvim
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/plenary.nvim"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/plenary.nvim
|
||||
url = https://github.com/nvim-lua/plenary.nvim.git
|
||||
|
||||
# git symbols in the gutter
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_vim-gitgutter"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_vim-gitgutter
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/vim-gitgutter"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/vim-gitgutter
|
||||
url = https://github.com/airblade/vim-gitgutter.git
|
||||
|
||||
# auto close brackets and quotes
|
||||
# coding.vim
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_auto-pairs"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_auto-pairs
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/auto-pairs"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/auto-pairs
|
||||
url = https://github.com/jiangmiao/auto-pairs
|
||||
|
||||
# language smarts
|
||||
# coding.lua
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-lspconfig"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-lspconfig
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/nvim-lspconfig"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/nvim-lspconfig
|
||||
url = https://github.com/neovim/nvim-lspconfig.git
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-cmp"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-cmp
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/nvim-cmp"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/nvim-cmp
|
||||
url = https://github.com/hrsh7th/nvim-cmp.git
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_cmp-nvim-lsp"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_cmp-nvim-lsp
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/cmp-nvim-lsp"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/cmp-nvim-lsp
|
||||
url = https://github.com/hrsh7th/cmp-nvim-lsp.git
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-treesitter"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-treesitter
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/nvim-treesitter"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/nvim-treesitter
|
||||
url = https://github.com/nvim-treesitter/nvim-treesitter.git
|
||||
# intelligent motions based on treesitter
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-treesitter-textobjects"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-treesitter-textobjects
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/nvim-treesitter-textobjects"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/nvim-treesitter-textobjects
|
||||
url = https://github.com/nvim-treesitter/nvim-treesitter-textobjects
|
||||
|
||||
# error/warning/info box
|
||||
# coding.lua
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_trouble.nvim"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_trouble.nvim
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/trouble.nvim"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/trouble.nvim
|
||||
url = https://github.com/folke/trouble.nvim
|
||||
|
||||
# aesthetic changes
|
||||
# init.lua
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_dressing.nvim"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_dressing.nvim
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/dressing.nvim"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/dressing.nvim
|
||||
url = https://github.com/stevearc/dressing.nvim.git
|
||||
|
||||
# plain-text-accounting ledger ftplugin
|
||||
# ftplugin/ledger.vim
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_vim-ledger"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/start/external_vim-ledger
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/vim-ledger"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/start/vim-ledger
|
||||
url = https://github.com/ledger/vim-ledger.git
|
||||
|
||||
# color theme
|
||||
# init.lua
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-noirbuddy"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-noirbuddy
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/nvim-noirbuddy"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/nvim-noirbuddy
|
||||
url = https://github.com/jesseleite/nvim-noirbuddy.git
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_colorbuddy.nvim"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_colorbuddy.nvim
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/colorbuddy.nvim"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/colorbuddy.nvim
|
||||
url = https://github.com/tjdevries/colorbuddy.nvim.git
|
||||
|
||||
# debug adapter protocol
|
||||
# debugging.lua
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-dap"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-dap
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/nvim-dap"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/nvim-dap
|
||||
url = https://github.com/mfussenegger/nvim-dap.git
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-dap-ui"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-dap-ui
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/nvim-dap-ui"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/nvim-dap-ui
|
||||
url = https://github.com/rcarriga/nvim-dap-ui.git
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-nio"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-nio
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/nvim-nio"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/nvim-nio
|
||||
url = https://github.com/nvim-neotest/nvim-nio
|
||||
|
||||
# snippet support
|
||||
# snippets.lua
|
||||
# (also coding.lua becuase nvim-cmp uses this too)
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_LuaSnip"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_LuaSnip
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/LuaSnip"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/LuaSnip
|
||||
url = https://github.com/L3MON4D3/LuaSnip
|
||||
[submodule "src/dot_local/share/nvim/site/pack/3pp/start/external_cmp_luasnip"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_cmp_luasnip
|
||||
url = https://github.com/saadparwaiz1/cmp_luasnip
|
||||
[submodule "submodule.src/dot_local/bin/external_pyinstantref.path"]
|
||||
path = src/dot_local/bin/external_pyinstantref
|
||||
url = https://github.com/dogeystamp/pyinstantref
|
||||
[submodule "submodule.src/dot_local/bin/external_inkscape-shortcut-manager.path"]
|
||||
path = src/dot_local/bin/external_inkscape-shortcut-manager
|
||||
url = https://github.com/dogeystamp/inkscape-shortcut-manager
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_telescope.nvim.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_telescope.nvim
|
||||
url = https://github.com/nvim-telescope/telescope.nvim.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_plenary.nvim.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_plenary.nvim
|
||||
url = https://github.com/nvim-lua/plenary.nvim.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_vim-gitgutter.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_vim-gitgutter
|
||||
url = https://github.com/airblade/vim-gitgutter.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_auto-pairs.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_auto-pairs
|
||||
url = https://github.com/jiangmiao/auto-pairs
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-lspconfig.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-lspconfig
|
||||
url = https://github.com/neovim/nvim-lspconfig.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-cmp.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-cmp
|
||||
url = https://github.com/hrsh7th/nvim-cmp.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_cmp-nvim-lsp.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_cmp-nvim-lsp
|
||||
url = https://github.com/hrsh7th/cmp-nvim-lsp.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-treesitter.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-treesitter
|
||||
url = https://github.com/nvim-treesitter/nvim-treesitter.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-treesitter-textobjects.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-treesitter-textobjects
|
||||
url = https://github.com/nvim-treesitter/nvim-treesitter-textobjects
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_trouble.nvim.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_trouble.nvim
|
||||
url = https://github.com/folke/trouble.nvim
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_dressing.nvim.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_dressing.nvim
|
||||
url = https://github.com/stevearc/dressing.nvim.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_vim-ledger.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/start/external_vim-ledger
|
||||
url = https://github.com/ledger/vim-ledger.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-noirbuddy.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-noirbuddy
|
||||
url = https://github.com/jesseleite/nvim-noirbuddy.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_colorbuddy.nvim.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_colorbuddy.nvim
|
||||
url = https://github.com/tjdevries/colorbuddy.nvim.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-dap.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-dap
|
||||
url = https://github.com/mfussenegger/nvim-dap.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-dap-ui.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-dap-ui
|
||||
url = https://github.com/rcarriga/nvim-dap-ui.git
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_nvim-nio.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_nvim-nio
|
||||
url = https://github.com/nvim-neotest/nvim-nio
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_LuaSnip.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_LuaSnip
|
||||
url = https://github.com/L3MON4D3/LuaSnip
|
||||
[submodule "submodule.src/dot_local/share/nvim/site/pack/3pp/start/external_cmp_luasnip.path"]
|
||||
path = src/dot_local/share/nvim/site/pack/3pp/opt/external_cmp_luasnip
|
||||
[submodule "src/.local/share/nvim/site/pack/3pp/start/cmp_luasnip"]
|
||||
path = src/.local/share/nvim/site/pack/3pp/opt/cmp_luasnip
|
||||
url = https://github.com/saadparwaiz1/cmp_luasnip
|
||||
|
18
README.md
18
README.md
@ -4,19 +4,17 @@ My dotfiles.
|
||||
|
||||
## Installation
|
||||
|
||||
Install [chezmoi](https://chezmoi.io):
|
||||
Clone with submodules (this is necessary for Neovim plugins):
|
||||
|
||||
```
|
||||
# pacman -S chezmoi
|
||||
```bash
|
||||
git clone --recurse-submodules https://github.com/dogeystamp/dots.git
|
||||
# alternatively, after cloning:
|
||||
git submodule init
|
||||
git submodule update
|
||||
```
|
||||
|
||||
Clone then apply these dotfiles:
|
||||
|
||||
```
|
||||
chezmoi init dogeystamp/dotfiles --apply
|
||||
```
|
||||
|
||||
Currently, a legacy `dotinstall.sh` is also available that installs the dotfiles as symlinks.
|
||||
Symlink all the files in src/ to your home directory using the provided dotinstall.sh script, or manually.
|
||||
Otherwise, copy them manually to your home directory.
|
||||
|
||||
After, install some packages. A list is provided in the `programs` file.
|
||||
This list encompasses all packages needed for a full system, including utilities and games.
|
||||
|
1
programs
1
programs
@ -2,7 +2,6 @@
|
||||
# essentials
|
||||
#
|
||||
ttf-jetbrains-mono
|
||||
ttf-jetbrains-mono-nerd
|
||||
wqy-microhei
|
||||
ttf-roboto
|
||||
inter-font
|
||||
|
@ -1 +0,0 @@
|
||||
.bashrc
|
0
src/dot_config/aerc/scripts/executable_wait-pass.sh → src/.config/aerc/scripts/wait-pass.sh
Normal file → Executable file
0
src/dot_config/aerc/scripts/executable_wait-pass.sh → src/.config/aerc/scripts/wait-pass.sh
Normal file → Executable file
@ -3,7 +3,7 @@ padding = { x = 8, y = 8 }
|
||||
opacity = 0.0
|
||||
|
||||
[font]
|
||||
normal = { family = "JetBrainsMono NF" }
|
||||
normal = { family = "JetBrains Mono" }
|
||||
size = 10
|
||||
[colors]
|
||||
[colors.primary]
|
275
src/.config/mpv/scripts/youtube-quality.lua
Normal file
275
src/.config/mpv/scripts/youtube-quality.lua
Normal file
@ -0,0 +1,275 @@
|
||||
-- youtube-quality.lua
|
||||
--
|
||||
-- Change youtube video quality on the fly.
|
||||
--
|
||||
-- Diplays a menu that lets you switch to different ytdl-format settings while
|
||||
-- you're in the middle of a video (just like you were using the web player).
|
||||
--
|
||||
-- Bound to ctrl-f by default.
|
||||
|
||||
local mp = require 'mp'
|
||||
local utils = require 'mp.utils'
|
||||
local msg = require 'mp.msg'
|
||||
local assdraw = require 'mp.assdraw'
|
||||
|
||||
local opts = {
|
||||
--key bindings
|
||||
toggle_menu_binding = "ctrl+f",
|
||||
up_binding = "UP",
|
||||
down_binding = "DOWN",
|
||||
select_binding = "ENTER",
|
||||
|
||||
--formatting / cursors
|
||||
selected_and_active = "▶ - ",
|
||||
selected_and_inactive = "● - ",
|
||||
unselected_and_active = "▷ - ",
|
||||
unselected_and_inactive = "○ - ",
|
||||
|
||||
--font size scales by window, if false requires larger font and padding sizes
|
||||
scale_playlist_by_window=false,
|
||||
|
||||
--playlist ass style overrides inside curly brackets, \keyvalue is one field, extra \ for escape in lua
|
||||
--example {\\fnUbuntu\\fs10\\b0\\bord1} equals: font=Ubuntu, size=10, bold=no, border=1
|
||||
--read http://docs.aegisub.org/3.2/ASS_Tags/ for reference of tags
|
||||
--undeclared tags will use default osd settings
|
||||
--these styles will be used for the whole playlist. More specific styling will need to be hacked in
|
||||
--
|
||||
--(a monospaced font is recommended but not required)
|
||||
style_ass_tags = "{\\fnmonospace}",
|
||||
|
||||
--paddings for top left corner
|
||||
text_padding_x = 5,
|
||||
text_padding_y = 5,
|
||||
|
||||
--other
|
||||
menu_timeout = 10,
|
||||
|
||||
--use youtube-dl to fetch a list of available formats (overrides quality_strings)
|
||||
fetch_formats = true,
|
||||
|
||||
--default menu entries
|
||||
quality_strings=[[
|
||||
[
|
||||
{"4320p" : "bestvideo[height<=?4320p]+bestaudio/best"},
|
||||
{"2160p" : "bestvideo[height<=?2160]+bestaudio/best"},
|
||||
{"1440p" : "bestvideo[height<=?1440]+bestaudio/best"},
|
||||
{"1080p" : "bestvideo[height<=?1080]+bestaudio/best"},
|
||||
{"720p" : "bestvideo[height<=?720]+bestaudio/best"},
|
||||
{"480p" : "bestvideo[height<=?480]+bestaudio/best"},
|
||||
{"360p" : "bestvideo[height<=?360]+bestaudio/best"},
|
||||
{"240p" : "bestvideo[height<=?240]+bestaudio/best"},
|
||||
{"144p" : "bestvideo[height<=?144]+bestaudio/best"}
|
||||
]
|
||||
]],
|
||||
}
|
||||
(require 'mp.options').read_options(opts, "youtube-quality")
|
||||
opts.quality_strings = utils.parse_json(opts.quality_strings)
|
||||
|
||||
local destroyer = nil
|
||||
|
||||
|
||||
function show_menu()
|
||||
local selected = 1
|
||||
local active = 0
|
||||
local current_ytdl_format = mp.get_property("ytdl-format")
|
||||
msg.verbose("current ytdl-format: "..current_ytdl_format)
|
||||
local num_options = 0
|
||||
local options = {}
|
||||
|
||||
|
||||
if opts.fetch_formats then
|
||||
options, num_options = download_formats()
|
||||
end
|
||||
|
||||
if next(options) == nil then
|
||||
for i,v in ipairs(opts.quality_strings) do
|
||||
num_options = num_options + 1
|
||||
for k,v2 in pairs(v) do
|
||||
options[i] = {label = k, format=v2}
|
||||
if v2 == current_ytdl_format then
|
||||
active = i
|
||||
selected = active
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
--set the cursor to the currently format
|
||||
for i,v in ipairs(options) do
|
||||
if v.format == current_ytdl_format then
|
||||
active = i
|
||||
selected = active
|
||||
break
|
||||
end
|
||||
end
|
||||
|
||||
function selected_move(amt)
|
||||
selected = selected + amt
|
||||
if selected < 1 then selected = num_options
|
||||
elseif selected > num_options then selected = 1 end
|
||||
timeout:kill()
|
||||
timeout:resume()
|
||||
draw_menu()
|
||||
end
|
||||
function choose_prefix(i)
|
||||
if i == selected and i == active then return opts.selected_and_active
|
||||
elseif i == selected then return opts.selected_and_inactive end
|
||||
|
||||
if i ~= selected and i == active then return opts.unselected_and_active
|
||||
elseif i ~= selected then return opts.unselected_and_inactive end
|
||||
return "> " --shouldn't get here.
|
||||
end
|
||||
|
||||
function draw_menu()
|
||||
local ass = assdraw.ass_new()
|
||||
|
||||
ass:pos(opts.text_padding_x, opts.text_padding_y)
|
||||
ass:append(opts.style_ass_tags)
|
||||
|
||||
for i,v in ipairs(options) do
|
||||
ass:append(choose_prefix(i)..v.label.."\\N")
|
||||
end
|
||||
|
||||
local w, h = mp.get_osd_size()
|
||||
if opts.scale_playlist_by_window then w,h = 0, 0 end
|
||||
mp.set_osd_ass(w, h, ass.text)
|
||||
end
|
||||
|
||||
function destroy()
|
||||
timeout:kill()
|
||||
mp.set_osd_ass(0,0,"")
|
||||
mp.remove_key_binding("move_up")
|
||||
mp.remove_key_binding("move_down")
|
||||
mp.remove_key_binding("select")
|
||||
mp.remove_key_binding("escape")
|
||||
destroyer = nil
|
||||
end
|
||||
timeout = mp.add_periodic_timer(opts.menu_timeout, destroy)
|
||||
destroyer = destroy
|
||||
|
||||
mp.add_forced_key_binding(opts.up_binding, "move_up", function() selected_move(-1) end, {repeatable=true})
|
||||
mp.add_forced_key_binding(opts.down_binding, "move_down", function() selected_move(1) end, {repeatable=true})
|
||||
mp.add_forced_key_binding(opts.select_binding, "select", function()
|
||||
destroy()
|
||||
mp.set_property("ytdl-format", options[selected].format)
|
||||
reload_resume()
|
||||
end)
|
||||
mp.add_forced_key_binding(opts.toggle_menu_binding, "escape", destroy)
|
||||
|
||||
draw_menu()
|
||||
return
|
||||
end
|
||||
|
||||
local ytdl = {
|
||||
path = "youtube-dl",
|
||||
searched = false,
|
||||
blacklisted = {}
|
||||
}
|
||||
|
||||
format_cache={}
|
||||
function download_formats()
|
||||
local function exec(args)
|
||||
local ret = utils.subprocess({args = args})
|
||||
return ret.status, ret.stdout, ret
|
||||
end
|
||||
|
||||
local function table_size(t)
|
||||
s = 0
|
||||
for i,v in ipairs(t) do
|
||||
s = s+1
|
||||
end
|
||||
return s
|
||||
end
|
||||
|
||||
local url = mp.get_property("path")
|
||||
|
||||
url = string.gsub(url, "ytdl://", "") -- Strip possible ytdl:// prefix.
|
||||
|
||||
-- don't fetch the format list if we already have it
|
||||
if format_cache[url] ~= nil then
|
||||
local res = format_cache[url]
|
||||
return res, table_size(res)
|
||||
end
|
||||
mp.osd_message("fetching available formats with youtube-dl...", 60)
|
||||
|
||||
if not (ytdl.searched) then
|
||||
local ytdl_mcd = mp.find_config_file("youtube-dl")
|
||||
if not (ytdl_mcd == nil) then
|
||||
msg.verbose("found youtube-dl at: " .. ytdl_mcd)
|
||||
ytdl.path = ytdl_mcd
|
||||
end
|
||||
ytdl.searched = true
|
||||
end
|
||||
|
||||
local command = {ytdl.path, "--no-warnings", "--no-playlist", "-J"}
|
||||
table.insert(command, url)
|
||||
local es, json, result = exec(command)
|
||||
|
||||
if (es < 0) or (json == nil) or (json == "") then
|
||||
mp.osd_message("fetching formats failed...", 1)
|
||||
msg.error("failed to get format list: " .. err)
|
||||
return {}, 0
|
||||
end
|
||||
|
||||
local json, err = utils.parse_json(json)
|
||||
|
||||
if (json == nil) then
|
||||
mp.osd_message("fetching formats failed...", 1)
|
||||
msg.error("failed to parse JSON data: " .. err)
|
||||
return {}, 0
|
||||
end
|
||||
|
||||
res = {}
|
||||
msg.verbose("youtube-dl succeeded!")
|
||||
for i,v in ipairs(json.formats) do
|
||||
if v.vcodec ~= "none" then
|
||||
local fps = v.fps and v.fps.."fps" or ""
|
||||
local resolution = string.format("%sx%s", v.width, v.height)
|
||||
local l = string.format("%-9s %-5s (%-4s / %s)", resolution, fps, v.ext, v.vcodec)
|
||||
local f = string.format("%s+bestaudio/best", v.format_id)
|
||||
table.insert(res, {label=l, format=f, width=v.width })
|
||||
end
|
||||
end
|
||||
|
||||
table.sort(res, function(a, b) return a.width > b.width end)
|
||||
|
||||
mp.osd_message("", 0)
|
||||
format_cache[url] = res
|
||||
return res, table_size(res)
|
||||
end
|
||||
|
||||
|
||||
-- register script message to show menu
|
||||
mp.register_script_message("toggle-quality-menu",
|
||||
function()
|
||||
if destroyer ~= nil then
|
||||
destroyer()
|
||||
else
|
||||
show_menu()
|
||||
end
|
||||
end)
|
||||
|
||||
-- keybind to launch menu
|
||||
mp.add_key_binding(opts.toggle_menu_binding, "quality-menu", show_menu)
|
||||
|
||||
-- special thanks to reload.lua (https://github.com/4e6/mpv-reload/)
|
||||
function reload_resume()
|
||||
local playlist_pos = mp.get_property_number("playlist-pos")
|
||||
local reload_duration = mp.get_property_native("duration")
|
||||
local time_pos = mp.get_property("time-pos")
|
||||
|
||||
mp.set_property_number("playlist-pos", playlist_pos)
|
||||
|
||||
-- Tries to determine live stream vs. pre-recordered VOD. VOD has non-zero
|
||||
-- duration property. When reloading VOD, to keep the current time position
|
||||
-- we should provide offset from the start. Stream doesn't have fixed start.
|
||||
-- Decent choice would be to reload stream from it's current 'live' positon.
|
||||
-- That's the reason we don't pass the offset when reloading streams.
|
||||
if reload_duration and reload_duration > 0 then
|
||||
local function seeker()
|
||||
mp.commandv("seek", time_pos, "absolute")
|
||||
mp.unregister_event(seeker)
|
||||
end
|
||||
mp.register_event("file-loaded", seeker)
|
||||
end
|
||||
end
|
11
src/.config/msmtp/config
Normal file
11
src/.config/msmtp/config
Normal file
@ -0,0 +1,11 @@
|
||||
account mail
|
||||
host disroot.org
|
||||
port 587
|
||||
protocol smtp
|
||||
auth on
|
||||
user dogeystamp@disroot.org
|
||||
from dogeystamp@disroot.org
|
||||
tls on
|
||||
tls_starttls on
|
||||
tls_trust_file /etc/ssl/certs/ca-certificates.crt
|
||||
passwordeval "pass msg/mail/dogeystamp@disroot.org"
|
40
src/.config/ncmpcpp/bindings
Normal file
40
src/.config/ncmpcpp/bindings
Normal file
@ -0,0 +1,40 @@
|
||||
def_key "t"
|
||||
find
|
||||
def_key "t"
|
||||
find_item_forward
|
||||
|
||||
def_key "+"
|
||||
show_clock
|
||||
def_key "="
|
||||
volume_up
|
||||
|
||||
def_key "j"
|
||||
scroll_down
|
||||
def_key "k"
|
||||
scroll_up
|
||||
|
||||
def_key "ctrl-u"
|
||||
page_up
|
||||
#push_characters "kkkkkkkkkkkkkkk"
|
||||
def_key "ctrl-d"
|
||||
page_down
|
||||
#push_characters "jjjjjjjjjjjjjjj"
|
||||
|
||||
def_key "h"
|
||||
previous_column
|
||||
def_key "l"
|
||||
next_column
|
||||
|
||||
def_key "."
|
||||
show_lyrics
|
||||
|
||||
def_key "n"
|
||||
next_found_item
|
||||
def_key "N"
|
||||
previous_found_item
|
||||
|
||||
# not used but bound
|
||||
def_key "J"
|
||||
move_sort_order_down
|
||||
def_key "K"
|
||||
move_sort_order_up
|
92
src/.config/ncmpcpp/config
Normal file
92
src/.config/ncmpcpp/config
Normal file
@ -0,0 +1,92 @@
|
||||
##
|
||||
# Files
|
||||
mpd_music_dir = "~/med/mus"
|
||||
lyrics_directory = ~/.cache/lyrics
|
||||
ncmpcpp_directory = ~/.config/ncmpcpp
|
||||
mpd_host = "localhost"
|
||||
mpd_port = "6600"
|
||||
mpd_connection_timeout = "5"
|
||||
mpd_crossfade_time = "2"
|
||||
|
||||
# Playlist
|
||||
playlist_disable_highlight_delay = "0"
|
||||
playlist_display_mode = "columns"
|
||||
playlist_show_remaining_time = "yes"
|
||||
|
||||
browser_display_mode = "columns"
|
||||
autocenter_mode = "yes"
|
||||
fancy_scrolling = "yes"
|
||||
follow_now_playing_lyrics = "yes"
|
||||
display_screens_numbers_on_start = "yes"
|
||||
ignore_leading_the = "yes"
|
||||
lyrics_database = "1"
|
||||
song_columns_list_format = "(10)[blue]{l} (30)[green]{a} (30)[magenta]{b} (50)[yellow]{t}"
|
||||
colors_enabled = "yes"
|
||||
main_window_color = "white"
|
||||
main_window_highlight_color = "blue"
|
||||
header_window_color = "cyan"
|
||||
volume_color = "red"
|
||||
progressbar_color = "cyan"
|
||||
statusbar_color = "white"
|
||||
active_column_color = "cyan"
|
||||
active_window_border = "blue"
|
||||
|
||||
alternative_header_first_line_format = "$0$aqqu$/a {$7%a - $9}{$5%t$9}|{$8%f$9} $0$atqq$/a$9"
|
||||
alternative_header_second_line_format = "{{$6%b$9}{ [$6%y$9]}}|{%D}"
|
||||
song_list_format = "{$3%n │ $9}{$7%a - $9}{$5%t$9}|{$8%f$9}$R{$6 │ %b$9}{$3 │ %l$9}"
|
||||
#user_interface = "alternative"
|
||||
user_interface = "classic"
|
||||
default_place_to_search_in = "database"
|
||||
|
||||
|
||||
# visualizer
|
||||
visualizer_fifo_path = "/tmp/mpd.fifo"
|
||||
visualizer_output_name = "my_fifo"
|
||||
visualizer_sync_interval = "10"
|
||||
visualizer_color = white
|
||||
#visualizer_type = "wave" (spectrum/wave)
|
||||
visualizer_type = "wave_filled" (spectrum/wave)
|
||||
visualizer_in_stereo = "yes"
|
||||
visualizer_look = "=|"
|
||||
|
||||
|
||||
## Navigation ##
|
||||
cyclic_scrolling = "yes"
|
||||
header_text_scrolling = "yes"
|
||||
jump_to_now_playing_song_at_start = "yes"
|
||||
lines_scrolled = "2"
|
||||
|
||||
## Other ##
|
||||
system_encoding = "utf-8"
|
||||
regular_expressions = "extended"
|
||||
|
||||
|
||||
|
||||
## Selected tracks ##
|
||||
selected_item_prefix = "* "
|
||||
discard_colors_if_item_is_selected = "no"
|
||||
|
||||
## Seeking ##
|
||||
incremental_seeking = "yes"
|
||||
seek_time = "1"
|
||||
|
||||
## Visivility ##
|
||||
header_visibility = "yes"
|
||||
statusbar_visibility = "yes"
|
||||
titles_visibility = "yes"
|
||||
|
||||
|
||||
progressbar_look = "=>-"
|
||||
progressbar_elapsed_color = "white"
|
||||
|
||||
now_playing_prefix = "> "
|
||||
song_status_format = " $2%a $4⟫$3⟫ $8%t $4⟫$3⟫ $5%b "
|
||||
autocenter_mode = "yes"
|
||||
centered_cursor = "yes"
|
||||
|
||||
# Misc
|
||||
display_bitrate = "yes"
|
||||
# enable_window_title = "no"
|
||||
follow_now_playing_lyrics = "yes"
|
||||
ignore_leading_the = "yes"
|
||||
empty_tag_marker = ""
|
0
src/dot_config/nvim/init.vim → src/.config/nvim/init.vim
Normal file → Executable file
0
src/dot_config/nvim/init.vim → src/.config/nvim/init.vim
Normal file → Executable file
@ -102,11 +102,25 @@ require("nvim-treesitter.configs").setup {
|
||||
------
|
||||
vim.cmd.packadd("trouble.nvim")
|
||||
require('trouble').setup({
|
||||
auto_preview = false,
|
||||
-- default config available at https://github.com/folke/trouble.nvim
|
||||
icons = false,
|
||||
fold_open = "v", -- icon used for open folds
|
||||
fold_closed = ">", -- icon used for closed folds
|
||||
indent_lines = false, -- add an indent guide below the fold icons
|
||||
signs = {
|
||||
-- icons / text used for a diagnostic
|
||||
error = "error",
|
||||
warning = "warn",
|
||||
hint = "hint",
|
||||
information = "info"
|
||||
},
|
||||
use_diagnostic_signs = false -- enabling this will use the signs defined in your lsp client
|
||||
})
|
||||
keymap("<leader>dxx", "<cmd>Trouble diagnostics toggle<cr>")
|
||||
keymap("gR", "<cmd>Trouble lsp_references toggle<cr>")
|
||||
keymap("<leader>dxx", "<cmd>TroubleToggle<cr>")
|
||||
keymap("<leader>dxw", "<cmd>TroubleToggle workspace_diagnostics<cr>")
|
||||
keymap("<leader>dxd", "<cmd>TroubleToggle document_diagnostics<cr>")
|
||||
keymap("<leader>dxq", "<cmd>TroubleToggle quickfix<cr>")
|
||||
keymap("<leader>dxl", "<cmd>TroubleToggle loclist<cr>")
|
||||
keymap("gR", "<cmd>TroubleToggle lsp_references<cr>")
|
||||
|
||||
|
||||
|
@ -4,7 +4,7 @@
|
||||
--------------------------------
|
||||
--------------------------------
|
||||
|
||||
vim.o.guifont = "JetBrainsMono NF:h10"
|
||||
vim.o.guifont = "JetBrains Mono:h10"
|
||||
|
||||
if vim.g.neovide then
|
||||
local confutil = require("confutil")
|
0
src/dot_config/sxiv/exec/executable_key-handler → src/.config/sxiv/exec/key-handler
Normal file → Executable file
0
src/dot_config/sxiv/exec/executable_key-handler → src/.config/sxiv/exec/key-handler
Normal file → Executable file
Before Width: | Height: | Size: 6.4 KiB After Width: | Height: | Size: 6.4 KiB |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user