Compare commits

...

11 Commits

Author SHA1 Message Date
9936e4bd76 chore(config): reorg of mini plugins
Signed-off-by: Ismo Vuorinen <ismo@ivuorinen.net>
2025-04-29 18:08:23 +03:00
c3a45e2653 chore(deps): update Brewfile
Signed-off-by: Ismo Vuorinen <ismo@ivuorinen.net>
2025-04-29 18:08:00 +03:00
506360a027 chore(config): fish: config cleanup, fixes
Signed-off-by: Ismo Vuorinen <ismo@ivuorinen.net>
2025-04-29 18:07:50 +03:00
github-actions[bot]
00074ec3ff chore: update pre-commit hooks (#104) 2025-04-28 18:53:17 +03:00
renovate[bot]
7c7daf89ea feat(github-action): update actions/setup-python (v5.5.0 → v5.6.0)
Signed-off-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-04-24 21:49:51 +00:00
renovate[bot]
267c54aa56 chore(deps): update node.js to v22.15.0 (#102) 2025-04-24 09:09:01 +03:00
github-actions[bot]
d72409efc0 chore: update pre-commit hooks (#103) 2025-04-24 08:48:35 +03:00
3d9e0477b0 feat(bin): git-attributes rewrite 2025-04-22 10:11:32 +03:00
cfab48eee0 chore(config): zed config mode change 2025-04-22 10:08:12 +03:00
624920b2ab chore(config): nvim, tmux and wezterm tweaks 2025-04-22 10:07:34 +03:00
github-actions[bot]
fd82f1e36c chore: update pre-commit hooks (#101) 2025-04-21 14:23:31 +03:00
17 changed files with 823 additions and 329 deletions

45
.gitattributes vendored
View File

@@ -1,4 +1,4 @@
## GITATTRIBUTES FOR WEB PROJECTS
## GITATTRIBUTES
#
# These settings are for any web project.
#
@@ -20,20 +20,23 @@
*.bat text eol=crlf
*.cmd text eol=crlf
*.coffee text
*.css text diff=css
*.htm text diff=html
*.html text diff=html
*.css text diff=css eol=lf
*.fish text diff=shell eol=lf
*.htm text diff=html eol=lf
*.html text diff=html eol=lf
*.inc text
*.ini text
*.js text
*.json text
*.jsx text
*.less text
*.lua text diff=lua eol=lf
*.ls text
*.map text -diff
*.od text
*.onlydata text
*.php text diff=php
*.plist text eol=lf
*.pl text
*.ps1 text eol=crlf
*.py text diff=python
@@ -41,15 +44,18 @@
*.sass text
*.scm text
*.scss text diff=css
*.sh text eol=lf
*.sh text eol=lf diff=shell
.husky/* text eol=lf
*.sql text
*.styl text
*.tag text
*.tmux text eol=lf diff=tmux
*.ts text
*.tsx text
*.vim text eol=lf
*.xml text
*.xhtml text diff=html
*.zsh text diff=zsh eol=lf
# Docker
Dockerfile text
@@ -68,6 +74,7 @@ Dockerfile text
AUTHORS text
CHANGELOG text
CHANGES text
CODEOWNERS text
CONTRIBUTING text
COPYING text
copyright text
@@ -105,6 +112,8 @@ TODO text
*.config text
.editorconfig text
.env text
*.env text
*.env.* text
.gitattributes text
.gitconfig text
.htaccess text
@@ -208,15 +217,37 @@ Procfile text
*.gitignore text
*.gitkeep text
.gitattributes export-ignore
.gitattributes text export-ignore
*.gitattributes text export-ignore
.gitmodules text export-ignore
*.gitmodules text export-ignore
**/.gitignore export-ignore
**/.gitkeep export-ignore
# Repo specials
local/bin/* text eol=lf
local/bin/* text eol=lf diff=shell
local/bin/*.md text eol=lf diff=markdown
config/antigen.zsh text
git/* text
**/git/* text
**/alias text
ssh/* text
ssh/shared.d/* text
ssh/local.d/* text
# Auto-generated rules - 2025-04-16 10:28:04
# Shell scripts detected by content
install text eol=lf diff=shell
# File extension-based rules
*.1 text eol=lf
*.applescript text eol=lf
*.d/work-git text eol=lf
*.dirs text eol=lf
*.example text eol=lf
*.itermcolors text eol=lf
*.locale text eol=lf
*.python-version text eol=lf
*.snippets text eol=lf
*.theme text eol=lf
*.yamlfmt text eol=lf

View File

@@ -25,7 +25,7 @@ jobs:
steps:
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
- uses: actions/setup-python@8d9ed9ac5c53483de85588cdf95a591a75ab9f55 # v5.5.0
- uses: actions/setup-python@a26af69be951a213d495a4c3e4e4022e16d87065 # v5.6.0
- run: pip install pre-commit && pre-commit autoupdate

2
.nvmrc
View File

@@ -1 +1 @@
22.14.0
22.15.0

View File

@@ -49,12 +49,12 @@ repos:
- id: actionlint
- repo: https://github.com/renovatebot/pre-commit-hooks
rev: 39.248.1
rev: 39.261.4
hooks:
- id: renovate-config-validator
- repo: https://github.com/JohnnyMorganz/StyLua
rev: v2.0.2
rev: v2.1.0
hooks:
- id: stylua # or stylua-system / stylua-github

View File

@@ -1,22 +0,0 @@
function ___paths_plugin_set_colors
if not set -q ___paths_plugin_colors
set -Ux ___paths_plugin_colors 27e6ff 29e0ff 5cd8ff 77d0ff 8ac8ff 9cbfff afb5ff c5a7ff d99bfe ea8feb f684d5 fe7abd ff73a3 ff708a fa7070 ff708a ff73a3 fe7abd f684d5 ea8feb d99bfe c5a7ff afb5ff 9cbfff 8ac8ff 77d0ff 5cd8ff 29e0ff
end
return 0
end
function _paths_uninstall --on-event paths_uninstall
for i in ___paths_plugin_wrap_color ___paths_plugin_output ___paths_plugin_handle_found_item ___paths_plugin_handle_source ___paths_plugin_cycle_color
functions -e $i
end
set -e ___paths_plugin_colors
set -e ___paths_plugin_current_color
end
function _paths_install --on-event _paths_install
___paths_plugin_set_colors
end
function _paths_update --on-event paths_update
___paths_plugin_set_colors
end

View File

@@ -8,9 +8,6 @@ test -e "$HOME/.config/fish/alias.fish" &&
test -e "$HOME/.config/fish/exports.fish" &&
source "$HOME/.config/fish/exports.fish"
test -e "$HOME/.config/fish/exports.secret.fish" &&
source "$HOME/.config/fish/exports.secret.fish"
test -e "$HOME/.dotfiles/config/fzf/key-bindings.fish" &&
source "$HOME/.dotfiles/config/fzf/key-bindings.fish"

View File

@@ -22,11 +22,6 @@ fish_add_path "$XDG_BIN_HOME"
# Add cargo bin to path
fish_add_path "$XDG_SHARE_HOME/cargo/bin"
# Set Aqua configuration
set -q AQUA_BIN; or set -gx AQUA_BIN "$XDG_DATA_HOME/aquaproj-aqua/bin"
set -q AQUA_CONFIG; or set -gx AQUA_CONFIG "$XDG_CONFIG_HOME/aqua/aqua.yaml"
set -gx PATH $AQUA_BIN $PATH
# NPM/NVM configuration
set -q NVM_DIR; or set -x NVM_DIR "$XDG_DATA_HOME/nvm"
fish_add_path "$NVM_DIR/bin"
@@ -109,7 +104,6 @@ set -q GNUPGHOME; or set -x GNUPGHOME "$XDG_DATA_HOME/gnupg"
# Go configuration
# set -q GOPATH; or set -x GOPATH "$XDG_DATA_HOME/go"
set -q GOBIN; or set -x GOBIN "$XDG_BIN_HOME"
fish_add_path "$GOBIN"
set -q GOENV_ROOT; or set -x GOENV_ROOT "$XDG_DATA_HOME/goenv"
set -q GOENV_RC_FILE; or set -x GOENV_RC_FILE "$XDG_CONFIG_HOME/goenv/goenvrc.fish"
@@ -131,7 +125,6 @@ set -q CARGO_HOME; or set -x CARGO_HOME "$XDG_DATA_HOME/cargo"
set -q CARGO_BIN_HOME; or set -x CARGO_BIN_HOME "$XDG_BIN_HOME"
set -q RUSTUP_HOME; or set -x RUSTUP_HOME "$XDG_DATA_HOME/rustup"
set -x RUST_WITHOUT "clippy,docs,rls"
fish_add_path "$CARGO_BIN_HOME"
fish_add_path "$CARGO_HOME/bin"
fish_add_path "$XDG_SHARE_HOME/bob/nvim-bin"

View File

@@ -2,7 +2,6 @@ jorgebucaran/fisher
ilancosman/tide@v6
jethrokuan/z
halostatue/fish-macos@v7
jgusta/paths
danhper/fish-ssh-agent
halostatue/fish-brew@v3
edc/bass

View File

@@ -1,175 +0,0 @@
function ___paths_plugin_wrap_color
set_color normal
set_color "$argv[1]"
echo -n (set_color "$argv[1]")"$argv[2..]"
set_color normal
end
# duplicated in conf.d
function ___paths_plugin_set_colors
if not set -q ___paths_plugin_colors
set -Ux ___paths_plugin_colors 27e6ff 29e0ff 5cd8ff 77d0ff 8ac8ff 9cbfff afb5ff c5a7ff d99bfe ea8feb f684d5 fe7abd ff73a3 ff708a fa7070 ff708a ff73a3 fe7abd f684d5 ea8feb d99bfe c5a7ff afb5ff 9cbfff 8ac8ff 77d0ff 5cd8ff 29e0ff
end
return 0
end
function ___paths_plugin_cycle_color
if not set -q ___paths_plugin_current_color
set -Ux ___paths_plugin_current_color 1
else if test $___paths_plugin_current_color -gt (count $___paths_plugin_colors)
set -Ux ___paths_plugin_current_color 1
end
echo $___paths_plugin_colors[$___paths_plugin_current_color]
set -Ux ___paths_plugin_current_color (math $___paths_plugin_current_color + 1)
end
function ___paths_plugin_handle_found_item -a testName outFlags
set -f flags (string split -n ' ' -- "$outFlags")
set -f options (fish_opt -s c -l clean)
set -a options (fish_opt -s s -l single)
set -a options (fish_opt -s k -l no-color)
set -a options (fish_opt -s n -l inline)
argparse $options -- $flags
set -f arrow "=>"
# check if file exists
if test -e "$testName"
set -f nameOut (string trim -- "$testName")
if not set -q _flag_c # is not clean
if test -L "$testName" # is symlink
set -f __linkname (readlink -f "$testName")
set __linkname (string trim -- "$__linkname")
set testName (string trim -- "$testName")
if not set -q _flag_k # is color
set nameOut (___paths_plugin_wrap_color (___paths_plugin_cycle_color) $testName) (___paths_plugin_wrap_color "yellow" "$arrow") (___paths_plugin_wrap_color (___paths_plugin_cycle_color) $__linkname)
else # is color
set nameOut (echo -n "$testName" "$arrow" "$__linkname")
end
else # is not symlink
if not set -q _flag_k # is color
set testName (string trim -- "$testName")
set nameOut (___paths_plugin_wrap_color (___paths_plugin_cycle_color) "$testName")
else
set testName (string trim -- "$testName")
set nameOut "$testName"
end
end
set nameOut (string trim -- "$nameOut")
# do the tick
if set -q _flag_k # is not color
set nameOut "- $nameOut"
else # is color
set nameOut (___paths_plugin_wrap_color "yellow" "-") "$nameOut"
end
end
set nameOut (string trim -- "$nameOut")
echo -n $nameOut
end
end
function paths --description "Reveal the executable matches in shell paths or fish autoload."
set -f options (fish_opt -s c -l clean)
set -a options (fish_opt -s s -l single)
set -a options (fish_opt -s k -l no-color)
set -a options (fish_opt -s q -l quiet)
set -a options (fish_opt -s n -l inline)
argparse $options -- $argv
if test (count $argv) -lt 1
echo "paths - executable matches in shell paths or fish autoload."
and echo "usage: paths [-c|-s|-k] <name>"
and echo -e "\t-c or --no-color: output without color"
and echo -e "\t-s or --single: output without color or headers, the first result"
and echo -e "\t-k or --clean: output without tick marks or headers"
# and echo -e "\t-n or --inline: output without endline"
and return 1
end
set -f foundStatus 1
set -f input (string trim -- $argv)
# deprecated
if set -q _flag_q
set _flag_c True
end
if set -q _flag_s
set _flag_k True
set _flag_c True
end
set -f outFlags ''
set -q _flag_n; and set -a outFlags -n
set -q _flag_c; and set -a outFlags -c
set -q _flag_k; and set -a outFlags -k
set -q _flag_s; and set -a outFlags -s
set outFlags (string split -n " " -- "$outFlags")
___paths_plugin_set_colors
# loop over list of path lists
for pVar in VIRTUAL_ENV fisher_path fish_function_path fish_user_paths PATH
set -e acc
set -f acc ''
set -e hit
# see if variable is empty
if test -z "$pVar"
continue
end
set -f acc (begin
for t in $$pVar
for snit in "$t/$input.fish" "$t/$input"
set -f found (___paths_plugin_handle_found_item "$snit" "$outFlags")
set found (string trim -- "$found")
if test -n "$found"
set -f hit True
echo "$found"
if set -q _flag_s
break
end
end
end
if set -q _flag_s
if set -q hit
break
end
end
end
end)
# prepend source
if not set -q _flag_c
if set -q hit
set pVar (string trim -- "$pVar")
echo -e -n "$pVar\n"
end
end
if test -n "$acc"
set foundStatus 0
for fk in $acc
echo $fk
if set -q _flag_s
# stop after one
return $foundStatus
end
end
end
end
# check
set -l built (type --type $input 12&>/dev/null)
if test -n "$built"
and test "$built" = 'builtin'
set $foundStatus 0
if not set -q _flag_c
echo -e -n "builtin\n"
if set -q _flag_k
echo - "$input"
else # is color
echo (___paths_plugin_wrap_color "yellow" "-") (___paths_plugin_wrap_color (___paths_plugin_cycle_color) "$input")
end
else
echo "$input"
end
end
return $foundStatus
end

View File

@@ -89,6 +89,8 @@ brew "coreutils"
brew "bats-core"
# Parser generator
brew "bison"
# Freely available high-quality data compressor
brew "bzip2"
# Software library to render fonts
brew "freetype"
# XML-based font configuration API for X Windows
@@ -222,7 +224,7 @@ brew "nginx"
# Port scanning utility for large networks
brew "nmap"
# Platform built on V8 to build network applications
brew "node"
brew "node", link: false
# Libraries for security-enabled client and server applications
brew "nss"
# Command-line Git information tool
@@ -232,9 +234,9 @@ brew "openldap"
# ISO-C API and CLI for generating UUIDs
brew "ossp-uuid"
# General-purpose scripting language
brew "php"
brew "php", link: false
# General-purpose scripting language
brew "php@8.2"
brew "php@8.2", link: true
# General-purpose scripting language
brew "php@8.3"
# Pins GitHub Actions to full hashes and versions
@@ -259,6 +261,8 @@ brew "re2c"
brew "rustup"
# Static analysis and lint tool, for (ba)sh scripts
brew "shellcheck"
# User interface to the TELNET protocol
brew "telnet"
# Send macOS User Notifications from the command-line
brew "terminal-notifier"
# Tool which checks for the support of TLS/SSL ciphers and flaws
@@ -317,8 +321,6 @@ brew "shivammathur/php/php-debug"
brew "shivammathur/php/php@8.2-debug"
# Command-line interface for 1Password
cask "1password-cli"
# AeroSpace is an i3-like tiling window manager for macOS
cask "aerospace"
# Universal database tool and SQL client
cask "dbeaver-community"
# Database version management tool
@@ -340,8 +342,6 @@ cask "jetbrains-toolbox"
cask "keybase"
# Kubernetes IDE
cask "lens"
# Neovim Client
cask "neovide"
# Reverse proxy, secure introspectable tunnels to localhost
cask "ngrok"
# Simple application that will prevent iTunes or Apple Music from launching

View File

@@ -2,6 +2,7 @@ return {
-- A collection of small QoL plugins for Neovim
-- https://github.com/folke/snacks.nvim
{
---@module 'snacks'
'folke/snacks.nvim',
priority = 1000,
lazy = false,
@@ -42,6 +43,7 @@ return {
-- replaces the UI for messages, cmdline and the popupmenu.
-- https://github.com/folke/noice.nvim
{
---@module 'noice'
'folke/noice.nvim',
event = 'VeryLazy',
dependencies = {
@@ -122,10 +124,12 @@ return {
-- trouble your code is causing.
-- https://github.com/folke/trouble.nvim
{
---@module 'trouble'
'folke/trouble.nvim',
lazy = false,
cmd = 'Trouble',
dependencies = { 'nvim-tree/nvim-web-devicons' },
---@type trouble.Config
opts = {
auto_preview = true,
auto_fold = true,

View File

@@ -12,6 +12,42 @@ return {
version = '*',
priority = 1001,
config = function()
-- ╭─────────────────────────────────────────────────────────╮
-- │ Text editing │
-- ╰─────────────────────────────────────────────────────────╯
-- Better Around/Inside textobjects
-- Examples:
-- - va) - [V]isually select [A]round [)]paren
-- - yinq - [Y]ank [I]nside [N]ext [Q]uote
-- - ci' - [C]hange [I]nside [']quote
require('mini.ai').setup { n_lines = 500 }
-- Comment lines
require('mini.comment').setup()
-- Text edit operators
-- g= - Evaluate text and replace with output
-- gx - Exchange text regions
-- gm - Multiply (duplicate) text
-- gr - Replace text with register
-- gs - Sort text
require('mini.operators').setup()
-- Split and join arguments, lists, and other sequences
require('mini.splitjoin').setup()
-- Fast and feature-rich surround actions
-- - saiw) - [S]urround [A]dd [I]nner [W]ord [)]Paren
-- - sd' - [S]urround [D]elete [']quotes
-- - sr)' - [S]urround [R]eplace [)] [']
-- - sff - find right (`sf`) part of surrounding function call (`f`)
require('mini.surround').setup()
-- ╭─────────────────────────────────────────────────────────╮
-- │ General workflow │
-- ╰─────────────────────────────────────────────────────────╯
-- Presets for common options and mappings
-- h: MiniBasics.config
require('mini.basics').setup {
@@ -25,25 +61,12 @@ return {
},
}
-- Better Around/Inside textobjects
--
-- Examples:
-- - va) - [V]isually select [A]round [)]paren
-- - yinq - [Y]ank [I]nside [N]ext [Q]uote
-- - ci' - [C]hange [I]nside [']quote
require('mini.ai').setup { n_lines = 500 }
-- Animate common Neovim actions
-- Replaced anuvyklack/windows.nvim
require('mini.animate').setup()
-- Buffer removing (unshow, delete, wipeout), which saves window layout
-- Replaced famiu/bufdelete.nvim
require('mini.bufremove').setup()
-- Show next key clues
-- Replaced folke/which-key.nvim
local miniclue = require 'mini.clue'
---@modules mini.clue
miniclue.setup {
window = {
config = {
@@ -108,22 +131,30 @@ return {
},
}
-- Comment lines
-- Replaced numToStr/Comment.nvim
require('mini.comment').setup()
-- Highlight cursor word and its matches
require('mini.cursorword').setup()
-- Work with diff hunks
-- Replaced lewis6991/gitsigns.nvim
require('mini.diff').setup()
-- Git integration
require('mini.git').setup()
-- Session management (read, write, delete)
require('mini.sessions').setup {
autowrite = true,
directory = vim.g.sessions_dir or vim.fn.stdpath 'data' .. '/sessions',
file = '',
}
-- ╭─────────────────────────────────────────────────────────╮
-- │ Appearance │
-- ╰─────────────────────────────────────────────────────────╯
-- Animate common Neovim actions
require('mini.animate').setup()
-- Highlight cursor word and its matches
require('mini.cursorword').setup()
-- Highlight patterns in text
-- Replaced folke/todo-comments.nvim
local hp = require 'mini.hipatterns'
hp.setup {
highlighters = {
@@ -170,36 +201,16 @@ return {
}
-- Visualize and work with indent scope
-- Replaced lukas-reineke/indent-blankline.nvim
require('mini.indentscope').setup()
-- Text edit operators
-- g= - Evaluate text and replace with output
-- gx - Exchange text regions
-- gm - Multiply (duplicate) text
-- gr - Replace text with register
-- gs - Sort text
require('mini.operators').setup()
-- Session management (read, write, delete)
require('mini.sessions').setup {
autowrite = true,
directory = vim.g.sessions_dir or vim.fn.stdpath 'data' .. '/sessions',
file = '',
}
-- Split and join arguments, lists, and other sequences
-- Replaced Wansmer/treesj
require('mini.splitjoin').setup()
-- Fast and flexible start screen
-- Replaced glepnir/dashboard-nvim
local starter = require 'mini.starter'
---@modules mini.starter
starter.setup {
items = {
starter.sections.telescope(),
starter.sections.builtin_actions(),
starter.sections.sessions(5, true),
starter.sections.recent_files(5),
},
content_hooks = {
starter.gen_hook.adding_bullet(),
@@ -209,25 +220,38 @@ return {
}
-- Minimal and fast statusline module with opinionated default look
-- Replaced nvim-lualine/lualine.nvim
local sl = require 'mini.statusline'
---@modules mini.statusline
sl.setup {
use_icons = true,
set_vim_settings = true,
content = {
active = function()
local mode, mode_hl = sl.section_mode { trunc_width = 120 }
local git = sl.section_git { trunc_width = 9999 }
local diagnostics = sl.section_diagnostics { trunc_width = 9999 }
local filename = sl.section_filename { trunc_width = 9999 }
local mode, mode_hl = sl.section_mode { trunc_width = 100 }
local git = sl.section_git { trunc_width = 40 }
local diagnostics = sl.section_diagnostics {
trunc_width = 75,
signs = {
ERROR = 'E ',
WARN = 'W ',
INFO = 'I ',
HINT = 'H ',
},
}
local lsp = MiniStatusline.section_lsp { trunc_width = 75 }
local filename = sl.section_filename { trunc_width = 140 }
local fileinfo = sl.section_fileinfo { trunc_width = 9999 }
local location = sl.section_location { trunc_width = 9999 }
return sl.combine_groups {
{ hl = mode_hl, strings = { mode } },
{ hl = 'statuslineDevinfo', strings = { git, diagnostics } },
{
hl = 'MiniStatuslineDevinfo',
strings = { git, lsp },
},
'%<', -- Mark general truncate point
{ hl = 'statuslineFilename', strings = { filename } },
'%=', -- End left alignment
{ hl = 'statuslineFileinfo', strings = { diagnostics } },
{ hl = 'statuslineFileinfo', strings = { fileinfo } },
{ hl = mode_hl, strings = { location } },
}
@@ -235,13 +259,6 @@ return {
},
}
-- Fast and feature-rich surround actions
-- Replaced kylechui/nvim-surround
-- - saiw) - [S]urround [A]dd [I]nner [W]ord [)]Paren
-- - sd' - [S]urround [D]elete [']quotes
-- - sr)' - [S]urround [R]eplace [)] [']
require('mini.surround').setup()
-- Work with trailing whitespace
require('mini.trailspace').setup()
end,

View File

@@ -52,6 +52,7 @@ if-shell '[ "$DEBUG" = "1" ]' 'set -g debug-file ~/.cache/tmux-debug.log'
set -g pane-active-border-style "fg=#7aa2f7"
set -g pane-border-style "fg=#3b4261"
set -g status-style "bg=default"
set -g status-justify "left"
set -g status-left ''
set -g status-left-length "0"

View File

@@ -17,16 +17,31 @@ config.font = wezterm.font_with_fallback {
'JetBrains Mono',
'Symbols Nerd Font Mono',
}
config.harfbuzz_features = { 'zero', 'ss01', 'cv05' }
config.font_shaper = 'Harfbuzz'
config.harfbuzz_features = { 'calt=1', 'clig=1', 'liga=1' }
-- Make the window a bit transparent
config.window_background_opacity = 0.96
config.selection_word_boundary = ' \t\n{[}]()"\'`,;:'
-- Window configuration
config.window_background_opacity = 0.95
config.window_decorations = 'RESIZE'
config.macos_window_background_blur = 10
config.window_padding = {
left = 5,
right = 5,
top = 5,
bottom = 5,
}
-- Don't show tab bar
config.enable_tab_bar = false
-- Fix alt on macOS
config.send_composed_key_when_left_alt_is_pressed = true
config.send_composed_key_when_right_alt_is_pressed = true
-- Scrolling deactivated, using tmux for that
config.scrollback_lines = 0
-- Function to detect the theme based on appearance
function Scheme_for_appearance(appearance)

View File

@@ -5,7 +5,7 @@
"assistant": {
"default_model": {
"provider": "copilot_chat",
"model": "claude-3-7-sonnet"
"model": "claude-3.7-sonnet-thought"
},
"version": "2"
},

675
local/bin/git-attributes Executable file
View File

@@ -0,0 +1,675 @@
#!/usr/bin/env bash
#
# Check git repo's files .gitattributes and ensure all of them are mapped.
#
# Author: Ismo Vuorinen <https://github.com/ivuorinen> 2022
# License: MIT
set -euo pipefail
# Default configuration
VERBOSE=0
CHECK_PATTERN="text: auto"
EXIT_ON_MISSING=0
SUGGEST_RULES=1 # Suggestions enabled by default
WRITE_RULES=0 # Writing to file is opt-in
FORMAT_WIDTH=0 # Auto-width by default (0 means auto)
MIN_FORMAT_WIDTH=20 # Minimum format width
DEBUG="${DEBUG:-0}"
if [ "$DEBUG" -eq 1 ]; then
set -x
fi
# Output functions
msg_err() {
echo -e "\e[31m$@\e[0m" >&2
}
msg_success() {
echo -e "\e[32m$@\e[0m"
}
msg_warn() {
echo -e "\e[33m$@\e[0m" >&2
}
msg_info() {
echo -e "\e[36m$@\e[0m"
}
msg_debug() {
[[ $VERBOSE -eq 1 ]] && echo -e "\e[35m$@\e[0m"
}
show_help() {
cat << EOF
Usage: $(basename "$0") [OPTIONS]
Check if all git-tracked files have corresponding rules in .gitattributes
Options:
-h, --help Display this help message
-v, --verbose Enable verbose output
-e, --exit Exit with error code if missing attributes found
-p, --pattern Pattern to check (default: "text: auto")
-n, --no-suggest Don't suggest .gitattributes rules (suggestions are on by default)
-w, --write Write suggested rules to .gitattributes file
-f, --format-width Specify width for formatting rule patterns (default: auto, min: $MIN_FORMAT_WIDTH)
EOF
}
# Parse arguments
while [[ $# -gt 0 ]]; do
case "$1" in
-h|--help)
show_help
exit 0
;;
-v|--verbose)
VERBOSE=1
shift
;;
-e|--exit)
EXIT_ON_MISSING=1
shift
;;
-p|--pattern)
CHECK_PATTERN="$2"
shift 2
;;
-n|--no-suggest)
SUGGEST_RULES=0
shift
;;
-w|--write)
WRITE_RULES=1
shift
;;
-f|--format-width)
if [[ $2 =~ ^[0-9]+$ ]]; then
FORMAT_WIDTH=$2
shift 2
else
msg_err "Error: --format-width requires a numeric argument"
exit 1
fi
;;
*)
msg_err "Unknown option: $1"
show_help
exit 1
;;
esac
done
# Function to check if git is installed
check_git_installed() {
if ! command -v git &> /dev/null; then
msg_err "git could not be found, please install it first"
exit 1
fi
}
# Check if we're in a git repository
check_git_repo() {
if ! git rev-parse --is-inside-work-tree &>/dev/null; then
msg_err "Not inside a git repository"
exit 1
fi
}
# Check if we're in the git root directory
check_git_root() {
local git_root
git_root=$(git rev-parse --show-toplevel)
local current_dir
current_dir=$(pwd)
if [[ "$git_root" != "$current_dir" ]]; then
msg_err "Not in git repository root directory"
msg_warn "Please run this command from: $git_root"
exit 1
fi
}
# Check if .gitattributes exists
check_gitattributes_exists() {
if [[ ! -f ".gitattributes" ]]; then
msg_err ".gitattributes file not found in the repository root"
msg_warn "Create a .gitattributes file before running this command"
exit 1
fi
}
# Format rule with proper alignment
format_rule() {
local pattern="$1"
local attributes="$2"
local width="$3"
# If pattern starts with "#", it's a comment, don't format
if [[ "$pattern" == "#"* ]]; then
echo "$pattern"
return
fi
# If pattern is empty, return empty
if [[ -z "$pattern" ]]; then
echo ""
return
fi
printf "%-${width}s %s\n" "$pattern" "$attributes"
}
# Get the file extension properly, handling special cases
get_file_extension() {
local file="$1"
local basename=$(basename "$file")
local extension=""
# Check if file has no extension or is a dotfile
if [[ "$basename" == .* && ! "$basename" =~ \..+$ ]]; then
# It's a dotfile without extension (like .gitignore)
extension="$basename"
elif [[ "$basename" =~ \..+$ ]]; then
# Normal file with extension
extension="${basename##*.}"
# Check for special cases like .d/ directories
if [[ "$extension" == "d" ]]; then
# This is likely a .d directory - use the full filename as pattern
if [[ -f "$file" ]]; then
# For files in .d directories, use the complete path as pattern
extension=$(basename "$file")
else
# For .d directory itself, use *.d
extension="d"
fi
fi
else
# No extension at all
extension="$basename"
fi
echo "$extension"
}
# Suggest appropriate gitattributes rules based on file extension
suggest_rule() {
local file="$1"
local extension=""
local pattern=""
local attributes=""
msg_debug "Checking file: $file"
# Skip directories
if [[ -d "$file" ]]; then
return
fi
# Get proper file extension
extension=$(get_file_extension "$file")
# If file path contains .d/ pattern, we need special handling
if [[ "$file" =~ \.d/ ]]; then
# Extract the pattern part that includes the .d/ directory
local dir_part=$(dirname "$file")
local base_name=$(basename "$file")
# Check if it's a config directory pattern worth capturing
if [[ "$dir_part" =~ /(\.d|[^/]+\.d)$ ]]; then
pattern="$dir_part/*"
msg_debug "Detected .d directory pattern: $pattern"
else
# Use standard extension pattern
pattern="*.${extension}"
fi
else
# Standard file with extension
pattern="*.${extension}"
fi
# Common text files
case "$extension" in
# Shell scripts
sh|bash|zsh|fish)
attributes="text eol=lf diff=shell"
;;
# Web development
html|htm|xhtml|css|scss|sass|less)
attributes="text eol=lf diff=html"
;;
js|jsx|ts|tsx|json|json5)
attributes="text eol=lf diff=javascript"
;;
# Programming languages
php)
attributes="text eol=lf diff=php"
;;
py)
attributes="text eol=lf diff=python"
;;
rb)
attributes="text eol=lf diff=ruby"
;;
go)
attributes="text eol=lf diff=golang"
;;
java|kt|scala)
attributes="text eol=lf diff=java"
;;
c|cpp|h|hpp)
attributes="text eol=lf diff=cpp"
;;
# Documentation
md|markdown|txt)
attributes="text eol=lf"
;;
# Configuration files
yml|yaml|toml|ini|cfg|conf)
attributes="text eol=lf"
;;
# Git config files and similar patterns
git)
attributes="text eol=lf"
;;
gitignore|gitattributes)
attributes="text eol=lf"
;;
# Binary files
png|jpg|jpeg|gif|ico|svg|webp|avif)
attributes="binary"
;;
pdf|doc|docx|xls|xlsx|ppt|pptx)
attributes="binary"
;;
zip|tar|gz|7z|rar)
attributes="binary"
;;
mp3|mp4|avi|mov|wav|ogg)
attributes="binary"
;;
ttf|otf|woff|woff2|eot)
attributes="binary"
;;
# Default for unknown extensions
*)
# Try to guess if it's text by checking if it contains null bytes
if file "$file" | grep -q text; then
attributes="text eol=lf"
else
attributes="binary"
fi
;;
esac
msg_debug "...suggesting $pattern $attributes"
echo "$pattern:$attributes"
}
# Function to check for missing .gitattributes
check_gitattributes() {
local missing_attributes
msg_info "Checking for pattern: $CHECK_PATTERN"
missing_attributes=$(git ls-files | git check-attr -a --stdin | grep "$CHECK_PATTERN" || true)
if [[ -n "$missing_attributes" ]]; then
msg_warn "Missing .gitattributes rules detected"
if [[ $SUGGEST_RULES -eq 1 ]]; then
# Generate suggestions
local suggestions
# Generate the suggestions
suggestions=$(suggest_gitattributes "$missing_attributes")
# Display the suggestions
echo ""
echo "$suggestions"
echo ""
if [[ $WRITE_RULES -eq 1 ]]; then
msg_debug "...writing to .gitattributes"
write_to_gitattributes "$suggestions"
fi
else
msg_err ".gitattributes rule missing for the following files:"
echo "$missing_attributes"
fi
if [[ $EXIT_ON_MISSING -eq 1 ]]; then
return 1
fi
else
msg_success "All files have a corresponding rule in .gitattributes"
fi
return 0
}
# Parse rule string and extract pattern and attributes
parse_rule() {
local rule="$1"
if [[ "$rule" == "#"* ]]; then
# This is a comment line
echo "$rule::"
return
fi
if [[ "$rule" =~ ^([^[:space:]]+)[[:space:]]+(.*)$ ]]; then
echo "${BASH_REMATCH[1]}:${BASH_REMATCH[2]}"
else
echo "$rule::"
fi
}
# Check shell scripts by name regardless of extension
detect_shell_scripts() {
msg_debug "Detecting shell scripts by name regardless of extension..."
local shell_scripts_rules=""
local shell_scripts_found=0
local patterns=()
local attributes=()
# Get already defined rules in .gitattributes
local existing_rules
existing_rules=$(grep -v "^#" .gitattributes || true)
# Get all shell scripts regardless of extension
local shell_scripts
shell_scripts=$(git ls-files | xargs file | grep "shell script" | cut -d: -f1)
if [[ -n "$shell_scripts" ]]; then
shell_scripts_found=$(echo "$shell_scripts" | wc -l | tr -d ' ')
msg_debug "Found $shell_scripts_found potential shell scripts."
# Track scripts that need rules
declare -A scripts_by_dir=()
local need_rule_count=0
# Process each script
while IFS= read -r script; do
local rel_path="${script#./}"
# Skip if exact path already in .gitattributes
if grep -q "^${rel_path} " <<< "$existing_rules"; then
msg_debug "Script already in .gitattributes: $rel_path"
continue
fi
# Skip if file extension already covered
local extension=$(get_file_extension "$rel_path")
if [[ "$extension" != "$rel_path" ]] && grep -q "^\*\.$extension " <<< "$existing_rules"; then
msg_debug "Script covered by extension rule: $rel_path (*.$extension)"
continue
fi
# Check if any parent directory is already covered
local is_covered=0
local dir_path="$rel_path"
while [[ "$dir_path" != "." && "$dir_path" != "/" ]]; do
dir_path=$(dirname "$dir_path")
if [[ "$dir_path" == "." ]]; then
break
fi
# Check if directory or any of its contents are covered
if grep -q "^${dir_path}/\?" <<< "$existing_rules" || grep -q "^${dir_path}/\*" <<< "$existing_rules"; then
msg_debug "Script covered by directory rule: $rel_path (${dir_path})"
is_covered=1
break
fi
done
if [[ $is_covered -eq 1 ]]; then
continue
fi
# Group by directory
local dir=$(dirname "$rel_path")
if [[ "$dir" == "." ]]; then
dir="root"
fi
# Add to appropriate group
if [[ -z "${scripts_by_dir[$dir]:-}" ]]; then
scripts_by_dir[$dir]="$rel_path"
else
scripts_by_dir[$dir]="${scripts_by_dir[$dir]}\n$rel_path"
fi
((need_rule_count++))
done <<< "$shell_scripts"
# Output grouped results
if [[ $need_rule_count -gt 0 ]]; then
patterns+=("# Shell scripts detected by content")
attributes+=("")
# Check if we can use directory-based rules instead of individual files
for dir in "${!scripts_by_dir[@]}"; do
local files_in_dir=$(echo -e "${scripts_by_dir[$dir]}" | wc -l)
local dir_path="$dir"
if [[ "$dir" == "root" ]]; then
# For root directory files, list each individually
while IFS= read -r file; do
patterns+=("$file")
attributes+=("text eol=lf diff=shell")
done <<< "$(echo -e "${scripts_by_dir[$dir]}")"
elif [[ $files_in_dir -gt 2 ]]; then
# If directory has multiple scripts, suggest a directory pattern
patterns+=("# Found $files_in_dir scripts in $dir_path")
attributes+=("")
# Special handling for .d directories
if [[ "$dir_path" =~ \.d$ || "$dir_path" =~ \.d/ ]]; then
patterns+=("$dir_path/*")
else
patterns+=("$dir_path/*")
fi
attributes+=("text eol=lf diff=shell")
# List the files as comments for reference
while IFS= read -r file; do
patterns+=("# - ${file}")
attributes+=("")
done <<< "$(echo -e "${scripts_by_dir[$dir]}" | sort)"
else
# For directories with few scripts, list them individually
while IFS= read -r file; do
patterns+=("$file")
attributes+=("text eol=lf diff=shell")
done <<< "$(echo -e "${scripts_by_dir[$dir]}")"
fi
done
msg_debug "Adding $need_rule_count shell scripts to suggestions (grouped by directory)."
else
msg_debug "All detected shell scripts already have rules."
fi
else
msg_debug "No shell scripts detected."
fi
# Return the formatted arrays
local rules_count=${#patterns[@]}
for ((i=0; i<rules_count; i++)); do
echo "${patterns[$i]}:${attributes[$i]}"
done
}
# Function to suggest gitattributes rules
suggest_gitattributes() {
local missing_attributes="$1"
local files
local extension_suggestions=()
local formatted_suggestions=""
local all_patterns=()
local all_attributes=()
local max_pattern_length=0
# Add header to suggestions
all_patterns+=("# Auto-generated rules - $(date +"%Y-%m-%d %H:%M:%S")")
all_attributes+=("")
msg_info "Suggested .gitattributes rules:"
# First, detect shell scripts and add them to suggestions
msg_info "Detecting shell scripts by content..."
local shell_scripts_rules
shell_scripts_rules=$(detect_shell_scripts)
# Add shell script rules to patterns and attributes arrays
if [[ -n "$shell_scripts_rules" ]]; then
while IFS=':' read -r pattern attributes; do
if [[ -n "$pattern" ]]; then
all_patterns+=("$pattern")
all_attributes+=("$attributes")
# Update max pattern length (skip comments)
if [[ "$pattern" != "#"* ]] && [[ ${#pattern} -gt $max_pattern_length ]]; then
max_pattern_length=${#pattern}
fi
fi
done <<< "$shell_scripts_rules"
fi
# Extract filenames from git check-attr output
files=$(echo "$missing_attributes" | awk -F': ' '{print $1}')
# Get suggestions for each file
declare -A seen_patterns=()
while IFS= read -r file; do
local suggestion=$(suggest_rule "$file")
if [[ -n "$suggestion" ]]; then
IFS=':' read -r pattern attributes <<< "$suggestion"
# Only add each pattern once
if [[ -z "${seen_patterns[$pattern]:-}" ]]; then
extension_suggestions+=("$suggestion")
seen_patterns[$pattern]=1
fi
fi
done <<< "$files"
# Remove duplicates and sort
local unique_extensions=()
mapfile -t unique_extensions < <(printf '%s\n' "${extension_suggestions[@]}" | sort -u)
# Add extension-based suggestions header if we have any
if [[ ${#unique_extensions[@]} -gt 0 ]]; then
all_patterns+=("")
all_attributes+=("")
all_patterns+=("# File extension-based rules")
all_attributes+=("")
# Add extension rules to patterns and attributes arrays
for suggestion in "${unique_extensions[@]}"; do
IFS=':' read -r pattern attributes <<< "$suggestion"
all_patterns+=("$pattern")
all_attributes+=("$attributes")
# Update max pattern length
if [[ ${#pattern} -gt $max_pattern_length ]]; then
max_pattern_length=${#pattern}
fi
done
fi
# Use user-specified format width if provided, otherwise use max_pattern_length
# But ensure it's at least MIN_FORMAT_WIDTH
local format_width=$max_pattern_length
if [[ $FORMAT_WIDTH -gt 0 ]]; then
format_width=$FORMAT_WIDTH
fi
# Ensure minimum width
if [[ $format_width -lt $MIN_FORMAT_WIDTH ]]; then
format_width=$MIN_FORMAT_WIDTH
fi
msg_debug "Using format width: $format_width"
# Format and output all suggestions with proper alignment
local rule_count=${#all_patterns[@]}
for ((i=0; i<rule_count; i++)); do
local pattern="${all_patterns[$i]}"
local attributes="${all_attributes[$i]}"
# Handle comments separately
if [[ "$pattern" == "#"* ]] || [[ -z "$attributes" ]]; then
formatted_suggestions+="$pattern\n"
echo "$pattern"
else
local formatted_rule=$(printf "%-${format_width}s %s\n" "$pattern" "$attributes")
formatted_suggestions+="$formatted_rule\n"
echo "$formatted_rule"
fi
done
# Add final message
echo ""
msg_info "Add these rules to your .gitattributes file to resolve missing attributes."
# Return the full suggestion text so it can be both displayed and written to file
echo -e "$formatted_suggestions"
}
# Write suggestions to .gitattributes file
write_to_gitattributes() {
local suggestions="$1"
local gitattributes=".gitattributes"
# Check if file exists and is writable
if [[ ! -w "$gitattributes" ]]; then
msg_err "Cannot write to $gitattributes. Check permissions."
return 1
fi
# Add a newline at the end of the file if it doesn't have one
if [[ -s "$gitattributes" ]] && [[ $(tail -c 1 "$gitattributes" | wc -l) -eq 0 ]]; then
echo "" >> "$gitattributes"
fi
# Append suggestions to the file
echo -e "$suggestions" >> "$gitattributes"
msg_success "Added suggested rules to $gitattributes"
# Remind to check the file
msg_warn "Please review the changes to ensure they're appropriate for your project."
return 0
}
# Main function
main() {
check_git_installed
check_git_repo
check_git_root
check_gitattributes_exists
check_gitattributes
}
main "$@"

View File

@@ -1,41 +0,0 @@
#!/usr/bin/env bash
#
# Check git repo's files .gitattributes and ensure all of them are mapped.
# Ismo Vuorinen <https://github.com/ivuorinen> 2022
source "${DOTFILES}/config/shared.sh"
set -euo pipefail
# Enable verbosity with VERBOSE=1
VERBOSE="${VERBOSE:-0}"
# Function to check if git is installed
check_git_installed()
{
if ! command -v git &> /dev/null; then
msg_err "git could not be found, please install it first"
fi
}
# Function to check for missing .gitattributes
check_gitattributes()
{
local missing_attributes
missing_attributes=$(git ls-files | git check-attr -a --stdin | grep "text: auto" || true)
if [[ -n "$missing_attributes" ]]; then
echo ".gitattributes rule missing for the following files:"
echo "$missing_attributes"
else
echo "All files have a corresponding rule in .gitattributes"
fi
}
# Main function
main()
{
check_git_installed
check_gitattributes
}
main "$@"