From 9a48ad3381d0a6e0aec347054fd4faaead5691da Mon Sep 17 00:00:00 2001 From: jabuxas Date: Fri, 27 Sep 2024 16:24:00 +0000 Subject: [PATCH] feat: add sdkman and switch to void --- .../fish/.config/fish/completions/sdk.fish | 243 ++++++++++++++++++ .../fish/.config/fish/conf.d/rustup.fish | 1 + .../configs/fish/.config/fish/conf.d/sdk.fish | 111 ++++++++ laptop/configs/fish/.config/fish/config.fish | 5 +- .../fish/functions/__sdkman-noexport-init.sh | 175 +++++++++++++ .../functions/fish_command_not_found.fish | 16 +- .../fish/.config/fish/functions/sdk.fish | 42 +++ laptop/configs/home/.zshrc | 4 + .../configs/sway/.config/sway/settings/init | 4 +- .../tmux/plugins/tmux-plugin-playerctl | 1 - laptop/configs/tmux/.config/tmux/plugins/tpm | 1 - laptop/configs/tmux/.config/tmux/tmux.conf | 12 +- .../base16/base16-default-dark.css | 0 .../waybar/{ => unused}/config-chinese | 0 .../waybar/{ => unused}/dwm-forest.css | 0 .../.config/waybar/{ => unused}/dwm.css | 0 .../.config/waybar/{ => unused}/dwm.jsonc | 0 .../waybar/.config/waybar/{ => unused}/state | Bin .../waybar/{ => unused}/style-melange.css | 0 .../{ => unused}/style-solarized-light.css | 0 .../waybar/{ => unused}/style-solarized.css | 0 .../waybar/{ => unused}/style.css.chinese | 0 22 files changed, 592 insertions(+), 23 deletions(-) create mode 100644 laptop/configs/fish/.config/fish/completions/sdk.fish create mode 100644 laptop/configs/fish/.config/fish/conf.d/rustup.fish create mode 100644 laptop/configs/fish/.config/fish/conf.d/sdk.fish create mode 100644 laptop/configs/fish/.config/fish/functions/__sdkman-noexport-init.sh create mode 100644 laptop/configs/fish/.config/fish/functions/sdk.fish delete mode 160000 laptop/configs/tmux/.config/tmux/plugins/tmux-plugin-playerctl delete mode 160000 laptop/configs/tmux/.config/tmux/plugins/tpm rename laptop/configs/waybar/.config/waybar/{ => unused}/base16/base16-default-dark.css (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/config-chinese (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/dwm-forest.css (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/dwm.css (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/dwm.jsonc (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/state (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/style-melange.css (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/style-solarized-light.css (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/style-solarized.css (100%) rename laptop/configs/waybar/.config/waybar/{ => unused}/style.css.chinese (100%) diff --git a/laptop/configs/fish/.config/fish/completions/sdk.fish b/laptop/configs/fish/.config/fish/completions/sdk.fish new file mode 100644 index 0000000..54693df --- /dev/null +++ b/laptop/configs/fish/.config/fish/completions/sdk.fish @@ -0,0 +1,243 @@ +# Defines autocompletion for SDKMAN! + +# Copyright (c) 2018-2023 Raphael Reitzig +# MIT License (MIT) +# https://github.com/reitzig/sdkman-for-fish + +# Guard: SDKMAN! needs to be installed +if not test -f "$SDKMAN_DIR/bin/sdkman-init.sh" + exit 0 +end + +# # # # # # +# Completion trigger predicates +# # # # # # + +# Test if there is no command +function __fish_sdkman_no_command + set cmd (commandline -opc) + + if [ (count $cmd) -eq 1 ] + return 0 + end + return 1 +end + +# Test if the main command matches one of the parameters +function __fish_sdkman_using_command + set cmd (commandline -opc) + + if [ (count $cmd) -eq 2 ] + if contains $cmd[2] $argv + return 0 + end + end + return 1 +end + +function __fish_sdkman_specifying_candidate + set cmd (commandline -opc) + + if [ (count $cmd) -eq 3 ] # currently, sdk does not support multiple versions + if contains $cmd[2] $argv + return 0 + end + end + return 1 +end + +function __fish_sdkman_command_has_enough_parameters + set cmd (commandline -opc) + + if [ (count $cmd) -ge (math $argv[1] + 2) ]; and contains $cmd[2] $argv[2..-1] + return 0 + end + return 1 +end + +# # # # # # +# Data collectors +# # # # # # + +function __fish_sdkman_candidates + cat "$SDKMAN_DIR"/var/candidates | string replace -a -r ',' '\n' +end + +function __fish_sdkman_candidates_with_versions + set regexpHome (string replace -a '/' '\\/' "$HOME/") + + find "$SDKMAN_DIR"/candidates/ -mindepth 2 -maxdepth 2 -name '*current' \ + | awk -F '/' '{ print $(NF-1) }' \ + | sort -u +end + +function __fish_sdkman_installed_versions + set cmd (commandline -opc) + if [ -d "$SDKMAN_DIR"/candidates/$cmd[3]/current ] + ls -v1 "$SDKMAN_DIR"/candidates/$cmd[3] | grep -v current + end +end + +# # # # # # +# Completion specification +# # # # # # + +# install +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'i install' \ + -d 'Install new version' +complete -c sdk -f -n '__fish_sdkman_using_command i install' \ + -a "(__fish_sdkman_candidates)" +# TODO complete available versions --> issue #4 +complete -c sdk -f -n '__fish_sdkman_specifying_candidate i install' \ + -a 'a.b.c' \ + -d "version list unavailable" +complete -c sdk -f -n '__fish_sdkman_specifying_candidate i install' \ + -a 'x.y.z' \ + -d "Specify path to install custom version." +# Implicit: complete files as fourth parameter +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 3 i install' + # block + +# uninstall +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'rm uninstall' -d 'Uninstall version' +complete -c sdk -f -n '__fish_sdkman_using_command rm uninstall' \ + -a "(__fish_sdkman_candidates_with_versions)" +complete -c sdk -f -n '__fish_sdkman_specifying_candidate rm uninstall' \ + -a "(__fish_sdkman_installed_versions)" +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 2 rm uninstall' + # block + +# list +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'ls list' \ + -d 'List versions' +complete -c sdk -f -n '__fish_sdkman_using_command ls list' \ + -a "(__fish_sdkman_candidates)" +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 1 ls list' + # block + +# use +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'u use' \ + -d 'Use specific version' +complete -c sdk -f -n '__fish_sdkman_using_command u use' \ + -a "(__fish_sdkman_candidates_with_versions)" +complete -c sdk -f -n '__fish_sdkman_specifying_candidate u use' \ + -a "(__fish_sdkman_installed_versions)" +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 2 u use' + # block + +# default +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'd default' \ + -d 'Set default version' +complete -c sdk -f -n '__fish_sdkman_using_command d default' \ + -a "(__fish_sdkman_candidates_with_versions)" +complete -c sdk -f -n '__fish_sdkman_specifying_candidate d default' \ + -a "(__fish_sdkman_installed_versions)" +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 2 d default' + # block + +# current +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'c current' \ + -d 'Display current version' +complete -c sdk -f -n '__fish_sdkman_using_command c current' \ + -a "(__fish_sdkman_candidates)" +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 1 c current' + # block + +# upgrade +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'ug upgrade' \ + -d 'Display what is outdated' +complete -c sdk -f -n '__fish_sdkman_using_command ug upgrade' \ + -a "(__fish_sdkman_candidates_with_versions)" +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 1 ug upgrade' + # block + +# version +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'v version' \ + -d 'Display version' +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 0 v version' + # block + +# help +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'help' \ + -d 'Display help message' +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 0 h help' + # block + +# offline +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'offline' \ + -d 'Set offline status' +complete -c sdk -f -n '__fish_sdkman_using_command offline' \ + -a 'enable' \ + -d 'Make sdk work while offline' +complete -c sdk -f -n '__fish_sdkman_using_command offline' \ + -a 'disable' \ + -d 'Turn on all features' +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 1 offline' + # block + +# selfupdate +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'selfupdate' \ + -d 'Update sdk' +complete -c sdk -f -n '__fish_sdkman_using_command selfupdate' \ + -a 'force' \ + -d 'Force re-install of current version' +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 1 selfupdate' + # block + +# update +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'update' \ + -d 'Reload the candidate list' +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 0 update' + # block + +# flush +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'flush' \ + -d 'Clear out archives and temporary storage folders' +complete -c sdk -f -n '__fish_sdkman_using_command flush' \ + -a 'temp' \ + -d 'Clear out staging work folder' +complete -c sdk -f -n '__fish_sdkman_using_command flush' \ + -a 'version' \ + -d 'Flush version file' +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 1 flush' + # block + +# env +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'e env' \ + -d 'Load environment from .sdkmanrc file' +complete -c sdk -f -n '__fish_sdkman_using_command e env' \ + -a 'init' \ + -d 'Initialize .sdkmanrc file' +complete -c sdk -f -n '__fish_sdkman_using_command e env' \ + -a 'install' \ + -d 'Install all candidate versions listed in .sdkmanrc' +complete -c sdk -f -n '__fish_sdkman_using_command e env' \ + -a 'clear' \ + -d 'Unload currently loaded environment' +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 1 e env' + # block + +# home +complete -c sdk -f -n '__fish_sdkman_no_command' \ + -a 'h home' \ + -d 'Show installation folder of given candidate' +complete -c sdk -f -n '__fish_sdkman_using_command h home' \ + -a "(__fish_sdkman_candidates_with_versions)" +complete -c sdk -f -n '__fish_sdkman_specifying_candidate h home' \ + -a "(__fish_sdkman_installed_versions)" +complete -c sdk -f -n '__fish_sdkman_command_has_enough_parameters 2 h home' + # block diff --git a/laptop/configs/fish/.config/fish/conf.d/rustup.fish b/laptop/configs/fish/.config/fish/conf.d/rustup.fish new file mode 100644 index 0000000..e4cb363 --- /dev/null +++ b/laptop/configs/fish/.config/fish/conf.d/rustup.fish @@ -0,0 +1 @@ +source "$HOME/.cargo/env.fish" diff --git a/laptop/configs/fish/.config/fish/conf.d/sdk.fish b/laptop/configs/fish/.config/fish/conf.d/sdk.fish new file mode 100644 index 0000000..420dc56 --- /dev/null +++ b/laptop/configs/fish/.config/fish/conf.d/sdk.fish @@ -0,0 +1,111 @@ +#!/usr/bin/fish + +# Makes command and binaries from SDKMAN! available in fish. +# Delegates to bash for the `sdk` command. + +# Copyright (c) 2018-2023 Raphael Reitzig +# MIT License (MIT) +# https://github.com/reitzig/sdkman-for-fish + +# Account for custom install locations +if set -q __sdkman_custom_dir + set -gx SDKMAN_DIR "$__sdkman_custom_dir" +end +# Guard: SDKMAN! needs to be installed +if set -q SDKMAN_DIR; and not test -f "$SDKMAN_DIR/bin/sdkman-init.sh" + echo "WARNING: SDKMAN! installation path set to $SDKMAN_DIR, but no installation found there" + exit 0 +end + +# Unless overridden, use the default location: +if not set -q SDKMAN_DIR + set -gx SDKMAN_DIR "$HOME/.sdkman" +end + +set __fish_sdkman_init "$SDKMAN_DIR/bin/sdkman-init.sh" + +# Guard: SDKMAN! needs to be installed +if not test -f "$__fish_sdkman_init" + exit 0 +end + +# Copied from https://github.com/jorgebucaran/fisher/blob/main/functions/fisher.fish to be consistent: +set --query fisher_path || set --local fisher_path $__fish_config_dir +set __fish_sdkman_noexport_init "$fisher_path/functions/__sdkman-noexport-init.sh" + +# Hack for issue #19: +# Create version of sdkman-init that doesn't export any environment variables. +# Refresh if sdkman-init changed. +if begin not test -f "$__fish_sdkman_noexport_init"; + or env test "$__fish_sdkman_init" -nt "$__fish_sdkman_noexport_init" + end + mkdir -p (dirname $__fish_sdkman_noexport_init) + sed -E -e 's/^(\s*).*(export|to_path).*$/\1:/g' "$__fish_sdkman_init" \ + > "$__fish_sdkman_noexport_init" +end + +# Runs the given command in bash, capturing some side effects +# and repeating them on the current fish shell. +# Returns the same status code as the given command. +function __fish_sdkman_run_in_bash + # We need to leave stdin and stdout of sdk free for user interaction. + # So, pipe relevant environment variables (which might have changed) + # through a file. + # But since now getting the exit code of sdk itself is a hassle, + # pipe it as well. + # + # TODO: Can somebody get this to work without the overhead of a file? + set pipe (mktemp) + bash -c "$argv[1]; + echo -e \"\$?\" > $pipe; + env | grep -e '^SDKMAN_\|^PATH' >> $pipe; + env | grep -i -E \"^(`echo \${SDKMAN_CANDIDATES_CSV} | sed 's/,/|/g'`)_HOME\" >> $pipe; + echo \"SDKMAN_OFFLINE_MODE=\${SDKMAN_OFFLINE_MODE}\" >> $pipe; + echo \"SDKMAN_ENV=\${SDKMAN_ENV}\" >> $pipe" # it's not an environment variable! + set bashDump (cat $pipe; rm $pipe) + + set sdkStatus $bashDump[1] + set bashEnv $bashDump[2..-1] + + # If SDKMAN! succeeded, copy relevant environment variables + # to the current shell (they might have changed) + if [ $sdkStatus = 0 ] + for line in $bashEnv + set parts (string split "=" $line) + set var $parts[1] + set value (string join "=" $parts[2..-1]) + + switch "$var" + case "PATH" + # Special treatment: need fish list instead + # of colon-separated list. + set value (string split : "$value") + end + + if test -n value + set -gx $var $value + # Note: This makes SDKMAN_{OFFLINE_MODE,ENV} environment variables. + # That gives it the behaviour we _want_! + end + end + end + + return $sdkStatus +end + +# If this is a subshell of a(n initialized) fish owned by the same user, +# no initialization necessary. +# Otherwise: +if not set -q SDKMAN_CANDIDATES_DIR; or test (ls -ld "$SDKMAN_CANDIDATES_DIR" | awk '{print $3}') != (whoami) + __fish_sdkman_run_in_bash "source $__fish_sdkman_init" +end + +# Set up auto_env +if grep -q "^sdkman_auto_env=true" "$SDKMAN_DIR/etc/config" + function __fish_sdkman_autoenv --on-variable PWD + # Run the (modified) init script, which performs the checks and calls for us! + __fish_sdkman_run_in_bash "source \"$__fish_sdkman_noexport_init\"" + + set -x SDKMAN_OLD_PWD "$PWD" # needed by the Bash implementation + end +end diff --git a/laptop/configs/fish/.config/fish/config.fish b/laptop/configs/fish/.config/fish/config.fish index 72fa7ec..bf110c1 100644 --- a/laptop/configs/fish/.config/fish/config.fish +++ b/laptop/configs/fish/.config/fish/config.fish @@ -3,13 +3,12 @@ if status --is-login set -gx BAT_THEME "Solarized (dark)" set -gx EDITOR "nvim" - set -gx DOCKER_HOST unix://$XDG_RUNTIME_DIR/podman/podman.sock set -gx LS_COLORS "$(vivid generate solarized-dark)" set -gx TERMINAL alacritty if test -z "$WAYLAND_DISPLAY" && test "$XDG_VTNR" -eq 1 set -gx XDG_CURRENT_DESKTOP "sway" - sway + dbus-run-session sway end end if status is-interactive @@ -39,7 +38,7 @@ function pst end if command test -p /dev/stdin - set file (mktemp) + set file (mktemp).log if test $use_ansifilter = true ansifilter > $file else diff --git a/laptop/configs/fish/.config/fish/functions/__sdkman-noexport-init.sh b/laptop/configs/fish/.config/fish/functions/__sdkman-noexport-init.sh new file mode 100644 index 0000000..a86652c --- /dev/null +++ b/laptop/configs/fish/.config/fish/functions/__sdkman-noexport-init.sh @@ -0,0 +1,175 @@ +#!/usr/bin/env bash + +# +# Copyright 2021 Marco Vermeulen +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +# set env vars if not set +if [ -z "$SDKMAN_CANDIDATES_API" ]; then + : +fi + +if [ -z "$SDKMAN_DIR" ]; then + : +fi + +# Load the sdkman config if it exists. +if [ -f "${SDKMAN_DIR}/etc/config" ]; then + source "${SDKMAN_DIR}/etc/config" +fi + +# Read the platform file +SDKMAN_PLATFORM="$(cat "${SDKMAN_DIR}/var/platform")" +: + +# OS specific support (must be 'true' or 'false'). +cygwin=false +darwin=false +solaris=false +freebsd=false +SDKMAN_KERNEL="$(uname -s)" +case "${SDKMAN_KERNEL}" in + CYGWIN*) + cygwin=true + ;; + Darwin*) + darwin=true + ;; + SunOS*) + solaris=true + ;; + FreeBSD*) + freebsd=true +esac + +# Determine shell +zsh_shell=false +bash_shell=false + +if [[ -n "$ZSH_VERSION" ]]; then + zsh_shell=true +elif [[ -n "$BASH_VERSION" ]]; then + bash_shell=true +fi + +# Source sdkman module scripts and extension files. +# +# Extension files are prefixed with 'sdkman-' and found in the ext/ folder. +# Use this if extensions are written with the functional approach and want +# to use functions in the main sdkman script. For more details, refer to +# . +OLD_IFS="$IFS" +IFS=$'\n' +scripts=($(find "${SDKMAN_DIR}/src" "${SDKMAN_DIR}/ext" -type f -name 'sdkman-*.sh')) +for f in "${scripts[@]}"; do + source "$f" +done +IFS="$OLD_IFS" +unset OLD_IFS scripts f + +# Create upgrade delay file if it doesn't exist +if [[ ! -f "${SDKMAN_DIR}/var/delay_upgrade" ]]; then + touch "${SDKMAN_DIR}/var/delay_upgrade" +fi + +# set curl connect-timeout and max-time +if [[ -z "$sdkman_curl_connect_timeout" ]]; then sdkman_curl_connect_timeout=7; fi +if [[ -z "$sdkman_curl_max_time" ]]; then sdkman_curl_max_time=10; fi + +# set curl retry +if [[ -z "${sdkman_curl_retry}" ]]; then sdkman_curl_retry=0; fi + +# set curl retry max time in seconds +if [[ -z "${sdkman_curl_retry_max_time}" ]]; then sdkman_curl_retry_max_time=60; fi + +# set curl to continue downloading automatically +if [[ -z "${sdkman_curl_continue}" ]]; then sdkman_curl_continue=true; fi + +# read list of candidates and set array +SDKMAN_CANDIDATES_CACHE="${SDKMAN_DIR}/var/candidates" +SDKMAN_CANDIDATES_CSV=$(<"$SDKMAN_CANDIDATES_CACHE") +__sdkman_echo_debug "Setting candidates csv: $SDKMAN_CANDIDATES_CSV" +if [[ "$zsh_shell" == 'true' ]]; then + SDKMAN_CANDIDATES=(${(s:,:)SDKMAN_CANDIDATES_CSV}) +else + IFS=',' read -a SDKMAN_CANDIDATES <<< "${SDKMAN_CANDIDATES_CSV}" +fi + +: + +for candidate_name in "${SDKMAN_CANDIDATES[@]}"; do + candidate_dir="${SDKMAN_CANDIDATES_DIR}/${candidate_name}/current" + if [[ -h "$candidate_dir" || -d "${candidate_dir}" ]]; then + : + : + fi +done +unset candidate_name candidate_dir +: + +# source completion scripts +if [[ "$sdkman_auto_complete" == 'true' ]]; then + if [[ "$zsh_shell" == 'true' ]]; then + # initialize zsh completions (if not already done) + if ! (( $+functions[compdef] )) ; then + autoload -Uz compinit + if [[ $ZSH_DISABLE_COMPFIX == 'true' ]]; then + compinit -u -C + else + compinit + fi + fi + autoload -U bashcompinit + bashcompinit + source "${SDKMAN_DIR}/contrib/completion/bash/sdk" + __sdkman_echo_debug "ZSH completion script loaded..." + elif [[ "$bash_shell" == 'true' ]]; then + source "${SDKMAN_DIR}/contrib/completion/bash/sdk" + __sdkman_echo_debug "Bash completion script loaded..." + else + __sdkman_echo_debug "No completion scripts found for $SHELL" + fi +fi + +if [[ "$sdkman_auto_env" == "true" ]]; then + if [[ "$zsh_shell" == "true" ]]; then + function sdkman_auto_env() { + if [[ -n $SDKMAN_ENV ]] && [[ ! $PWD =~ ^$SDKMAN_ENV ]]; then + sdk env clear + fi + if [[ -f .sdkmanrc ]]; then + sdk env + fi + } + + chpwd_functions+=(sdkman_auto_env) + else + function sdkman_auto_env() { + if [[ -n $SDKMAN_ENV ]] && [[ ! $PWD =~ ^$SDKMAN_ENV ]]; then + sdk env clear + fi + if [[ "$SDKMAN_OLD_PWD" != "$PWD" ]] && [[ -f ".sdkmanrc" ]]; then + sdk env + fi + + : + } + + trimmed_prompt_command="${PROMPT_COMMAND%"${PROMPT_COMMAND##*[![:space:]]}"}" + [[ -z "$trimmed_prompt_command" ]] && PROMPT_COMMAND="sdkman_auto_env" || PROMPT_COMMAND="${trimmed_prompt_command%\;};sdkman_auto_env" + fi + + sdkman_auto_env +fi diff --git a/laptop/configs/fish/.config/fish/functions/fish_command_not_found.fish b/laptop/configs/fish/.config/fish/functions/fish_command_not_found.fish index 275b786..2b70a29 100644 --- a/laptop/configs/fish/.config/fish/functions/fish_command_not_found.fish +++ b/laptop/configs/fish/.config/fish/functions/fish_command_not_found.fish @@ -1,8 +1,8 @@ -function fish_command_not_found - set -l pkgs (apk search --quiet cmd:$argv[1]) - set pkgs (string join '|' $pkgs) - echo "$argv[1]: not found" - if test -n "$pkgs" - echo " install with: apk add $pkgs" - end -end +# function fish_command_not_found +# set -l pkgs (apk search --quiet cmd:$argv[1]) +# set pkgs (string join '|' $pkgs) +# echo "$argv[1]: not found" +# if test -n "$pkgs" +# echo " install with: apk add $pkgs" +# end +# end diff --git a/laptop/configs/fish/.config/fish/functions/sdk.fish b/laptop/configs/fish/.config/fish/functions/sdk.fish new file mode 100644 index 0000000..25def1f --- /dev/null +++ b/laptop/configs/fish/.config/fish/functions/sdk.fish @@ -0,0 +1,42 @@ +# Wrapper function for SDKMAN! + +# Copyright (c) 2018-2023 Raphael Reitzig +# MIT License (MIT) +# https://github.com/reitzig/sdkman-for-fish + +function sdk -d "Manage SDKs" + # Guard: SDKMAN! needs to be installed + if not test -f "$__fish_sdkman_init" + # Propose to install SDKMAN! + + function read_confirm + while true + read -l -P "$argv[1] [y/N] " confirm + + switch $confirm + case Y y + return 0 + case '' N n + return 1 + end + end + end + + if read_confirm "You don't seem to have SDKMAN! installed. Install now?" + if not which curl > /dev/null + echo "curl required" + return 1 + end + if not which bash > /dev/null + echo "bash required" + return 1 + end + + curl -s "https://get.sdkman.io" | bash | sed '/All done!/q' + echo "Please open a new terminal/shell to load SDKMAN!" + end + else + # Declare the _actual_ sdk command for fish + __fish_sdkman_run_in_bash "source \"$__fish_sdkman_noexport_init\" && sdk $argv" + end +end diff --git a/laptop/configs/home/.zshrc b/laptop/configs/home/.zshrc index 37f6a06..aab01f6 100644 --- a/laptop/configs/home/.zshrc +++ b/laptop/configs/home/.zshrc @@ -75,3 +75,7 @@ if [ -z "${WAYLAND_DISPLAY}" ] && [ "${XDG_VTNR}" -eq 1 ]; then export XDG_CURRENT_DESKTOP="sway" sway fi + +#THIS MUST BE AT THE END OF THE FILE FOR SDKMAN TO WORK!!! +export SDKMAN_DIR="$HOME/.sdkman" +[[ -s "$HOME/.sdkman/bin/sdkman-init.sh" ]] && source "$HOME/.sdkman/bin/sdkman-init.sh" diff --git a/laptop/configs/sway/.config/sway/settings/init b/laptop/configs/sway/.config/sway/settings/init index 394ba3d..1d59792 100644 --- a/laptop/configs/sway/.config/sway/settings/init +++ b/laptop/configs/sway/.config/sway/settings/init @@ -7,13 +7,15 @@ exec_always { } exec { + pipewire & + pipewire-pulse & waybar & autotiling & gammastep -t 4500:3500 -l -23.5475:-46.63611 & dbus-update-activation-environment WAYLAND_DISPLAY XDG_CURRENT_DESKTOP=sway DISPLAY rm -rf ~/tmp/* ~/scripts/swww.sh - otd-daemon + # otd-daemon ~/scripts/weechat.sh dunst & nextcloud --background & diff --git a/laptop/configs/tmux/.config/tmux/plugins/tmux-plugin-playerctl b/laptop/configs/tmux/.config/tmux/plugins/tmux-plugin-playerctl deleted file mode 160000 index 5e99e7f..0000000 --- a/laptop/configs/tmux/.config/tmux/plugins/tmux-plugin-playerctl +++ /dev/null @@ -1 +0,0 @@ -Subproject commit 5e99e7f28bdc151314ef85266c24947116115538 diff --git a/laptop/configs/tmux/.config/tmux/plugins/tpm b/laptop/configs/tmux/.config/tmux/plugins/tpm deleted file mode 160000 index 99469c4..0000000 --- a/laptop/configs/tmux/.config/tmux/plugins/tpm +++ /dev/null @@ -1 +0,0 @@ -Subproject commit 99469c4a9b1ccf77fade25842dc7bafbc8ce9946 diff --git a/laptop/configs/tmux/.config/tmux/tmux.conf b/laptop/configs/tmux/.config/tmux/tmux.conf index 2702f3d..66d1ed5 100644 --- a/laptop/configs/tmux/.config/tmux/tmux.conf +++ b/laptop/configs/tmux/.config/tmux/tmux.conf @@ -2,10 +2,6 @@ set -g prefix C-a unbind C-b bind-key C-a send-prefix -set -g default-terminal "tmux-256color" -set-option -sa terminal-overrides ",xterm-kitty:RGB" -set-option -ga terminal-overrides ",xterm-256color:Tc" - unbind C-o bind C-o display-popup -E "tms" @@ -62,10 +58,6 @@ bind-key -T copy-mode-vi 'C-l' select-pane -R bind-key -T copy-mode-vi 'C-\' select-pane -l bind-key -T copy-mode-vi 'C-Space' select-pane -t:.+ -set -g @plugin 'tmux-plugins/tpm' -set -g @plugin 'tmux-plugins/tmux-sensible' -set -g @plugin 'richin13/tmux-plugin-playerctl' - set-option -g set-titles on set-option -g set-titles-string "#S / #W" @@ -76,4 +68,6 @@ set -g visual-bell off set -as terminal-overrides ',*:Smulx=\E[4::%p1%dm' # undercurl support set -as terminal-overrides ',*:Setulc=\E[58::2::%p1%{65536}%/%d::%p1%{256}%/%{255}%&%d::%p1%{255}%&%d%;m' # underscore colours - needs tmux-3.0 set -g status-position top -run '~/.config/tmux/plugins/tpm/tpm' + +# set -g default-terminal "tmux-256color" +set -sg terminal-overrides ",*:RGB" diff --git a/laptop/configs/waybar/.config/waybar/base16/base16-default-dark.css b/laptop/configs/waybar/.config/waybar/unused/base16/base16-default-dark.css similarity index 100% rename from laptop/configs/waybar/.config/waybar/base16/base16-default-dark.css rename to laptop/configs/waybar/.config/waybar/unused/base16/base16-default-dark.css diff --git a/laptop/configs/waybar/.config/waybar/config-chinese b/laptop/configs/waybar/.config/waybar/unused/config-chinese similarity index 100% rename from laptop/configs/waybar/.config/waybar/config-chinese rename to laptop/configs/waybar/.config/waybar/unused/config-chinese diff --git a/laptop/configs/waybar/.config/waybar/dwm-forest.css b/laptop/configs/waybar/.config/waybar/unused/dwm-forest.css similarity index 100% rename from laptop/configs/waybar/.config/waybar/dwm-forest.css rename to laptop/configs/waybar/.config/waybar/unused/dwm-forest.css diff --git a/laptop/configs/waybar/.config/waybar/dwm.css b/laptop/configs/waybar/.config/waybar/unused/dwm.css similarity index 100% rename from laptop/configs/waybar/.config/waybar/dwm.css rename to laptop/configs/waybar/.config/waybar/unused/dwm.css diff --git a/laptop/configs/waybar/.config/waybar/dwm.jsonc b/laptop/configs/waybar/.config/waybar/unused/dwm.jsonc similarity index 100% rename from laptop/configs/waybar/.config/waybar/dwm.jsonc rename to laptop/configs/waybar/.config/waybar/unused/dwm.jsonc diff --git a/laptop/configs/waybar/.config/waybar/state b/laptop/configs/waybar/.config/waybar/unused/state similarity index 100% rename from laptop/configs/waybar/.config/waybar/state rename to laptop/configs/waybar/.config/waybar/unused/state diff --git a/laptop/configs/waybar/.config/waybar/style-melange.css b/laptop/configs/waybar/.config/waybar/unused/style-melange.css similarity index 100% rename from laptop/configs/waybar/.config/waybar/style-melange.css rename to laptop/configs/waybar/.config/waybar/unused/style-melange.css diff --git a/laptop/configs/waybar/.config/waybar/style-solarized-light.css b/laptop/configs/waybar/.config/waybar/unused/style-solarized-light.css similarity index 100% rename from laptop/configs/waybar/.config/waybar/style-solarized-light.css rename to laptop/configs/waybar/.config/waybar/unused/style-solarized-light.css diff --git a/laptop/configs/waybar/.config/waybar/style-solarized.css b/laptop/configs/waybar/.config/waybar/unused/style-solarized.css similarity index 100% rename from laptop/configs/waybar/.config/waybar/style-solarized.css rename to laptop/configs/waybar/.config/waybar/unused/style-solarized.css diff --git a/laptop/configs/waybar/.config/waybar/style.css.chinese b/laptop/configs/waybar/.config/waybar/unused/style.css.chinese similarity index 100% rename from laptop/configs/waybar/.config/waybar/style.css.chinese rename to laptop/configs/waybar/.config/waybar/unused/style.css.chinese