Bottles: Add cli.

This commit is contained in:
Dmitry Voronin 2024-12-12 05:27:20 +03:00
parent a8198e354f
commit a02dd3f695
Signed by: voronind
SSH key fingerprint: SHA256:3kBb4iV2ahufEBNq+vFbUe4QYfHt98DHQjN7QaptY9k
14 changed files with 116 additions and 66 deletions

View file

@ -20,6 +20,7 @@ in {
+ mkHost "fmpmaven" "10.30.22.10" 22 "root" + mkHost "fmpmaven" "10.30.22.10" 22 "root"
+ mkHost "home" "10.0.0.1" 22143 "root" + mkHost "home" "10.0.0.1" 22143 "root"
+ mkHost "laptop" "192.168.1.9" 22143 "root" + mkHost "laptop" "192.168.1.9" 22143 "root"
+ mkHost "max" "10.0.0.13" 22143 "root"
+ mkHost "nixbuilder" "10.0.0.1" 22143 "nixbuilder" + mkHost "nixbuilder" "10.0.0.1" 22143 "nixbuilder"
+ mkHost "pi" "192.168.1.6" 22143 "root" + mkHost "pi" "192.168.1.6" 22143 "root"
+ mkHost "pocket" "192.168.1.11" 22143 "root" + mkHost "pocket" "192.168.1.11" 22143 "root"

View file

@ -100,6 +100,10 @@
desc = "Run"; desc = "Run";
run = openWith "steam-run"; run = openWith "steam-run";
}]; }];
bottle_run = [{
desc = "Run bottle";
run = openWith "btp";
}];
unlock = [{ unlock = [{
desc = "Unlock"; desc = "Unlock";
block = true; block = true;
@ -125,7 +129,6 @@
rules = let rules = let
defaultUse = [ defaultUse = [
"text" "text"
"archive"
"archive_fast" "archive_fast"
"hex" "hex"
]; ];
@ -157,8 +160,8 @@
(mkMime "text/html" [ "browser" ]) (mkMime "text/html" [ "browser" ])
(mkMime "application/vnd.openxmlformats-officedocument.*" [ "document" ]) (mkMime "application/vnd.openxmlformats-officedocument.*" [ "document" ])
(mkName "*.xlsx" [ "document" ]) (mkName "*.xlsx" [ "document" ])
(mkMime "inode/directory" [ "audio_shuffle" ])
(mkMime "application/x-executable" [ "steam_run" ]) (mkMime "application/x-executable" [ "steam_run" ])
{ mime = "inode/directory"; use = [ "archive" "bottle_run" "audio_shuffle" ]; }
(mkMime "*" [ ]) (mkMime "*" [ ])
]; ];
}; };

View file

@ -357,7 +357,7 @@
# Autocomplete with names of all archives. # Autocomplete with names of all archives.
function _comp_archive_names() { function _comp_archive_names() {
_autocomplete_first $(_archive_names) _autocomplete $(_archive_names)
} }
# Check if file is an archive. # Check if file is an archive.

View file

@ -19,7 +19,7 @@
function _complete_ask_model() { function _complete_ask_model() {
local IFS=$'\n' local IFS=$'\n'
local models=($(ollama list | sed -e "1d" | cut -f1)) local models=($(ollama list | sed -e "1d" | cut -f1))
_autocomplete_first ''${models[@]} _autocomplete ''${models[@]}
} }
complete -F _complete_ask_model ask_model complete -F _complete_ask_model ask_model

View file

@ -4,54 +4,14 @@
# There are also options like -o nospace. see man for more info. # There are also options like -o nospace. see man for more info.
# Usage: _foo() { _autocomplete "{foo,bar}" } ; complete -F _foo foo # Usage: _foo() { _autocomplete "{foo,bar}" } ; complete -F _foo foo
function _autocomplete() { function _autocomplete() {
local IFS=$'\n' local iter use cur
local commands="''${*}" cur=''${COMP_WORDS[COMP_CWORD]}
use="''${@//\\ /___}"
COMPREPLY=() for iter in $use; do
if [[ $iter =~ ^$cur ]]; then
local cur="''${COMP_WORDS[COMP_CWORD]}" COMPREPLY+=( $(printf "%q" "''${iter//___/ }") )
local prev="''${COMP_WORDS[COMP_CWORD-1]}"
local command="''${COMP_WORDS[0]}"
COMPREPLY=( $(compgen -W "''${commands}" -- ''${cur}) )
return 0
}
# Autocomplete only first argument.
function _autocomplete_first() {
local IFS=$'\n'
local commands="''${*}"
COMPREPLY=()
local cur="''${COMP_WORDS[COMP_CWORD]}"
local prev="''${COMP_WORDS[COMP_CWORD-1]}"
local command="''${COMP_WORDS[0]}"
if [[ "''${prev}" = "''${command}" ]]; then
COMPREPLY=( $(compgen -W "''${commands}" -- ''${cur}) )
return 0
fi
}
# Autocomplete only first argument and the rest with files.
function _autocomplete_first_ls() {
local IFS=$'\n'
local commands="''${*}"
COMPREPLY=()
local cur="''${COMP_WORDS[COMP_CWORD]}"
local prev="''${COMP_WORDS[COMP_CWORD-1]}"
local command="''${COMP_WORDS[0]}"
if [[ "''${prev}" = "''${command}" ]]; then
COMPREPLY=( $(compgen -W "''${commands}" -- ''${cur}) )
return 0
else
COMPREPLY=( $(compgen -W "$(ls)" -- ''${cur}) )
return 0
fi fi
done
} }
# Autocomplete by grepping file names. # Autocomplete by grepping file names.
@ -60,12 +20,8 @@
COMPREPLY=() COMPREPLY=()
local pattern="''${1}" local pattern="''${1}"
local cur="''${COMP_WORDS[COMP_CWORD]}" local candidates=$("$(ls | grep -E ''${pattern})")
local prev="''${COMP_WORDS[COMP_CWORD-1]}" _autocomplete ''${candidates}
local command="''${COMP_WORDS[0]}"
COMPREPLY=( $(compgen -W "$(ls | grep -E ''${pattern})" -- ''${cur}) )
return 0
} }
# Autocomplete nested program. # Autocomplete nested program.

View file

@ -0,0 +1,89 @@
{ ... }: {
text = ''
# Switch bottle.
# Usage: bt <NAME>
function bt() {
export SHELL_NAME="''${*}"
}
# Create new bottle.
# Usage: btc [ENV] [EXTRA]
function btc() {
local env="''${1}"
[[ "''${env}" = "" ]] && env="gaming"
bottles-cli new --bottle-name "''${SHELL_NAME}" --environment "''${env}" "''${@:2}" 2> /dev/null
}
# Run a file inside a bottle.
# Usage: btre <EXE> [EXTRA]
function btre() {
bottles-cli run -b "''${SHELL_NAME}" -e "''${@}"
}
# Run a program inside a bottle.
# Usage: btr <NAME> [EXTRA]
function btr() {
bottles-cli run -b "''${SHELL_NAME}" -p "''${@}"
}
# List bottles.
function btl() {
bottles-cli list bottles 2> /dev/null
}
# List programs in a bottle.
function btlp() {
bottles-cli programs -b "''${SHELL_NAME}" 2> /dev/null
}
# Add a program to bottle.
# Usage: bta <NAME> <EXE> [EXTRA]
function bta() {
local name="''${1}"
local exe=$(realpath "''${2}")
if [[ "''${exe}" = "" ]]; then
help bta
return 2
fi
bottles-cli add -b "''${SHELL_NAME}" -n "''${name}" -p "''${exe}" "''${@:3}" 2> /dev/null
}
# Set bottle env var.
# Usage: bte <NAME=VALUE>
function bte() {
local env="''${1}"
if [[ "''${env}" = "" ]]; then
help bte
return 2
fi
bottles-cli edit -b "''${SHELL_NAME}" --env-var "''${@}" 2> /dev/null
}
# Play bottle.
# Usage: btp <BOTTLE>
function btp() {
local bottle="''${1##*/}"
if [[ "''${bottle}" = "" ]]; then
help btp
return 2
fi
local program=$(bottles-cli programs -b "''${bottle}" 2> /dev/null | sed -n -e "s/^- //; 2p")
bottles-cli run -b "''${bottle}" -p "''${program}"
}
function _comp_bottles_list() {
_autocomplete $(bottles-cli list bottles 2> /dev/null | sed -e "1d; s/^- //")
}
function _comp_programs_list() {
local IFS=$'\n'
_autocomplete $(bottles-cli programs -b "''${SHELL_NAME}" 2> /dev/null | sed -e "1d; s/^- //")
}
complete -F _comp_bottles_list bt btp
complete -F _comp_programs_list btr
'';
}

View file

@ -65,7 +65,7 @@
function _comp_cdd() { function _comp_cdd() {
local IFS=$'\n' local IFS=$'\n'
local dirs=($(_cdd_directories)) local dirs=($(_cdd_directories))
_autocomplete_first ''${dirs[@]} _autocomplete ''${dirs[@]}
} }
complete -o nosort -o filenames -F _comp_cdd cdd complete -o nosort -o filenames -F _comp_cdd cdd

View file

@ -329,7 +329,7 @@
# Autocomplete with my git emails. # Autocomplete with my git emails.
function _gu() { function _gu() {
_autocomplete_first hi@voronind.com dd.voronin@fsight.ru _autocomplete hi@voronind.com dd.voronin@fsight.ru
} }
complete -F _gu gu complete -F _gu gu

View file

@ -21,7 +21,7 @@
# Autocomplete with available functions. # Autocomplete with available functions.
function _help_functions() { function _help_functions() {
_autocomplete_first $(find_function) _autocomplete $(find_function)
} }
complete -F _help_functions help h complete -F _help_functions help h

View file

@ -391,7 +391,7 @@
} }
function _comp_name_parse() { function _comp_name_parse() {
_autocomplete_first_ls $(find_function | grep ^parse) _autocomplete $(find_function | grep ^parse)
} }
complete -o filenames -F _comp_name_parse name_parse complete -o filenames -F _comp_name_parse name_parse

View file

@ -32,7 +32,7 @@
} }
function _complete_own() { function _complete_own() {
_autocomplete_first_ls $(_get_users) _autocomplete $(_get_users)
} }
complete -F _complete_own own complete -F _complete_own own

View file

@ -25,7 +25,7 @@
} }
function _complete_s() { function _complete_s() {
_autocomplete_first $(_get_users) _autocomplete $(_get_users)
} }
complete -F _complete_s s complete -F _complete_s s

View file

@ -78,7 +78,7 @@
# Autocomplete with running sessions once. # Autocomplete with running sessions once.
function _complete_tmux_session() { function _complete_tmux_session() {
_autocomplete_first "$(tmux list-sessions 2> /dev/null | sed -e 's/:.*//')" _autocomplete "$(tmux list-sessions 2> /dev/null | sed -e 's/:.*//')"
} }
# Autocomplete with running sessions. # Autocomplete with running sessions.
@ -88,7 +88,7 @@
# Autocomplete with current dir name and dirs inside this one. # Autocomplete with current dir name and dirs inside this one.
function _complete_tmux_name() { function _complete_tmux_name() {
_autocomplete_first "''${PWD##*/}"$'\n'$(ls --classify | grep /$ | sed -e 's/\/$//') _autocomplete "''${PWD##*/}"$'\n'$(ls --classify | grep /$ | sed -e 's/\/$//')
} }
complete -F _complete_tmux_session ta complete -F _complete_tmux_session ta

View file

@ -131,6 +131,7 @@ in {
(mkStatic "10.0.0.10" "9c:1c:37:62:3f:d5") # Printer. (mkStatic "10.0.0.10" "9c:1c:37:62:3f:d5") # Printer.
(mkStatic "10.0.0.11" "dc:a6:32:f5:77:95") # RPi. (mkStatic "10.0.0.11" "dc:a6:32:f5:77:95") # RPi.
(mkStatic "10.0.0.12" "ec:9c:32:ad:bc:4a") # Camera. (mkStatic "10.0.0.12" "ec:9c:32:ad:bc:4a") # Camera.
(mkStatic "10.0.0.13" "c0:a5:e8:b5:d9:16") # Max.
]; ];
}; };
}; };